天天看点

TreeView的RenderControl的问题

treeview,这东西,正常情况下一般是不用的,不过我们的美工,没弄个树型的样式出来,没折,将就用一下treeview了

说重点:

环境搭建:一页面,拖一下treeview控件上去,随便添加几个项。

然后page_load事件里输出:

TreeView的RenderControl的问题
TreeView的RenderControl的问题

   system.io.stringwriter sw = new system.io.stringwriter();

TreeView的RenderControl的问题

            htmltextwriter write = new htmltextwriter(sw);

TreeView的RenderControl的问题

            treeview1.rendercontrol(write);

TreeView的RenderControl的问题

            if (sw != null)

TreeView的RenderControl的问题

            {

TreeView的RenderControl的问题

                response.write(sw.tostring());

TreeView的RenderControl的问题

            }

TreeView的RenderControl的问题

public override void verifyrenderinginserverform(control control)

TreeView的RenderControl的问题

        {

TreeView的RenderControl的问题

            //不引发"控件必须放在具有 runat=server 的窗体标记内“验证

TreeView的RenderControl的问题

        }

TreeView的RenderControl的问题

        public override bool enableeventvalidation

TreeView的RenderControl的问题
TreeView的RenderControl的问题

            get

TreeView的RenderControl的问题
TreeView的RenderControl的问题

                return false;//解决因rendercontrol引发的异常

TreeView的RenderControl的问题
TreeView的RenderControl的问题

然后查看页面源文件,发现rendercontrol出来的html和自动生成的html是不一样的,主要区别在于折叠的js事件中

关键点来了,为了回调更新treeview的内容,却发现拿出来的rendercontrol的html的代码是有问题的,几经折腾,先绕过了rendercontrol,直接抓页面源码,再正则了。这时候,也有一个折腾人的地方,如果请求头没有user-agent,抓回来的也是和rendercontrol输出的一样。

目前是没折的处理方法,抓页面源码再正则进行中。。。。

到于rendercontrol为啥输出的和页面直接加载的不一样。。还有待研究。。。知道的说一声

继续阅读