4

パネルの内側にデータグリッドがあるページに、ajax コントロール ツールキットの AJAX アコーディオンがあります。行の編集をクリックすると、複数行のテキスト ボックスを作成するための 1 つの列のカスタム itemtemplate があります。行の更新をクリックすると、テキスト ボックスの元のコンテンツがテキスト ボックスにレンダリングされます。テキストボックスではなくリテラルに更新して戻ることになっています。DataBind() を !IsPostBack に入れると、アコーディオン ペインをクリックしてもレンダリングされません。何か案は?

コード:

    protected void Page_Load(object sender, EventArgs e)
        {
            announ.HeaderStyle.CssClass = "header";
                        announ.Width = Unit.Percentage(100);
                        announ.GridLines = GridLines.None;
                        announ.AutoGenerateColumns = false;
                        announ.CellPadding = 10;
                        announ.CellSpacing = 0;
                        announ.HorizontalAlign = HorizontalAlign.Center;
                        announ.HeaderStyle.Font.Bold = true;
                        announ.EnableViewState = false;
                        announ.AlternatingItemStyle.BackColor = System.Drawing.Color.GhostWhite;
                        //announ.DeleteCommand += AnnounDeleteCommand;
                        announ.EditCommand += announ_EditCommand;
                        announ.UpdateCommand += announ_UpdateCommand;
                        announ.CancelCommand += announ_CancelCommand;
                        announ.DataKeyField = "id";
                        var tc1 = new TemplateColumn
                                      {
                                          HeaderTemplate = new
                                              DataGridTemplate(ListItemType.Header, "Announcement"),
                                          ItemTemplate = new DataGridTemplate(ListItemType.Item, "announcement_text"),
                                          EditItemTemplate = new
                                              DataGridTemplate(ListItemType.EditItem, "announcement_text")
                                      };



                    var editColumn = new EditCommandColumn
                                         {
                                             ButtonType = ButtonColumnType.PushButton,
                                             HeaderText = "Edit",
                                             EditText = "Edit",
                                             UpdateText = "Update",
                                             CancelText = "Cancel"
                                         };
    var dateColumn = new BoundColumn {HeaderText = "Posted On", DataField = "date", ReadOnly = true};
                    var expirationColumn = new BoundColumn {HeaderText = "Expiration Date", DataField = "expiration_date"};
    announ.Columns.Add(tc1);
                    announ.Columns.Add(dateColumn);
                    announ.Columns.Add(expirationColumn);
    announ.DataSource = myAnnouncements;
                    announ.DataBind();

var deptMgtaccord = new Accordion
                                        {
                                            ID = "deptMgtaccord",
                                            HeaderCssClass = "accordion-header",
                                            HeaderSelectedCssClass = "accordion-headerSelected",
                                            AutoSize = AutoSize.None,
                                            SelectedIndex = 0,
                                            FadeTransitions = true,
                                            TransitionDuration = 250,
                                            FramesPerSecond = 40,
                                            RequireOpenedPane = false,
                                            SuppressHeaderPostbacks = true
                                        };
                if (IsPostBack)
                {
                    deptMgtaccord.SelectedIndex = selected;
                }

                var announcementPane = new AccordionPane {ID = "announcementPane"};
                announcementPane.HeaderContainer.Attributes.Add("onmouseover", "this.style.backgroundColor='#e3e2e2';");
                announcementPane.HeaderContainer.Attributes.Add("onmouseout", "this.style.backgroundColor='#ffffff';");
                announcementPane.HeaderContainer.Controls.Add(new LiteralControl("Announcements >>"));
                announcementPane.ContentContainer.Controls.Add(announ);
                deptMgtaccord.Panes.Add(announcementPane);
                var statsPane = new AccordionPane {ID = "statsPane"};
                statsPane.HeaderContainer.Attributes.Add("onmouseover", "this.style.backgroundColor='#e3e2e2';");
                statsPane.HeaderContainer.Attributes.Add("onmouseout", "this.style.backgroundColor='#ffffff';");
                statsPane.HeaderContainer.Controls.Add(new LiteralControl("Statistics >>"));
                statsPane.ContentContainer.Controls.Add(new LiteralControl("Stats"));
                deptMgtaccord.Panes.Add(statsPane);
ph1.Controls.Add(deptMgtaccord);
    }

           protected void announ_CancelCommand(object source, DataGridCommandEventArgs e)
            {
                announ.EditItemIndex = -1;
                announ.DataBind();
            }

            protected void announ_UpdateCommand(object source, DataGridCommandEventArgs e)
            {
                var dc = new MTCDataDataContext();
                var announText = (TextBox) e.Item.Cells[1].Controls[1];
                int announId = (int)announ.DataKeys[e.Item.ItemIndex];
                var currentAnnoun = (from a in dc.announcements
                                     where a.id == announId
                                     select a).SingleOrDefault();
                currentAnnoun.announcement_text = announText.Text;
                dc.SubmitChanges();

                announ.EditItemIndex = -1;
                announ.DataBind();
            }

            protected void announ_EditCommand(object source, DataGridCommandEventArgs e)
            {
                announ.EditItemIndex = e.Item.ItemIndex;
                announ.DataBind();
            }


public class DataGridTemplate : ITemplate
    {
        ListItemType templateType;
        string columnName;
        public DataGridTemplate(ListItemType type, string colname)
        {
            templateType = type;
            columnName = colname;
        }

        public void InstantiateIn(Control container)
        {
            Literal lc = new Literal();
            TextBox tb = new TextBox();
            switch (templateType)
            {
                case ListItemType.Header:
                    lc.Text = "<B>" + columnName + "</B>";
                    container.Controls.Add(lc);
                    break;
                case ListItemType.Item:
                    lc.DataBinding += lc_DataBinding;
                    container.Controls.Add(lc);
                    break;
                case ListItemType.EditItem:
                    tb.TextMode = TextBoxMode.MultiLine;
                    tb.Rows = 6;
                    tb.Columns = 57;
                    tb.DataBinding += tb_DataBinding;
                    container.Controls.Add(tb);
                    break;
                case ListItemType.Footer:
                    lc.Text = "<I>" + columnName + "</I>";
                    container.Controls.Add(lc);
                    break;
            }
        }
        void tb_DataBinding(object sender, EventArgs e)
        {
            TextBox tb = (TextBox)sender;
            DataGridItem row = (DataGridItem)tb.NamingContainer;
            tb.ID = "txt_" + row.ItemIndex;
            tb.Text = DataBinder.Eval(row.DataItem, columnName).ToString();
        }
        void lc_DataBinding(object sender, EventArgs e)
        {
            Literal lc = (Literal)sender;
            DataGridItem row = (DataGridItem)lc.NamingContainer;
            lc.ID = "txt_" + row.ItemIndex;
            lc.Text = DataBinder.Eval(row.DataItem, columnName).ToString();
        }
    }
4

1 に答える 1

1

コントロールが ControlTree に戻ってイベントを発生させるためには、要求ごとに動的コントロールをPreInitに追加する必要があります。

ページ イベント:
PreInit

典型的な使用法:
開始ステージが完了した後、初期化ステージが開始する前に発生します。

このイベントは、次の目的で使用します。

  • IsPostBack プロパティをチェックして、ページが初めて処理されるかどうかを判断します。この時点で、IsCallback および IsCrossPagePostBack プロパティも設定されています。
  • 動的コントロールを作成または再作成します。
  • マスター ページを動的に設定します。
  • Theme プロパティを動的に設定します。
  • プロファイル プロパティ値の読み取りまたは設定。

    注: リクエストがポストバックの場合、コントロールの値はまだビュー ステートから復元されていません。この段階でコントロール プロパティを設定すると、次のイベントでその値が上書きされる可能性があります。

于 2011-02-25T19:41:17.263 に答える