熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> .NET編程 >> 正文

.Net環境下基於Ajax的MVC方案[1]

2013-11-13 12:13:22  來源: .NET編程 

  問題背景

  現在越來越多人開始嘗試基於Ajax進行無刷新的Web開發不過Net環境下應用Ajax並不是非常方便這主要可能是由以下一些原因造成的

  ·由於Ajax基於javascript的本質使得開發者必須對javascript非常了解起碼其javascript能力足以實現對callback返回內容對頁面的更新所以開發的門檻就有一定程度的上升

  ·當基於Ajax機制進行開發時原有的基於postback方式下時aspnet由後台邏輯代碼(Model)aspx頁面(View)aspxcs(Controller)構成的MVC構架其實失效了當callback返回數據時要麼在client端用javascript解析返回內容以實現更新要麼則必須在server端構造好比較完整的html代碼再直接由javascript將該構造好的html設置給某個頁面對象很顯然這樣一來要實現一個最簡單的callback功能都要不少代碼並且是相對比較亂的代碼即使在即將到來的aspnet該問題依然不會得到有效解決

  本文目的

  本文旨在充分利於現有的aspnet本身的特點和ajax的特性提出一個用於在aspnet環境下進行基於ajax的web開發的MVC方案以實現以下主要目的

  ·AspNet環境下用於Ajax的清晰的MVC構架

  ·降低編程人員對過多javascript編碼的依賴以降低編程門檻

  ·靈活的支持ajax模式下的常用開發方式

  問題分析

  如何實現以上幾個主要目的呢?

 1)要對xmlhttprequest對更良好的封裝以使調用方式更簡單

 2)盡量在server端進行更新數據的構造但是也要避免每次返回數據都手工構造因此就想到可以充分使用UserControl由UserControl作為View對應的由ascxcs文件作為Controller這樣構成的MVC也是比較清晰的
 
 問題解決

  基於以上思想本人實現了以下一個組類庫以簡化該過程

  源碼及范例下載

  代碼簡析

  1)首先在client端AjaxHelperjs封裝了xmlhttprequest並提供一個將現有的<form>序列化為形如param=v&param=v&形式用於post的參數

  Updater(ajaxTemplate output params onComplete)函數用於實現一次callback調用

  ajaxTemplate(必選)指定執行需要功能的UserControl路徑
  output(可選)填充返回數據的指定標簽的引用或ID值
  params(可選)形如param=v&param=v&的post參數
  onComplete(可選)可用於對返回數據進行特殊處理的回調函數函數格式  function(str)str為返回的數據

  SerializeForm(form)函數用於序列化<form>

  form可以是對指定<form>的引用或ID值

  2)在server端Ajaxaspx文件封裝了對由客戶端ajaxTemplate指定的UserControl的調用其余的具體邏輯功能則在特定的UserControl及其ascxcs內實現

  3)這樣具體執行一次callback時編程人員只需在頁面引用AjaxHelperjs並在指定的位置通過javascript:Updater(ajaxTemplate output params onComplete)進行調用如果需要對某一form進行提交則可調用javascript:SerializeForm(form)序列化該form並傳給params當然也可以手動構造params並指定將返回數據通過設置output應用的頁面或通過onComplete自定義處理

  4)由於充分使用UserControl意味著可以充分利用aspnet原有的web服務器端控件和數據綁定機制這樣其實已經很大程度上簡化了返回數據的構造在ascxcs中通過RequestForm[ParamName]就能訪問到client端傳入的params再訪問邏輯代碼獲取源數據

  范例

  包含在源碼中的范例實現了一個簡單的無刷新獲取博客園首頁內容到一個textarea的功能詳見源碼!

[]  []  


From:http://tw.wingwit.com/Article/program/net/201311/15430.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.