извличане и попълване на стойности в модален изскачащ прозорец на bootstrap

Това се опитвам да постигна тук. Потребителят щраква върху бутон и се появява изскачащият модален изскачащ прозорец. Потребителят въвежда стойността на идентификатора на събитието в текстовото поле на модалния изскачащ прозорец и искам информация относно събитието да се показва в другите полета в модалния изскачащ прозорец.

Написах функция под събитие txtEventId_TextChanged и успях да получа стойността, въведена в текстовото поле за идентификатор на събитие. Успях да предам тази стойност в базата данни и да извлека съответните й стойности и от базата данни.

Проблемът ми сега е, че не мога да покажа тези данни в модалния изскачащ прозорец.

Ето HTML кода:

          <!-- Maintainenance Modal -->


        <div class="modal fade" id="maintenanceModal" role="dialog" tabindex = -1 aria-labelledby="myModalLabel" aria-hidden="true" data-backdrop="false">
            <div class="modal-dialog">

               <!-- Maintaineance Modal content-->

                <div class="modal-content">
                        <div class="modal-header">
                            <button type="button" class="close" data-dismiss="modal">&times;</button>
                               <h4 class="modal-title">Maintain Event</h4>
                        </div>

                          <div class="row">
                                <div class="col-xs-2">
                                    <div class ="form-group">
                                        <label for="eventID" id="lblEventId">EventID</label> 
                                    </div>
                                </div>
                                <div class="col-xs-6">
                                    <div class="form-group">
                                        <asp:TextBox ID="txtEventId" runat="server" CssClass="form-control dialogtextbox" AutoPostBack="false" OnTextChanged="txtEventId_TextChanged"></asp:TextBox>
                                    </div>
                                </div>
                            </div>
                    <asp:HiddenField ID="HiddenField1" runat="server" />
                <div class="modal-body">
                  <div class="EventsIcons"> 
                         <div class ="form-group">
                            <label for="MaintainDropDown" id="MaintainEventLabel">Select The Event Type </label>
                            <select id="MaintainDropDown" runat="server" class="btn btn-default dropdown-toggle eventdropdown" data-toggle="dropdown" aria-expanded="true">
                                <option value="WorkAnniversary">WORKANNIVERSARY</option>
                                <option value="Birthday">BIRTHDAY</option>
                                <option value="Community">COMMUNITY</option>
                                <option value="FoodSafety">FOOD SAFETY</option>
                                <option value="Health&Safety">HEALTH & SAFETY</option>
                                <option value="Holiday">HOLIDAY</option>
                                <option value="Maintenance">MAINTENANCE</option>
                                <option value="QualityAudit">QUALITY AUDIT</option>
                                <option value="SocialEvent">SOCIAL EVENT</option>
                                <option value="Stat-Holiday">STAT-HOLIDAY</option>
                                <option value="Sustainability">SUSTAINABILITY</option>
                                <option value="TownHall">TOWN HALL</option>
                                <option value="Visitor">VISITOR</option>
                                <option value="Wellness">WELLNESS</option>
                            </select> 
                        </div>


                 </div> 

                    <div class="Description">
                        <label for="description" id="MaintainDescription">Description</label>
                        <textarea class="form-control" rows="5" id="maintainTxtDescription" name="eventdescription" runat="server"></textarea>
                    </div>

                    <div class="row">
                        <div class="col-xs-2">
                            <div class="form-group">
                                <label id="Label3">Start Time</label>
                            </div>
                        </div>
                        <div class='col-xs-6'>
                            <div class="form-group">
                                <div class='input-group date' id="maintainStartDate">
                                    <asp:TextBox ID="maintainTxtStartDate" runat="server" CssClass="form-control dialogtextbox"></asp:TextBox>
                                    <span class="input-group-addon">
                                        <span class="glyphicon glyphicon-calendar"></span>
                                    </span>
                                </div>
                            </div>
                        </div>
                        <div class="col-xs-4">
                            <div class="form-group">
                                <div class="input-group date" id="startTime">
                                    <asp:TextBox ID="maintainTxtStartTime" runat="server" CssClass="form-control dialogtextbox"></asp:TextBox>
                                    <span class="input-group-addon">
                                        <span class="glyphicon glyphicon-time"></span>
                                    </span>
                                </div>
                           </div>
                        </div>
                    </div>

                    <div class="row">
                        <div class="col-xs-2">
                          <div class="form-group">
                            <label id="Label4">End Time</label>
                          </div>
                        </div>
                        <div class="col-xs-6">
                          <div class="form-group">
                                <div class="input-group date" id="endDate">
                                    <asp:TextBox ID="maintainTxtEndDate" runat="server" CssClass="form-control dialogtextbox"></asp:TextBox>
                                    <span class="input-group-addon">    
                                        <span class="glyphicon glyphicon-calendar"></span>
                                    </span>
                                </div>
                            </div>
                          </div>   
                          <div class="col-xs-4">
                            <div class="form-group">
                                <div class="input-group date" id="endTime">
                                    <asp:TextBox ID="maintainTxtEndTime" runat="server" CssClass="form-control dialogtextbox"></asp:TextBox>
                                    <span class="input-group-addon">
                                        <span class="glyphicon glyphicon-time"></span>
                                    </span>
                                </div>
                            </div>
                          </div>
                    </div>

                    <div class="row">
                        <div class="col-xs-offset-1 col-xs-6">
                            <div class="form-group">
                                <asp:CheckBox ID="maintainChkBoxAllDayEvents" runat="server" CssClass="checkbox" Text="All Day Event" OnClick="document.getElementById('maintainTxtStartTime').disabled = this.checked;document.getElementById('maintainTxtEndTime').disabled = this.checked;" />
                            </div>
                        </div>
                        <div class="col-xs-offset-1 col-xs-4">
                            <div class="form-group">
                                <asp:Button ID="btnMaintainSubmit" runat="server" Text="SUBMIT" 
                                    CssClass="btn btn-group-justified btn-success" />
                            </div>
                        </div>
                    </div>

                </div>

            <div class="modal-footer">
      <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
    </div>
  </div>

</div>

И ето моят код зад кода.

    protected void txtEventId_TextChanged(object sender, EventArgs e)
    {
        BusinessLogicLayer BL = new BusinessLogicLayer();

        EventId = Convert.ToInt32(txtEventId.Text);

        try
        {
          DataTable dt =  BL.BLGetEventDetails(EventId);

          foreach (DataRow row in dt.Rows)
          {
              StartDate = row["StartDate"].ToString();
              EndDate = row["EndDate"].ToString();
              StartTime = row["StartTime"].ToString();
              EndTime = row["EndTime"].ToString();
              EventDescription = row["EventDescription"].ToString();
              EventType = row["EventType"].ToString();

              if (StartDate.Equals(""))
              {
                  MessageBox.Show("EventId Does Not Exists");
                  maintainTxtStartDate.Text = "";
                  maintainTxtStartTime.Text = "";
                  maintainTxtEndDate.Text = "";
                  maintainTxtEndTime.Text = "";
                  MaintainDropDown.Disabled = true;
              }
              else
              {
                  maintainTxtStartDate.Text = StartDate;
                  maintainTxtStartTime.Text = StartTime;
                  maintainTxtEndDate.Text = EndDate;
                  maintainTxtEndTime.Text = EndTime;
                  MaintainDropDown.Value = EventType;
                  maintainTxtDescription.InnerText = EventDescription;
              }

          }


        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.Message, "txtEventId_TextChanged", MessageBoxButtons.OK, MessageBoxIcon.Error);
        }
    }

Ако посоча AutoPostBack="true" за txtEventId, изскачащият прозорец изчезва от екрана, след като въведа стойността и натисна Enter. Ако задам AutoPostBack = "false", тогава стойностите не се попълват, тъй като контролата не отива към функцията txtEventId_TextChanged. Не искам да задавам AutoPostBack="true", защото по време на обратна връзка цялата страница ще се презареди и модалният изскачащ прозорец ще изчезне. Опитах да настроя scriptmanager и updatepanel за него, но тъй като вече имам друг съществуващ scriptmanager и updatepanel, добавен в страницата Default.aspx, не мога да добавя нов към него.

Моля, уведомете ме какво правя грешно и как да поправя това. Вашето ръководство е високо оценено.


person metalwailer    schedule 12.08.2015    source източник


Отговори (1)


Имате две възможности:

  1. RegisterStartupScript

    Използвайте RegisterStartupScript в края на вашия метод, за да изпратите JS код на клиента, вие ще изпратите повикването към вашия модал по този начин

    ScriptManager.RegisterStartupScript(this, typeof(Page), "callModal", 
    "$('#maintenanceModal').modal();", true);
    

    Това е най-лесният начин да постигнете това, което искате

  2. PageMethods

    Можете да използвате PageMethods, за да върнете JSON със стойностите, които искате да покажете, по този начин не е необходимо да правите Postback и ще получите информацията, която искате. Вижте изискванията и как да използвате PageMethods

person Enrique Zavaleta    schedule 12.08.2015