使用Asp.net Mvc3 Razor視圖方式擴充JQuery UI Widgets方法介紹

來源:互聯網
上載者:User

JQuery UI Widgets是本人非常喜歡的一套前端JS組件,日常開發中基於原有的jquery ui widget js代碼進行開發,需要寫非常多的重複代碼,同時一些現有組件無法滿足需求的情況下,需要對現有組件進行擴充,本文使用一套基於jquery ui 的擴充js組件---jtable (http://www.jtable.org),包含了基本的列表和編輯視窗,比起jqGrid,jquery easyui grid或者extjs grid,jtable的代碼非常簡潔、對於grid功能要求不是很複雜的情況下,強烈推薦大家使用!

除了jtable組件推薦給大家,本文主要向大家分享一些代碼編寫思路,如何減少前端js重複代碼,以及基於現有jquery ui widgets組件進行擴充代碼的寫法
本文涉及2個視圖檔案,1個Controller檔案

jTableTemplateView.cshtml// 基於jtable組件的代碼模板
someBusinessView.cshtml // 某業務功能視圖模板
TemplateController.cs // 模板後台Controller控制
大體思路如下:

someBusinessView.cshtml,通過
<script type="text/javascript" src="/Template/jsTemplateView?code=xxx" ></script>
指令碼src屬性指向jTableTemplateView頁面,同時傳遞參數code參數到TemplateController,
TemplateController調用jTableTemplateView視圖渲染時,通過參數Code擷取業務對象相關資訊或變數傳遞給jsTemplateView頁面,然後輸出業務指令碼資訊到someBusinessView,代碼如下:
1.jTableTemplate.View複製代碼 代碼如下:@{
Layout = null; // 只輸出當前視圖
Response.ContentType = "application/javascript"; // 設定返回MIME類型
}
/*
* jTableTemplate v0.1 created by wdong 2012-11-07
* Copyright (c) 2012 wdong http://wdong.cnblogs.com/ mail:wdong0472@gmail.com
* 使用jTableTemplate可以方便產生頁面上所需的Grid列表及Editor編輯視窗,非常簡潔的實現基本表單的CRUD操作
* USAGE: 參數說明
* $(selector).ControlName({title:"please your grid title"});
* $(selector).ControlName("load");
*/

@using Tiyo.Platform.Business.Entities

@{
string code = ViewBag.Code;

ObjectEntity entity = ViewData[code + ".ObjectCode"] as ObjectEntity;
IList<ObjectDetailsEntity> entityDetails = entity.Details;

string controlName = ViewData[code + ".ControlName"].ToString();
string title = ViewData[code + ".Title"].ToString();
string paging = ViewData[code + ".Paging"].ToString();
string pageSize = ViewData[code + ".PageSize"].ToString();
string defaultSorting = ViewData[code + ".DefaultSorting"].ToString();
string listAction = ViewData[code + ".ListAction"].ToString();
string updateAction = ViewData[code + ".UpdateAction"].ToString();
string deleteAction = ViewData[code + ".DeleteAction"].ToString();
}

(function ($) {
// extend jtable jquery ui widget
$.widget("jTableTemplate.@controlName", $.extend(true,{}, $.hik.jtable.prototype, {
_init: function(){
return $.hik.jtable.prototype._init.apply(this, arguments);
}
}));

//各種屬性、參數
var options = {
title: '@title'
,paging: @paging //Enables paging
,pageSize:@pageSize //Actually this is not needed since default value is 10.
,sorting: true //Enables sorting
,defaultSorting: '@defaultSorting' //Optional. Default sorting on first load.
,actions: {
listAction: '@listAction'
,deleteAction: '@deleteAction'
,updateAction: '@updateAction'
}
,fields: {
ID: {
title:"主鍵"
,list:false
}
@foreach(var field in entityDetails)
{
if(!field.Ispk)
{
<text>
,@field.Fieldname:{
title:"@field.Displayname"
,list: @field.Visible.ToString().ToLower()
}
</text>
}
}
}
};

$.fn.extend(true,$.jTableTemplate.@{@controlName}.prototype,{options:options});
})(jQuery);

此處擴充JQuery UI Widgets的基本結構代碼如下: 複製代碼 代碼如下:$.widget("ui.customwidget", $.extend({}, $.ui.extendwidget.prototype, {
_init: function(){
return $.ui.extendwidget.prototype._init.apply(this, arguments);
}

// Override other methods here.
}));

customerwidget為你自訂的外掛程式名稱,extendwidget為現有插或被擴充外掛程式
2.someBusinessView.cshtml複製代碼 代碼如下:@{
ViewBag.Title = "AreaList";
}

<script type="text/javascript" src="/JQueryTemplate/jTableTemplate?code=xxx"></script>

<div id="DataContainer"></div>

<script type="text/javascript">
$.SomeApp = {
doInit: function() {
try {
$('#DataContainer').xxx({title:"test列表"}).xxx("load");
} catch (err) {
alert(err);
}
}
}

$(function(){
$.SomeApp .doInit();
});

</script>

3.TemplateController.cs 複製代碼 代碼如下:using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Tiyo.Platform.Controller;
using System.Web.Mvc;

namespace Tiyo.Plugins.ExtJsTemplate.Controllers
{
public class JQueryTemplateController:BaseController
{
/// <summary>
/// 擷取JTable列表+編輯視窗
/// </summary>
/// <param name="code">環境內容標識</param>
/// <returns></returns>
public ViewResult jTableTemplate(string code)
{
ViewBag.Code = code;

// 添加視圖所需環境內容資訊(即控制項所需變數值等資訊)
BaseDataHelper.AddContextData(code,ViewData);
return View();
}
}
}

注意,此處代碼為擷取jTableTemplate模板視圖所需變數資訊,大家可根據自己習慣和需要自行替換

// 添加視圖所需環境內容資訊(即控制項所需變數值等資訊)
BaseDataHelper.AddContextData(code,ViewData);

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.