先贴代码:
protected void Page_Load(object sender, EventArgs e) { this.gvCon.MyBind+=new MyGridView.MyBind_Delegate(Bind); //这一句不用管 !,MyGridView 的需要! if (Page.IsPostBack == false) { Bind(); } }
在 Bind 函数的动态绑定 编辑列。 当点 编辑时, 可以改变为 编辑样式, 但是, 当点击 Update 或 Cancel 时 , 数据丢失 !!这时, 我们采用的做法是 在 PageLoad 重新 Bind 一次!! 这就多Bind的了一次。 而且,在这一次Bind之后,会刷新页面的值啊, 再 Update 时, 不是没有效果了吗!!还要在RowDataBound 函数里加上
if (e.Row.RowIndex == this.gvTypeList.EditIndex) return;
麻烦, 这个问题也一直困扰着我很长时间。直到最近,决心把它搞下去。
方法一:如果用 Ajax , 最高效的方式,就是在按钮回发的时候,不要把整个控件放到 UpdatePanel 里, 用 PageMethods 调用后台 WebMethod 所写的方法(其实是 WebService),返回操作结果(要定义一些 XML 来约束 结果集)。这样回发的负荷最少,适用于结果集数据量比较小和操作模式单一的情况。 但是对编程水平要求偏高。如果数据量大或操作模式复杂的话, 可回发,或让 UpdatePanel 完成这个工作。
方法二:通过 Trace ,发现, Edit 的时候,__EVENTTARGET 变量为GridView控件ID, __EVENTARGUMENT 变量为 命令$行索引。 而Update和 Cancel 两个变量是没有值 的, 我试着利用这一点,给动态创建的回发按钮绑定脚本事件设置两个变量,测试可行。这个方案应该是普遍受用的。
public string GetPostBackJs(string Command, int Index) { return string.Format(@"$('#__EVENTTARGET').val('{0}');$('#__EVENTARGUMENT').val('{1}');", this.UniqueID, Command + "$" + Index.ToString()); }
在创建按钮的地方设置属性:
editTc.Controls.Add(new ImageButton() { CommandName = CommandEnum.Cancel.ToString(), ImageUrl = this.CancelImgUrl, AlternateText = "取消" , OnClientClick= GetPostBackJs(CommandEnum.Cancel.ToString() , this.EditIndex ) });
OK。
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索变量
, 按钮
, this
, tostring
, bind
cancel
gridview动态绑定数据、gridview动态绑定列、gridview 动态绑定、动态创建gridview、gridview绑定数据,以便于您获取更多的相关知识。