這篇文章主要介紹了寫輕量級ajax元件01-與webform平台上的各種實現方式比較,需要的朋友可以參考下
前言
Asp.net WebForm 和Asp.net MVC(簡稱MVC) 都是基於Asp.net的web開發框架,兩者有很大的區別,其中一個就是MVC更加註重http本質,而WebForm試圖屏蔽http,為此提供了大量的伺服器控制項和ViewState機制,讓開發人員可以像開發Windows Form應用程式一樣,基於事件模型去程式設計。兩者各有優缺點和適用情景,但MVC現在是許多Asp.net開發者的首選。
WebForm是建立在Asp.net的基礎上的,Asp.net提供了足夠的擴展性,我們也可以利用這些在WebForm下編寫像MVC一樣的框架,這個有機會再寫。說到WebForm很多人就會聯想到伺服器控件(拖曳控件!!!),其實不然,我們也可以完全不使用伺服器控件,像MVC一樣關注html。 WebForm要拋棄伺服器控件,集中在html,首先就要將
標籤去掉,這個runat server 的form 是其PostBack機制的基礎。既然我們要回歸到html css js,那麼意味著許多東西都要自己實現,例如處理Ajax請求。不像MVC那樣,WebForm開始的設計就將伺服器控制項當作主要組成部分,如果不使用它,那麼只能利用它的擴充性去實作。本系列就是實作一個基於WebForm平台的輕量ajax元件,主要分為三個部分:
1. 介紹WebForm下各種實作方式。
2. 分析ajaxpro組件。
3. 寫出自己的ajax元件。
一、Ajax簡介
非同步允許我們在不刷新整個頁面的情況下,像伺服器請求或提交資料。對於複雜的頁面,為了請求一點資料而重載整個頁面顯然是很低效的,ajax就是為了解決這個問題的。 ajax的核心是XmlHttpRequest對象,透過該對象,以文字的形式向伺服器提交請求。 XmlHttpRequest2.0後,也支援提交二進位資料。
ajax安全:出於安全考慮,ajax受同源策略限制;也就是只能存取同一個域、同一個連接埠的請求,跨域請求會被拒絕。當然有時候需求需要跨域發送請求,常用的跨域處理方法有CORS(跨域資源共享)和JSONP(參數式JSON)。
ajax資料互動格式:雖然Ajax核心物件XmlHttpRequest有"XML"字眼,但客戶端與伺服器資料交換格式不限於xml,例如現在更多是使用json格式。
ajax 也是有缺點的。例如對搜尋引擎的支援不太好;有時候也會違背url資源定位的初衷。
二、Asp.net MVC 平台下使用ajax
在MVC裡,ajax呼叫後台方法非常方便,只需要指定Action的名稱即可。
前台程式碼:
<body> <h1>index</h1> <input type="button" value="GetData" onclick="getData()" /> <span id="result"></span> </body> <script type="text/javascript"> function getData() { $.get("GetData", function (data) { $("#result").text(data); }); } </script>
# 後台程式碼:
##
public class AjaxController : Controller { public ActionResult GetData() { if(Request.IsAjaxRequest()) { return Content("data"); } return View(); } }
#三、WebForm 平台下使用ajax
3.1 基於伺服器控制項套件或第三方元件
這是基於伺服器控制項的,例如ajax toolkit工具包,或像FineUI這樣的元件。 web前端始終是由html css js組成的,只不過如何去產生的問題。原生的我們可以自己寫,或是用一些前端插件;基於伺服器控制項的,都是在後台產生的,通常效率也低一點。伺服器元件會在前台產生一系列代理,本質還是一樣的,只不過控制項封裝了這個過程,不需要我們自己寫。基於控制項或第三方元件的模式,在某些管理系統還挺有用的,訪問量不是很大,可以快速開發。3.2 基於ICallbackEventHandler介面
.net 提供了ICallbackEventHandler接口,用於處理回調請求。此介面需要用ClientScriptManager在前台產生代理腳本,用於傳送和接收請求,所以需要