你目前正处于脱机状态,正在等待 Internet 重新连接

如何: 手动后返回为一个.aspx 页使用 Visual Basic.net 中的特定事件

注意:这篇文章是由无人工介入的微软自动的机器翻译软件翻译完成。微软很高兴能同时提供给您由人工翻译的和由机器翻译的文章, 以使您能使用您的语言访问所有的知识库文章。然而由机器翻译的文章并不总是完美的。它可能存在词汇,语法或文法的问题,就像是一个外国人在说中文时总是可能犯这样的错误。虽然我们经常升级机器翻译软件以提高翻译质量,但是我们不保证机器翻译的正确度,也不对由于内容的误译或者客户对它的错误使用所引起的任何直接的, 或间接的可能的问题负责。

点击这里察看该文章的英文版: 328923
概要
本分步指南介绍了如何设置.aspx 页,以便在生成的 HTML 代码会发布回发到服务器以响应特定事件的控件。对于示例目的这篇文章,请使用 Internet 资源管理器 Web 控件树视图控件。

AutoPostBack 属性

  • ,则返回 true。AutoPostBack 是真时在控件的控件可以发布回发到服务器中的不想导致回发事件的响应。

    例如对于设置为 True 在树视图上的 AutoPostBack 控件导致回发中响应这些事件: onExpand ; onCollapse ; onCheck ; 和 onSelectedIndexChange。
  • false。通过设置为 False 的 AutoPostBack,您后重新手动对特定的事件作出响应。

创建代码

若要向后后手动响应 onSelectedIndexChange 事件,请按照下列步骤操作。
  1. 创建一个 Web 应用程序,然后放入一个.aspx 页的 TreeView 控件。
  2. 在.aspx 页将在 树视图 控件的 AutoPostBack 属性设置为 False
  3. TreeView节点 属性中单击 收藏 省略号 (...) 按钮,然后将某些节点和子项添加到 树视图 节点集合。
  4. 处理 onload 事件的 HTML 页,然后调用 initTree 函数。在 Page_Load 事件为.aspx 页中,将会生成此客户端函数。

    将在.aspx 页的 HTML 视图中添加的 onload 事件处理程序到 body 标记,如下所示:
    <body onload="initTree()">					
  5. 将下面的代码从此 Page_Load 函数添加到自己的 Page_Load 函数在 代码隐藏 类中为.aspx 文件中。
    Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load    Dim strTreeName As String = "TreeView1"    Dim strRef As String = Page.GetPostBackEventReference(TreeView1)    Dim strScript As String = "<script language=""JavaScript""> " & vbCrLf & _        "<!-- " & vbCrLf & _        "	function initTree() { " & vbCrLf & _        "		" & strTreeName & ".onSelectedIndexChange = function() { " & vbCrLf & _        "			if (event.oldTreeNodeIndex != event.newTreeNodeIndex) " & vbCrLf & _        "				this.queueEvent('onselectedindexchange', event.oldTreeNodeIndex & ',' & event.newTreeNodeIndex); " & vbCrLf & _        "			window.setTimeout('" & strRef.Replace("'", "\'") & "', 0, 'JavaScript'); " & vbCrLf & _        "		} " & vbCrLf & _        "	} " & vbCrLf & _        "// --> " & vbCrLf & _        "</script>"    Page.RegisterClientScriptBlock("InitTree", strScript)End Sub					

该代码的说明

该代码是如何开发

在本文内上文中提供的代码被开发的使用以下过程:
  • .aspx 页开发和 树视图 控件的 AutoPostBack 已设置为 True
  • .aspx 页在 Internet Explorer 浏览器中查看和源被保存到一个.html 文件。
  • 树视图 控件的 AutoPostBack 已设置为 False,然后在页被再次在浏览器中查看。
  • 比较这两个文件,并注意差异帮助产生本文前面提供的代码。

有关代码的更多信息

  • 从本文中 Page_Load 函数代码呈现在浏览器中下面的代码:
    <script language="JavaScript"><!--     function initTree() {         TreeView1.onSelectedIndexChange = function() {             if (event.oldTreeNodeIndex != event.newTreeNodeIndex)                 this.queueEvent('onselectedindexchange', event.oldTreeNodeIndex & ',' & event.newTreeNodeIndex);             window.setTimeout('__doPostBack(\'TreeView1\',\'\')', 0, 'JavaScript');         }     } // --></script>						
    initTree 函数运行时在 HTML 页加载到浏览器。initTree 函数重写的 TreeView1onSelectedIndexChange 事件,以便 onSelectedIndexChange 事件将被添加到该事件队列中的页并回发到服务器再过帐。
  • 在新的 onSelectedIndexChange 函数的第一行
    if (event.oldTreeNodeIndex != event.newTreeNodeIndex)     this.queueEvent('onselectedindexchange', event.oldTreeNodeIndex + ',' + event.newTreeNodeIndex);						
    已保存的.html 文件中定义直接来自于原始定义为函数。
  • 设置 AutoPostBack 的树视图 为 true 将呈现在 HTML 中下面的代码:
    window.setTimeout('__doPostBack(\'TreeView1\',\'\')', 0, 'JavaScript');						
    回发的机制 (在此例 __doPostBack) 可能会在将来更改,因为通过使用下面的代码生成在服务器上的该函数:
    string strRef = Page.GetPostBackEventReference(TreeView1);					
    的回发事件引用然后使用在 Page_Load 生成在客户端 回发 事件。
参考
有关更多的信息请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
305140信息: ASP.NET 路线图

319441如何: 使用 Visual Basic.net 动态将节点添加到树视图的 web 浏览器控件

警告:本文已自动翻译

属性

文章 ID:328923 - 上次审阅时间:06/25/2003 17:06:43 - 修订版本: 3.4

Microsoft ASP.NET 1.0, Microsoft Visual .NET 2002 标准版, Microsoft ASP.NET 1.1, Microsoft Visual Basic .NET 2003 标准版

  • kbmt kbhowtomaster kbservercontrols KB328923 KbMtzh
反馈
or="var m=document.createElement('meta');m.name='ms.dqp0';m.content='true';document.getElementsByTagName('head')[0].appendChild(m);" onload="var m=document.createElement('meta');m.name='ms.dqp0';m.content='false';document.getElementsByTagName('head')[0].appendChild(m);" src="http://c1.microsoft.com/c.gif?">