Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/asp.net/31.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

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/ms-access/4.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
C# FindControl返回空文本对象 --%> 印度 美国 法国 俄罗斯_C#_Asp.net_Gridview - Fatal编程技术网

C# FindControl返回空文本对象 --%> 印度 美国 法国 俄罗斯

C# FindControl返回空文本对象 --%> 印度 美国 法国 俄罗斯,c#,asp.net,gridview,C#,Asp.net,Gridview,前端 <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="BindGridView._Default" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> &

前端

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="BindGridView._Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="false" OnRowEditing="OnRowEditing"
            OnRowCommand="GridView1_RowCommand" OnRowDataBound="GridView1_RowDataBound" OnRowUpdating="GridView1_RowUpdating">

            <Columns>
                <asp:TemplateField HeaderText="Name1">
                    <ItemTemplate>
                        <asp:Label ID="lblName1" runat="server" Text='<%# Eval("Name1")%>' />
                    </ItemTemplate>
                    <EditItemTemplate>
                        <asp:TextBox ID="txtUName1" runat="server" Text='<%# Eval("Name1")%>' />
                    </EditItemTemplate>
                </asp:TemplateField>

                 <asp:TemplateField HeaderText="Name2" >
                    <ItemTemplate>
                        <asp:Label ID="lblName2" runat="server" Text='<%# Eval("Name2")%>' />
                    </ItemTemplate>
                    <EditItemTemplate>
                        <asp:TextBox ID="txtUName2" runat="server" Text='<%# Eval("Name2")%>' />
                    </EditItemTemplate>
                </asp:TemplateField>

                  <asp:TemplateField HeaderText="Name3" >
                    <ItemTemplate>
                        <asp:Label ID="lblName3" runat="server" Text='<%# Eval("Name3")%>' />
                    </ItemTemplate>
                    <EditItemTemplate>
                        <asp:TextBox ID="txtUName3" runat="server" Text='<%# Eval("Name3")%>' />
                    </EditItemTemplate>
                </asp:TemplateField>

                 <asp:TemplateField HeaderText="Country">
                    <ItemTemplate>
                        <asp:Label ID="lblCountry" runat="server" Text='<%# Eval("Country")%>' />                       
                    </ItemTemplate>
                    <EditItemTemplate>
                     <asp:HiddenField ID="hdnCountry" runat="server" Value='<%#Eval("country") %>' />
                       <%-- <asp:TextBox ID="txtCountry" runat="server" Text='<%# Eval("Country")%>' />--%>
                        <asp:DropDownList ID="DrpDownList1" runat="server" >
                        <asp:ListItem>India</asp:ListItem>
                        <asp:ListItem>United States</asp:ListItem>
                        <asp:ListItem>France</asp:ListItem>
                        <asp:ListItem>Russia</asp:ListItem>
                        </asp:DropDownList>
                    </EditItemTemplate>
                </asp:TemplateField>

                 <asp:TemplateField>
                    <ItemTemplate>
                        <asp:LinkButton ID="LinkButton1" Text="Edit" runat="server" CommandName="Edit" CommandArgument='<%# DataBinder.Eval(Container.DataItem, "Id") %>' />
                    </ItemTemplate>
                    <EditItemTemplate>
                        <asp:LinkButton ID="LinkButton2" Text="Update" runat="server" CommandName="Update"/>
                        <asp:LinkButton ID="LinkButton3" Text="Cancel" runat="server" OnClick="OnCancel" />
                    </EditItemTemplate>
                </asp:TemplateField>               
            </Columns>
        </asp:GridView>
    </div>
    </form>
</body>
</html>
使用系统;
使用System.Collections.Generic;
使用System.Linq;
使用System.Web;
使用System.Web.UI;
使用System.Web.UI.WebControl;
使用系统数据;
命名空间BindGridView
{
公共部分类\u默认值:System.Web.UI.Page
{
public List lstEmp=新列表();
受保护的无效页面加载(对象发送方、事件参数e)
{
如果(!this.IsPostBack)
{
BindGrid();
}
}
受保护的void BindGrid()
{
List lstEmp=ReturnList();
GridView1.DataSource=lstEmp;
GridView1.DataBind();
}
受保护的void OnRowEditing(对象发送方,GridViewEditEventArgs e)
{        
GridView1.EditIndex=0;
BindEdit(会话[“Name”].ToString());
}
受保护的void OnCancel(对象发送方、事件参数e)
{
GridView1.EditIndex=-1;
这个.BindGrid();
}
私有void BindEdit(字符串id)
{
List lstEmp=ReturnList();
lstEmp=新列表(lstEmp.Where(x=>x.Id.ToString()==Id.ToList());
GridView1.DataSource=lstEmp;
GridView1.DataBind();
}
受保护的void GridView1_row命令(对象发送方,GridViewCommandEventArgs e)
{ 
尝试
{
if(e.CommandName==“Edit”)//重定向到MangeRulepage并将查询字符串模式变量设置为“Edit”
{
//BindEdit(例如CommandArgument.ToString());
会话[“名称”]=e.CommandArgument.ToString();
}
}
捕获(例外情况除外)
{
掷骰子;
}     
}
受保护的void GridView1_RowDataBound(对象发送方,GridViewRowEventArgs e)
{
如果(e.Row.RowType==DataControlRowType.DataRow&&GridView1.EditIndex==e.Row.RowIndex)
{
DropDownList ddl=(DropDownList)e.Row.FindControl(“DrpDownList1”);
HiddenField hdnval=(HiddenField)e.Row.FindControl(“hdncontry”);
如果(ddl!=null)
{ 
ddl.Items.FindByValue(hdnval.Value).Selected=true;
}
}
}
受保护的无效GridView1_行更新(对象发送方,GridViewUpdateEventArgs e)
{
//GridView1.EditIndex=-1;
TextBox tb=(TextBox)GridView1.FindControl(“TxtName”);//在更新时无法获取对象*tb*
如果(tb!=null)
{
string text=tb.text;
}          
}
公营雇员
{
公共int Id{get;set;}
公共字符串名称1{get;set;}
公共字符串名称2{get;set;}
公共字符串名称3{get;set;}
公共字符串国家{get;set;}
}
私有列表返回列表()
{
DataTable dt=新的DataTable();
AddRange(newdatacolumn[3]{newdatacolumn(“Id”)、newdatacolumn(“Name”)、newdatacolumn(“Country”)});
增加(1,“1,2,3”,“美国”);
增加(2,“,”印度“);
增加(3,“4,5,6”,“法国”);
增加(4),“俄罗斯”);
对于(int i=0;i
在ASP.NETGridView上工作了很长时间后,我一直在EditItemTemplate中查找GridView中的文本框对象。在谷歌上搜索过去几个小时的信息,但无法找到问题的解决方案


请提供帮助。

尝试使用以下代码查找文本框

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;

namespace BindGridView
{
    public partial class _Default : System.Web.UI.Page
    {
        public List<Employee> lstEmp = new List<Employee>();
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!this.IsPostBack)
            {

                BindGrid();
            }

        }

        protected void BindGrid()
        {
            List<Employee> lstEmp = ReturnList();
            GridView1.DataSource = lstEmp;
            GridView1.DataBind();
        }

        protected void OnRowEditing(object sender, GridViewEditEventArgs e)
        {        
            GridView1.EditIndex = 0;
            BindEdit(Session["Name"].ToString());
        }

        protected void OnCancel(object sender, EventArgs e)
        {
            GridView1.EditIndex = -1;
            this.BindGrid();
        }

        private void BindEdit(string id)
        {
            List<Employee> lstEmp = ReturnList();
            lstEmp = new List<Employee>(lstEmp.Where(x => x.Id.ToString() == id).ToList());

            GridView1.DataSource = lstEmp;
            GridView1.DataBind();
        }

        protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
        { 
            try
            {
                if (e.CommandName == "Edit")//redirect to MangeRulepage and set query string Mode variable to 'EDIT'
                {
                    //BindEdit(e.CommandArgument.ToString());
                    Session["Name"] = e.CommandArgument.ToString();
                }
            }
            catch (Exception ex)
            {
                throw ex;
            }     
        }

        protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
        {
            if (e.Row.RowType == DataControlRowType.DataRow && GridView1.EditIndex == e.Row.RowIndex)
            {
                DropDownList ddl = (DropDownList)e.Row.FindControl("DrpDownList1");
                HiddenField hdnval = (HiddenField)e.Row.FindControl("hdnCountry");
                if (ddl != null)
                { 
                    ddl.Items.FindByValue(hdnval.Value).Selected = true;
                }
            }
        }

        protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)
        {
            //GridView1.EditIndex = -1;           

            TextBox tb = (TextBox)GridView1.FindControl("txtUName1");// Not getting object *tb* in case of update

            if (tb != null)
            {
                string text = tb.Text;
            }          
        }

        public class Employee
        {
          public int Id { get; set; }
          public string Name1 { get; set; }
          public string Name2 { get; set; }
          public string Name3 { get; set; }
          public string Country { get; set; }            
        }

        private List<Employee> ReturnList()
        {
            DataTable dt = new DataTable();
            dt.Columns.AddRange(new DataColumn[3] { new DataColumn("Id"), new DataColumn("Name"), new DataColumn("Country") });
            dt.Rows.Add(1, "1,2,3", "United States");
            dt.Rows.Add(2, "", "India");
            dt.Rows.Add(3, "4,5,6", "France");
            dt.Rows.Add(4, "", "Russia");

            for (int i = 0; i < dt.Rows.Count; i++)
            {
                Employee emp = new Employee();
                emp.Id = Convert.ToInt32(dt.Rows[i]["Id"]);
                emp.Name1 = dt.Rows[i]["Name"].ToString();
                emp.Country = dt.Rows[i]["Country"].ToString();
                lstEmp.Add(emp);
            }

            return lstEmp;
        }
    }


}


希望这对您有所帮助

不要在这里发布所有代码,否则您将得不到答案。只需发布导致错误的行。
 GridViewRow row = TaskGridView.Rows[e.RowIndex];

TextBox tb = (TextBox)(row.Cells[0].Controls[0]); 
  TextBox tb = (TextBox)(row.FindControl("txtUName1"));