treeview,这东西,正常情况下一般是不用的,不过我们的美工,没弄个树型的样式出来,没折,将就用一下treeview了
说重点:
环境搭建:一页面,拖一下treeview控件上去,随便添加几个项。
然后page_load事件里输出:
system.io.stringwriter sw = new system.io.stringwriter();
htmltextwriter write = new htmltextwriter(sw);
treeview1.rendercontrol(write);
if (sw != null)
{
response.write(sw.tostring());
}
public override void verifyrenderinginserverform(control control)
{
//不引发"控件必须放在具有 runat=server 的窗体标记内“验证
}
public override bool enableeventvalidation
get
return false;//解决因rendercontrol引发的异常
然后查看页面源文件,发现rendercontrol出来的html和自动生成的html是不一样的,主要区别在于折叠的js事件中
关键点来了,为了回调更新treeview的内容,却发现拿出来的rendercontrol的html的代码是有问题的,几经折腾,先绕过了rendercontrol,直接抓页面源码,再正则了。这时候,也有一个折腾人的地方,如果请求头没有user-agent,抓回来的也是和rendercontrol输出的一样。
目前是没折的处理方法,抓页面源码再正则进行中。。。。
到于rendercontrol为啥输出的和页面直接加载的不一样。。还有待研究。。。知道的说一声