Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/asp.net/34.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Asp.net 将新行添加到listview将删除以上选定的下拉列表清除_Asp.net_Listview_Drop Down Menu - Fatal编程技术网

Asp.net 将新行添加到listview将删除以上选定的下拉列表清除

Asp.net 将新行添加到listview将删除以上选定的下拉列表清除,asp.net,listview,drop-down-menu,Asp.net,Listview,Drop Down Menu,当我将新行添加到上面的列表视图时,选定的dropdownlist将被清除。出现此问题的原因是什么 protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { FirstListViewRow(); BindDataToGridviewDropdownlist();

当我将新行添加到上面的列表视图时,选定的dropdownlist将被清除。出现此问题的原因是什么

protected void Page_Load(object sender, EventArgs e)
{
            if (!Page.IsPostBack)
            {
                FirstListViewRow();
                BindDataToGridviewDropdownlist();
            }
        }
        protected void BindDataToGridviewDropdownlist()
        {
            DataSet dsDept = new DataSet();
            dsDept.ReadXml(Server.MapPath("XMLFile2.xml"));
            DataView dv = dsDept.Tables[0].DefaultView;
            foreach (var list in listview1.Items)
            {
                if (list.ItemType == ListViewItemType.DataItem)
                {
                    DropDownList ddf = (DropDownList)list.FindControl("ddldatatype");
                    ddf.DataSource = dv;
                    ddf.DataTextField = "value";
                    ddf.DataBind();
                    ddf.Items.Insert(0, new ListItem("--Select--", "0"));
                }
            }
        }
        private void FirstListViewRow()
        {
            DataTable dt = new DataTable();
            DataRow dr = null;
            dt.Columns.Add(new DataColumn("OrderNo", typeof(string)));
            dt.Columns.Add(new DataColumn("ColumnTitle", typeof(string)));
            dt.Columns.Add(new DataColumn("Datatype", typeof(string)));
            dt.Columns.Add(new DataColumn("Examples", typeof(string)));
            dt.Columns.Add(new DataColumn("Options", typeof(string)));
            dt.Columns.Add(new DataColumn("Delete", typeof(string)));
            dr = dt.NewRow();
            dt.Rows.Add(dr);
            dr["OrderNo"] = 1;
            Session["CurrentTable"] = dt;
            listview1.DataSource = dt;
            listview1.DataBind();
        }

        private void AddNewRow()
        {
            int rowIndex = 0;
            if (Session["CurrentTable"] != null)
            {
                DataTable dtCurrentTable = (DataTable)Session["CurrentTable"];
                DataRow drCurrentRow = null;
                if (dtCurrentTable.Rows.Count > 0)
                {
                    for (int i = 1; i <= dtCurrentTable.Rows.Count; i++)
                    {
                        Label TextBoxorder = (Label)listview1.Items[rowIndex].FindControl("txtorder");
                        TextBox TextBoxcolumnname = (TextBox)listview1.Items[rowIndex].FindControl("txtcolumnname");
                        DropDownList DropDatatype = (DropDownList)listview1.Items[rowIndex].FindControl("ddldatatype");
                        DropDownList Dropexample = (DropDownList)listview1.Items[rowIndex].FindControl("ddlexamples");
                        TextBox TextBoxoptions = (TextBox)listview1.Items[rowIndex].FindControl("txtoptions");
                        CheckBox Checkdel = (CheckBox)listview1.Items[rowIndex].FindControl("chkdel");

                        drCurrentRow = dtCurrentTable.NewRow();
                        drCurrentRow["OrderNo"] = i + 1;

                        // dtCurrentTable.Rows[i - 1]["Order"] = TextBoxorder.Text;
                        dtCurrentTable.Rows[i - 1]["ColumnTitle"] = TextBoxcolumnname.Text;
                        dtCurrentTable.Rows[i - 1]["Datatype"] = DropDatatype.Text;
                        dtCurrentTable.Rows[i - 1]["Examples"] = Dropexample.Text;
                        dtCurrentTable.Rows[i - 1]["Options"] = TextBoxoptions.Text;
                        dtCurrentTable.Rows[i - 1]["Delete"] = Checkdel.Text;

                        rowIndex++;
                    }
                    dtCurrentTable.Rows.Add(drCurrentRow);
                    Session["CurrentTable"] = dtCurrentTable;
                    listview1.DataSource = dtCurrentTable;
                    listview1.DataBind();
                    Label txn = (Label)listview1.Items[rowIndex].FindControl("txtorder");
                    txn.Focus();
                }
            }
            else
            {
                Response.Write("Session is null");
            }
            BindDataToGridviewDropdownlist();
        }
        protected void btnGenerate_Click(object sender, EventArgs e)
        {


        }
        protected void btnAdd_Click(object sender, EventArgs e)
        {
            AddNewRow();
        }

        protected void btndelete_Click(object sender, EventArgs e)
        {
            DataTable dt = new DataTable();
            if (Session["CurrentTable"] != null)
            {
                dt = (DataTable)Session["CurrentTable"];
                int j = 0;
                for (int i = 0; i < listview1.Items.Count; i++)
                {
                    ListViewDataItem items = listview1.Items[i];
                    CheckBox chkBox = (CheckBox)items.FindControl("chkdel");

                    if (chkBox.Checked == true)
                    {
                        dt.Rows.RemoveAt(j);
                        dt.AcceptChanges();
                    }
                    else
                    {
                        j++;
                    }
                }
                Session["CurrentTable"] = dt;
                listview1.DataSource = dt;
                listview1.DataBind();
                BindDataToGridviewDropdownlist();
            }
        }

        protected void btnClear_Click(object sender, EventArgs e)
        {
            listview1.Items.Clear();
        }
    }
}
受保护的无效页面加载(对象发送方,事件参数e)
{
如果(!Page.IsPostBack)
{
FirstListViewRow();
BindDataToGridviewDropdownlist();
}
}
受保护的void BindDataToGridviewDropdownlist()
{
数据集dsDept=新数据集();
dsDept.ReadXml(Server.MapPath(“XMLFile2.xml”);
DataView dv=dsDept.Tables[0].DefaultView;
foreach(listview1.Items中的变量列表)
{
if(list.ItemType==ListViewItemType.DataItem)
{
DropDownList ddf=(DropDownList)list.FindControl(“ddldatatype”);
ddf.DataSource=dv;
ddf.DataTextField=“值”;
ddf.DataBind();
Insert(0,newlistItem(“--Select--”和“0”);
}
}
}
私有void FirstListViewRow()
{
DataTable dt=新的DataTable();
数据行dr=null;
Add(新的数据列(“OrderNo”,typeof(string));
添加(新的数据列(“ColumnTitle”,typeof(string));
添加(新的数据列(“数据类型”,typeof(字符串));
Add(新数据列(“示例”,typeof(字符串));
添加(新的数据列(“选项”,typeof(字符串));
添加(新数据列(“删除”,typeof(字符串));
dr=dt.NewRow();
dt.Rows.Add(dr);
dr[“OrderNo”]=1;
会话[“当前表”]=dt;
listview1.DataSource=dt;
listview1.DataBind();
}
私有void AddNewRow()
{
int rowIndex=0;
if(会话[“CurrentTable”]!=null)
{
DataTable dtCurrentTable=(DataTable)会话[“CurrentTable”];
DataRow drCurrentRow=null;
如果(dtCurrentTable.Rows.Count>0)
{

对于(int i=1;i在该列表视图中添加属性DataKeyNames,如下所示:

<asp:listview id="listview1" runat="server" datakeynames="Datatype" xmlns:asp="#unknown"></asp:listview>
以下是BindDataToGridviewDropdownlist方法的外观:

protected void BindDataToGridviewDropdownlist()
    {
        DataSet dsDept = new DataSet();
        dsDept.ReadXml(Server.MapPath("XMLFile2.xml"));
        DataView dv = dsDept.Tables[0].DefaultView;
        foreach (var list in listview1.Items)
        {
            if (list.ItemType == ListViewItemType.DataItem)
            {
                DropDownList ddf = (DropDownList)list.FindControl("ddldatatype");
                ddf.DataSource = dv;
                ddf.DataTextField = "value";
                ddf.DataBind();
                ddf.Items.Insert(0, new ListItem("--Select--", "0"));

                ListViewDataItem di = (ListViewDataItem)list;
                string dataType = listview1.DataKeys[di.DisplayIndex].Values[0].ToString();
                ddf.SelectedValue = dataType;
            }

        }
    }
protected void BindDataToGridviewDropdownlist()
    {
        DataSet dsDept = new DataSet();
        dsDept.ReadXml(Server.MapPath("XMLFile2.xml"));
        DataView dv = dsDept.Tables[0].DefaultView;
        foreach (var list in listview1.Items)
        {
            if (list.ItemType == ListViewItemType.DataItem)
            {
                DropDownList ddf = (DropDownList)list.FindControl("ddldatatype");
                ddf.DataSource = dv;
                ddf.DataTextField = "value";
                ddf.DataBind();
                ddf.Items.Insert(0, new ListItem("--Select--", "0"));

                ListViewDataItem di = (ListViewDataItem)list;
                string dataType = listview1.DataKeys[di.DisplayIndex].Values[0].ToString();
                ddf.SelectedValue = dataType;
            }

        }
    }