惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
H
Hacker News: Front Page
P
Palo Alto Networks Blog
T
ThreatConnect
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
T
True Tiger Recordings
P
Privacy & Cybersecurity Law Blog
B
Blog
IT之家
IT之家
Last Week in AI
Last Week in AI
F
Full Disclosure
Hacker News: Ask HN
Hacker News: Ask HN
C
Comments on: Blog
Microsoft Azure Blog
Microsoft Azure Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Security Blog
Microsoft Security Blog
博客园 - 【当耐特】
N
News and Events Feed by Topic
NISL@THU
NISL@THU
腾讯CDC
雷峰网
雷峰网
Security Latest
Security Latest
李成银的技术随笔
M
Microsoft Research Blog - Microsoft Research
L
LangChain Blog
L
Lohrmann on Cybersecurity
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
C
Check Point Blog
Y
Y Combinator Blog
Recent Announcements
Recent Announcements
博客园 - Franky
N
News | PayPal Newsroom
V
V2EX
A
About on SuperTechFans
The Register - Security
The Register - Security
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google Online Security Blog
Google Online Security Blog
MyScale Blog
MyScale Blog
Cisco Talos Blog
Cisco Talos Blog
Vercel News
Vercel News
WordPress大学
WordPress大学
C
Cyber Attacks, Cyber Crime and Cyber Security
The Hacker News
The Hacker News
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
爱范儿
爱范儿
A
Arctic Wolf
L
LINUX DO - 最新话题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More

博客园 - 小柯

Enterprise Library 4.1 Configuration的使用 C#模仿QQ截图功能 asp.net 中 DropDownList 加入可输入功能解决方案 - 小柯 解决SQL Server Management Studio Express为英文的问题 Visual Studio 2008 简体中文正式版下载及序列号(无使用期限限制,正式版) 程序人生--一个程序员对学弟学妹建议(转) .NET 换肤软件 IrisSkin 2.0 破解版下载及多款皮肤下载 (转)JavaScript 弹出窗口总结 (转)JavaScript常用判断函数(正则表达式版) C#中常用的经典文件操作方法 反编译工具Reflector下载(集成两个常用.net插件,FileGenerator和FileDisassembler) - 小柯 C#遍历指定目录的递归(完美改进版+完整程序源码) C#遍历目录树的递归 - 小柯 在ASP.NET中自动给URL加上超链接 ASP.NET 中 Cookie 的基本知识 - 小柯 ASP.NET2.0统计图表(转) ASP.NET获取IP及电脑名等信息的简单方法+通用类文件源码 - 小柯 (转)了解你的兵器---VS2005 快捷键 Asp.net Ajax 系列(一) ----------用了再说
Asp.Net Ajax系列(二) 局部页面呈现(Partial-Page Rendering)
小柯 · 2006-12-17 · via 博客园 - 小柯

观察前面一篇文章的例子,你将在aspx页面的源代码发现<asp:UpdatePanel><asp:ScriptManager〉两个标签,这里我们将解释其局部页面呈现的概念。

局部页面呈现(Partial-Page Rendering)可以理解为 局部页面加载,根据我们上一个例子,局部页面加载技术能够使得我们避免重新加载整个页面,它只更新我们需要刷新的部分,因此将大大减少用户等待时间,增强用户体验。上篇文章使用Microsoft Asp.Net 2.0 Ajax Extensions 组件,将使得我们不用写任何客户端javascript代码, 就可以使用这种技术。

Microsoft ASP.NET2.0 AJAX Extensions 使得我们能轻松扩展我们现有的asp.net 2..0应用程序,使得它能具备AJAX特性。我们可以在以下情况是用它:

  •       极力提高用户的网页交互体验,增强响应感受,使得网页行为接近传统客户端程序。

  • 减少整页刷新,避免反复刷新而产生的闪动。

  • 不必为兼容不同浏览器而编写客户端脚本

  • 充分享受 ASP.NET AJAX Control Toolkit 的控件和组件的高效率

  • 开发自定义控件

局部页面呈现依赖于ASP.NET 2.0 AJAX Extensions的服务器端控件和在Microsoft AJAX Library 中的客户端功能。在应用的过程中并不要求你使用Microsoft AJAX Library,因为它的功能将在你使用服务器端控件的时候自动提供。当然,你也可以直接调用该库的开放API,去开发具备其他的AJAX特性的网页。

Partial-Page Rendering的基本特征包含:

Asp.net服务器控件一样的声明模型。在很多情况下,你仅仅声明一个标签就可以定制局部页面呈现。

  • 拥有服务器端控件,包含 ScriptManagerUpdatePanel 控件

  • 服务器端控件和Microsoft AJAX Library集成,为普通任务提供实现类似取消postback或决定多次点击后如何运行的能力

  • 错误处理机制能使你将错误自定义的显示在浏览器里

  • 跨浏览器的兼容性已经融入Microsoft AJAX Library. 易于使用的服务器控件将自动调用匹配适合浏览器的功能

背景

使用ASP.Net服务器控件的典型网页能够通过已被初始化的用户行为完成提交,比如说点击一个按钮。在响应流中,服务器将呈现一个新网页。在很多情况下,完全没有必要在提交之间重新呈现那些没有任何改变的控件和文本。

使用ASP.NET AJAX 局部页面呈现技术,你只需要更新一个网页中的独立区域部分 ,使得其对用户有更好的响应性。你可以使用ASP.NET的服务器控件,也可以写客户端脚本来调用Microsoft AJAX Library中的API来实现局部页面呈现。

服务器端控件

想要在ASP.NET网页上实现AJAX功能,你必须标识一个需要更新的独立区域。于是你需要使用UpdatePanel控件来进行包装该区域,里面可以放HTML也可以是ASP.NET控件。你可以在网页Design视图下从工具栏将其拖入,也可以使用在Source视图中以声明标签的方式实现。就像下面

<asp:UpdatePanel ID="UpdatePanel1" runat="server">
    <ContentTemplate>
        <!-- Place updatable markup and controls here. -->
    </ContentTemplate>
</asp:UpdatePanel>
 
在上一个篇的例子里,你如果察看源文件,也将会看到这个标签。
 
所有包含自这个update panel 内的控件所引发的提交都会在默认情况下自动以异步的方式执行,使得该区域能够实现局部页面的更新。你也可以指定一个update panel区域以外的一个控件去引发该区域的提交和刷新,也就意味着你可以指定某个控件作为其触发器。关于这部分内容我们将在以后会提到。

当异步提交就像一次普通的提交在服务器的页面事件中发生的时候,ViewStateForm的数据将被保存下来。然而,除了在updatePanel中的内容会在客户端浏览器更新,其余的将保持原状。

为了实现局部页面呈现,你还有一件事情要做,就是放置一个ScriptManager控件在页面上。ScriptManager控件自动跟踪页面上所有的update panel,同时也充当着他们的触发器, 调整服务器局部页面呈现的行为,指示页面的某个部分作为最近一次异步提交的显示结果。

放在form标签中即可

<asp:ScriptManager ID="ScriptManager1" runat="server" EnablePartialRendering="true" />

局部页面呈现的缺陷

如果局部页面呈现失效或者浏览器不支持,那么提交将变得和任何普通ASP.Net网页一样,异步提交行为将被同步提交和整页更新所替代,UpdatePanel控件将失效,控件里的内容就象没有放在里面一样。

后面我将讲解UpdatePanel具体使用的例子