单独控制IE WebControl里面的Treeview的几个动作的Postback
2024-07-21 02:23:17
供稿:网友
在使用这个treeview是经常需要将动作postback到服务器端来做一些数据操作,如onexpanded或者selectindexchange等。treeview控件提供了一个autopostback的属性来设置这个treeview是否需要进行postback的动作来让后台操作数据。但是这个属性一旦设成true的话,那么treeview的所有动作都会postback回去将页面刷新,不管是expaned还是selectindexchangek都postback回去一次,很多时候我们只是需要将其中的某种事件postback回去而已。如果所有的事件都postback的话,不但影响用户体验还有影响系统性能。解决这个问题的方法是自己处理每种动作的postback,如果条件不成立就不postback,尽量减少不必要的postback。
下面就举个例子讲讲怎么自己控制postback的动作。
protected microsoft.web.ui.webcontrols.treeview tvschema;
private void page_load(object sender, system.eventargs e)
{
if(!ispostback)
{
//修改expand客户端事件的代码
string script = @"javascript: if (this.clickednodeindex != null){
this.queueevent('onexpand', this.clickednodeindex);
expandedtable(this,this.clickednodeindex);
}
";
tvschema.attributes["onexpand"]=script;
}
//注册控制脚本
registetreescript();
}
private void registetreescript()
{
string script
= @"<script language='javascript'>
function expandedtable(sender,_nodeindex)
{
var node=sender.gettreenode(_nodeindex);
//如果没有子对象时就postback;
if(node.getchildren().length==0)
"+getpostbackeventreference(tvschema)[email protected]";
}
</script>";
this.registerclientscriptblock("tvschema",script);
}
private void tvschema_expand(object sender, microsoft.web.ui.webcontrols.treeviewclickeventargs e)
{
//根据选中的目标,自己生成子树
}
在上面的代码中registetreescript()函数里大部分都是客户端的脚本而已,但是这些客户端脚本不能够触发页面的postback的,所以需要调用getpostbackeventreference(tvschema)来生成postback的脚本,不过这个函数的不只是返回__dopostback('tvschema','');这个字符串这么简单。当你的页面上没有其他postback动作的webcontrol时,他就会自动生成那个__dopostback的客户端脚本了。