知识大全 数据回发时,维护ASP.NET Tree控件位置
Posted 知
篇首语:百川东到海,何时复西归?少壮不努力,老大徒伤悲。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 数据回发时,维护ASP.NET Tree控件位置相关的知识,希望对你有一定的参考价值。
数据回发时,维护ASP.NET Tree控件位置 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
ASP NET 提供了一个功能强大的TreeView控件 但是它看起来有一个缺陷 它好像不能够跟踪用户最后选择的一个节点 如果你滚动到第 个节点然后展开该节点 那么当单击链接页面进行回发后 你必须重新利用滚动条下拉到你想要的节点位置 在 NET较早的版本里 您可能考虑使用SmartNavigation这个特性 SmartNavigation是Web页面指令的一个属性 它的取值为布尔值 一个设置为true的页面指令看起来类似如下 <%@ Page Language= VB AutoEventWireup= false CodeFile= Default aspx vb Inherits= _Default SmartNavigation= true %> 不过 正如好多人已经注意到的 SmartNavigation本身就有洗衣阿问题 事实上微软也被这个问题所困扰以至于在ASP NET 里添加了MaintainScrollbackPositionOnPostback属性而取代SmartNavigation 遗憾的是 我在使用它们时 感觉它们都有一些问题 我稍后将进行解释 本文我将介绍SmartNavigation和MaintainScrollbackPositionOnPostback 在维护页面回发位置方面的缺点 并提供如何利用Javascript来解决这个问题 这个小技巧即使对复杂的Web页面也同样有效 再见了SmartNavigationeb 欢迎MaintainScrollbackPositionOnPostback SmartNavigation主要作用是减少页面导航时的闪动 它主要利用适当的IFrames来进行这个工作并仅仅显示改变的部分 SmartNavigation 同样被设计为能够维护页面位置 元素焦点 回发浏览器访问历史记录的作用 遗憾的是 即使微软知道SmartNavigation已经去掉 但是检查MSDN文档 您仍然能够看到SmartNavigation其实仅仅被定义为 过时 的 利用GOOGLE的搜索您可以搜到大家对SmartNavigation的讨论 下一步 ASP NET 引进了MaintainScrollbackPositionOnPostback 和SmartNavigation类似 您可以在Page属性里设置它的值为true或者为false <%@ Page Language= VB AutoEventWireup= false CodeFile= Default aspx vb Inherits= _Default MaintainScrollPositionOnPostback= true %> 非常简明 这个属性/属性值对是用来维护页面位置的 遗憾的是 它只是维护页面的位置 因为如果你在用户控件里使用了TreeView控件 然后在页面里使用该用户控件 那么页面在在回发后您将返回到用户控件的位置而不是TreeView节点位置 简单的说 MaintainScrollbackPositionOnPostback只是用来维护页面的回发位置 如果你的页面固定--也就是一个应用程序那样不需要进行利用滚动条进行上下滚动 那么这个属性对你可能无用 如果你的页面很常需要滚动 那么你就需要利用该属性 在TreeView里维护控件的位置 最近 我在开发一个Web应用程序Windowsy 也就是每一个页面都会全屏显示而不是滚动 页面里使用类TreeView来进行导航想列表一样进行显示 但是页面本身不需要上下滚动 但是问题是这里的数据列可能需要扩展使得页面出现滚动 我准备使用如下的方式解决这个问题 首先 利用TreeView控件的SelectedNode属性 可以知道哪个节点被选取 这个被选取的节点需要保存起来 它最终会程序为HTML元素 如果我知道了被选择HTML控件的ID 那么我就可以滚动到该控件并设置该控件为当前焦点 确实 如果您看以下使用TreeView控件的页面HTML代码 你将发现生成的一个隐藏<input>元素 以及为textbox类型 它的ID可能类似TreeViewx_SelectedNode <input type= hidden name= TreeView _SelectedNode id= TreeView _SelectedNode value= TreeView t />有了这些知识 你就知道该怎么做了 基本方法是隐藏的Input是一个textbox 我们要做的就是知道将来呈献的内容 一个TreeView最终呈现为HTML表格 节点的值被用来作为单元格的值 <TD>元素呈现节点名称 所以通过查找单元格ID并滚动到那里
为了具体说明做法 我使用TreeView编写了一些代码 在Page_Load时间里加载一段脚本来找到需要的单元格(参考下表) 在<body>的onload时间里调用该函数
Imports System Collections GenericPartial Class _DefaultInherits System Web UI PageProtected Sub Page_Load(ByVal sender As Object _ByVal e As System EventArgs) Handles Me LoadInjectLoadEvent()If (IsPostBack) Then ReturnTreeView Nodes Clear()Dim chicken As New TreeNode( Chicken ) TreeView Nodes Add(chicken) Dim beef As New TreeNode( Beef ) TreeView Nodes Add(beef) Dim pork As New TreeNode( Pork ) TreeView Nodes Add(pork) Dim fish As New TreeNode( Fish ) TreeView Nodes Add(fish) chicken ChildNodes Add(New TreeNode( Crepes Florentine with Buffalo Chicken )) fish ChildNodes Add(New TreeNode( Linguine with White Clam Sauce )) pork ChildNodes Add(New TreeNode( Pork Loin with Peanut and Madarin Orange Sauce )) beef ChildNodes Add(New TreeNode( Standing Rib Roast with Fennel and Blue Cheese Potatoes )) We need a bunch of stuff here so we will add some stubs Dim I As Integer For I = To chicken ChildNodes Add(New TreeNode( Placeholder + I ToString())) fish ChildNodes Add(New TreeNode( Placeholder + I ToString())) pork ChildNodes Add(New TreeNode( Placeholder + I ToString())) beef ChildNodes Add(New TreeNode( Placeholder + I ToString())) Next TreeView CollapseAll()End SubPublic Sub InjectLoadEvent() Dim script As String = _ function LoadEvent() + _ + _ try + _ + _ var elem = document getElementById( _SelectedNode ); + _ if(elem != null ) + _ + _ var node = document getElementById(elem value); + _ if(node != null) + _ + _ node scrollIntoView(true); + _ scrollLeft = ; + _ + _ + _ + _ catch(oException) + _ + _ Page ClientScript RegisterClientScriptBlock(Me GetType() LoadEvent _String Format(script TreeView ClientID Panel ClientID) True) End SubEnd Class 下面的代码显示了页面的布局 <%@ Page Language= VB AutoEventWireup= false CodeFile= Default aspx vb Inherits= _Default %><!DOCTYPE PUBLIC //W C//DTD XHTML Transitional//EN transitional dtd >< xmlns= ><head runat= server > <title>Focus Tree Node on Postback</title></head><body onload= LoadEvent() > <form id= form runat= server > <div> <asp:Panel ID= Panel runat= server Height= px Width= px ScrollBars= Both > <asp:TreeView ID= TreeView runat= server > <SelectedNodeStyle BackColor= # FF /> </asp:TreeView> </asp:Panel> </div> </form></body></>下图显示了本例子运行的结果
最后 下面的代码显示了javascript的注入方式 <script>function LoadEvent() try var elem = document getElementById( TreeView _SelectedNode ); if(elem != null ) var node = document getElementById(elem value); if(node != null) node scrollIntoView(true); Panel scrollLeft = ; catch(oException) // ></script> 用Javascript定义的LoadEvent函数将查找隐藏字段 我们利用TreeView控件的ClientID 查找所有元素 不过 在嵌套多个TreeView控件后 名称将变得非常长 找到单元格的值后 我使用scrollIntoView方法 scrollLeft属性将让滚动条滚动当前位置 cha138/Article/program/net/201311/13687相关参考
浅析五大ASP.NET数据控件 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! ASPNET中有不
知识大全 ASP.NET入门教程 7.2 ASP.NET 2.0的数据控件
ASP.NET入门教程7.2ASP.NET2.0的数据控件 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一
ASP.NET数据绑定控件比较浅析 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! ASPNET数
ASP.Net2.0中的5个数据控件 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!第一篇的入门帖就
ASP.NET2.0中数据源控件之异步数据访问 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 在
ASP.NET入门教程7.4数据绑定控件 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
ASP.NET2.0中的数据源控件 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! ASPNET引
知识大全 组合ASP.NET 2.0数据控件构建强大用户接口
组合ASP.NET2.0数据控件构建强大用户接口 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
知识大全 ASP.NET入门教程 7.2.2 数据绑定控件[2]
ASP.NET入门教程7.2.2数据绑定控件[2] 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!&
知识大全 ASP.NET入门教程 7.2.2 数据绑定控件[1]
ASP.NET入门教程7.2.2数据绑定控件[1] 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!&