Панель обновления и выпадающий список Выбранное изменение индекса Проблема - PullRequest
1 голос
/ 18 февраля 2012

У меня есть две выпадающие категории и подкатегории на моей странице.Также у меня есть htmleditor на той же странице.Ниже мой aspx

<div class="clearfx">
    </div>
     <div>
         <label>
             Description :
                </label>
                 <div style="padding-left: 10px; margin-left: 146px;">
                    <cc:HtmlEditor ID="Editor" runat="server" Height="600px" Width="850px" EnableViewState="true" />
                            </div>
                        </div>
                        <div class="clearfx">
                        </div>
                        <div>
                            <asp:UpdatePanel runat="server" ID="up" UpdateMode="Always" ChildrenAsTriggers="true">
                                <ContentTemplate>
                                    <label>Category : </label>
                                    <asp:DropDownList runat="server" ID="Categories" Width="200px" AutoPostBack="True"
                                        OnSelectedIndexChanged="CategoriesSelectedIndexChanged">
                                    </asp:DropDownList>
                                   <asp:RequiredFieldValidator ID="rfvCountry" runat="server" ErrorMessage="Choose a category."
                                        ControlToValidate="Categories" Display="None" EnableTheming="False" EnableViewState="False"
                                        InitialValue="-1" SetFocusOnError="True" ValidationGroup="grpReg"></asp:RequiredFieldValidator>
                                    <asp:ValidatorCalloutExtender ID="rfvCountry_ValidatorCalloutExtender" runat="server"
                                        Enabled="True" TargetControlID="rfvCountry">
                                    </asp:ValidatorCalloutExtender>
                                     <asp:ImageButton runat="server" ID="Refresh" ImageAlign="AbsMiddle" 
                                        ImageUrl="~/cdn/images/refresh.png" onclick="RefreshClick"/> 
                                         <span class="helptext">(click on refresh image, incase subcategories do not load.)</span>
                                </ContentTemplate>

                            </asp:UpdatePanel>

                        </div>
                        <div class="clearfx">
                        </div>

<div>
                            <label>
                                Sub Category :
                            </label>
                            <asp:DropDownList runat="server" ID="SubCategories"  Width="200px">
                            </asp:DropDownList>
                            <asp:RequiredFieldValidator ID="RequiredFieldValidator2" runat="server" ErrorMessage="Choose a sub category."
                                ControlToValidate="SubCategories" Display="None" EnableTheming="False" EnableViewState="False"
                                InitialValue="-1" SetFocusOnError="True" ValidationGroup="grpReg"></asp:RequiredFieldValidator>
                            <asp:ValidatorCalloutExtender ID="ValidatorCalloutExtender2" runat="server" Enabled="True"
                                TargetControlID="RequiredFieldValidator2">
                            </asp:ValidatorCalloutExtender>
                        </div>

Что я делаю, так это то, что при выбранном изменении индекса выпадающего списка категорий я заполняю подкатегории.для подавления обратной записи я использую панель обновления, но моя проблема в том, что выбранное изменение индекса срабатывает, но раскрывающиеся подкатегории не связываются.Когда я удаляю панель обновления, то она работает нормально, но мой HTML-редактор теряет свое значение, даже имея свое собственное и Page enableviewstate = true.Пожалуйста, помогите мне.

Мои методы Codebehind: выпадающее меню Выбранное событие изменения индекса:

protected void CategoriesSelectedIndexChanged(object sender, EventArgs e)
        {
            if (Categories.SelectedIndex > 0)
            {
                BindSubCategory(Common.ParseInt(Categories.SelectedItem.Value));
            }
            else
            {
                SubCategories.SelectedIndex = 0;
                SubCategories.Items.Clear();
            }
        } 

Событие загрузки страницы:

 protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                BindGrid();
                BindCategories();
            }
        }

 private void BindCategories()
        {
            List<Category> cat = _categoryRepository.GetAll().ToList();
            Common.BindDropdown(cat, Categories); // static method
        }
 public static class Common
    {
 /// <summary>
        /// 
        /// </summary>
        /// <param name="list"></param>
        /// <param name="ddl"></param>
        public static void BindDropdown(IList list, DropDownList ddl)
        {
            if (list.Count>0)
            {


                    ddl.DataSource = list;
                    ddl.DataTextField = "Name";
                    ddl.DataValueField = "Id";
                    ddl.DataBind();
                    ddl.Items.Insert(0, new ListItem("---Select---", "-1"));

            }
        }
}

Ответы [ 2 ]

0 голосов
/ 18 февраля 2012

Попробуйте это:

<div class="clearfx"> 
</div> 

<div> 
    <label> Description : </label> 
    <div style="padding-left: 10px; margin-left: 146px;"> 
        <cc:HtmlEditor ID="Editor" runat="server" Height="600px" Width="850px" EnableViewState="true" /> 
    </div> 
</div> 

<div class="clearfx"> 
</div> 


<asp:UpdatePanel runat="server" ID="up" UpdateMode="Always" ChildrenAsTriggers="true"> 
    <ContentTemplate> 
        <div>
            <label>Category : </label> 
            <asp:DropDownList runat="server" ID="Categories" Width="200px" AutoPostBack="True" 
                OnSelectedIndexChanged="CategoriesSelectedIndexChanged"> 
            </asp:DropDownList> 
            <asp:RequiredFieldValidator ID="rfvCountry" runat="server" ErrorMessage="Choose a category." 
                ControlToValidate="Categories" Display="None" EnableTheming="False" EnableViewState="False" 
                InitialValue="-1" SetFocusOnError="True" ValidationGroup="grpReg"></asp:RequiredFieldValidator> 
            <asp:ValidatorCalloutExtender ID="rfvCountry_ValidatorCalloutExtender" runat="server" 
                Enabled="True" TargetControlID="rfvCountry"> 
            </asp:ValidatorCalloutExtender> 
            <asp:ImageButton runat="server" ID="Refresh" ImageAlign="AbsMiddle"  
                ImageUrl="~/cdn/images/refresh.png" onclick="RefreshClick"/>  
            <span class="helptext">(click on refresh image, incase subcategories do not load.)</span> 

            <div class="clearfx"> 
            </div> 

            <div> 
                <label> Sub Category : </label> 
                <asp:DropDownList runat="server" ID="SubCategories"  Width="200px"> 
                </asp:DropDownList> 
                <asp:RequiredFieldValidator ID="RequiredFieldValidator2" runat="server" ErrorMessage="Choose a sub category." 
                    ControlToValidate="SubCategories" Display="None" EnableTheming="False" EnableViewState="False" 
                    InitialValue="-1" SetFocusOnError="True" ValidationGroup="grpReg"></asp:RequiredFieldValidator> 
                <asp:ValidatorCalloutExtender ID="ValidatorCalloutExtender2" runat="server" Enabled="True" 
                    TargetControlID="RequiredFieldValidator2"> 
                </asp:ValidatorCalloutExtender> 
            </div>

        </div>  
    </ContentTemplate> 
</asp:UpdatePanel>
0 голосов
/ 18 февраля 2012

Вам необходимо поместить подкатегории в другую панель обновления и добавить соответствующие триггеры (установите вторую панель на срабатывание события выпадающего списка «Выбранные в обмене»).

 <Triggers>
            <asp:AsyncPostBackTrigger ControlId="Categories" 
              EventName="SelectedIndexChanged" />
  </Triggers>

образец здесь

...