0

ユーザーコントロールでデータベースから値をロードしたい

ユーザー コントロールを追加できますが、ユーザー コントロールに値を読み込むことができません

コード:

Add.aspx.cs

以下のコードは、複数のユーザー コントロールを追加し、以前のコントロール値を保持するためのものです。

    public List<string> NoOfControls
    {
        get
        {
            return ViewState["NoOfControls"] == null ? new List<string>() : (List<string>)ViewState["NoOfControls"];

        }
        set
        {
            ViewState["NoOfControls"] = value;
        }

    }


    protected override void LoadViewState(object savedState)
    {
        base.LoadViewState(savedState);

        GenerateControls();
    }



    private void GenerateControls()
    {
        foreach (string i in NoOfControls)
        {
            VisaUserControl ctrl = (VisaUserControl)Page.LoadControl("VisaUserControl.ascx");

            ctrl.ID = i;
            this.rpt1.Controls.Add(ctrl);
        }
    }

    protected void btnAddVisa_Click(object sender, EventArgs e)
    {

        List<string> temp = null;
        var uc = (VisaUserControl)this.LoadControl(@"VisaUserControl.ascx");

        string id = Guid.NewGuid().ToString();
        uc.ID = id;

        temp = NoOfControls;
        temp.Add(id);
        NoOfControls = temp;
        rpt1.Controls.Add(uc);
    }

Edit.aspx.cs

以下のコードは、ユーザーコントロールでデータベースから値をロードするためのものです

using (OleDbCommand cmd = new OleDbCommand("Select * from visa_details where emp_id = '"+ empid +"'", DbConnection))
using (OleDbDataAdapter da = new OleDbDataAdapter(cmd))
{

   OleDbDataReader DR1 = cmd.ExecuteReader();
   while(DR1.Read())
   {
     //Here I can get values
      string visaNumb = DR1[2].ToString();
      string visaCountry = DR1[3].ToString();
      string visaType = DR1[4].ToString();
      string visaEntry = DR1[5].ToString();
      string expiryDate = DR1[6].ToString();

      for (int i = 0; i < y; i++)
      {
       VisaUserControl userconrol = (VisaUserControl)Page.LoadControl("VisaUserControl.ascx");
       userconrol.TextVisaNumber = visaNumb;
       userconrol.VisaCountry = visaCountry;
       userconrol.VisaType = visaType;
       userconrol.VisaEntry = visaEntry;
       userconrol.ExpiryDate = expiryDate;

      repeater1.Controls.Add(userconrol);
      }
     }
    }  

.ascx.cs

ここに値がありますが、ロード時にすべての値が削除されます

protected void Page_Load(object sender, EventArgs e)
{
 txtUser.Text = Request.Form[txtUser.UniqueID];
 dropCountry.SelectedValue = Request.Form[dropCountry.UniqueID];
 dropVisa.SelectedValue = Request.Form[dropVisa.UniqueID];
 dropEntry.SelectedValue = Request.Form[dropEntry.UniqueID];
 txtDate.Text = Request.Form[txtDate.UniqueID];
}

public string TextVisaNumber
{
  get { return txtUser.Text; }
  set { txtUser.Text = value; }
}

public string VisaCountry
{
 get { return dropCountry.SelectedValue; }
 set { dropCountry.SelectedValue = value; }
}

public string VisaType
{
 get { return dropVisa.SelectedValue; }
 set { dropVisa.SelectedValue = value; }
}

public string VisaEntry
{
 get { return dropEntry.SelectedValue; }
 set { dropEntry.SelectedValue = value; }
}

public string ExpiryDate
{
  get
  {
    return txtDate.Text;
  }
  set
  {
    txtDate.Text = value;
  }
}

何か案は?前もって感謝します

4

1 に答える 1