原文地址:http://www.cnblogs.com/wuhuacong/p/3317223.htmljavascript
在前面介紹了兩篇關於個人基於MVC4+EasyUI技術的Web開發框架的隨筆,本篇繼續介紹其中界面部分的一些使用知識,包括控件的賦值、取值、清空,以及相關的使用。css
咱們知道,通常Web界面包括的界面控件有:單行文本框、多行文本框、密碼文本框、下拉列表Combobox、日期輸入控件、數值輸入控件、單項選擇、複選框、表格控件DataGrid、樹形控件、佈局控件、彈出式對話框、提示信息、列表控件等,這些界面控件的操做都有哪些不一樣,下面咱們來逐一進行介紹。html
使用easyui的控件,單行文本可使用easyui-validatebox樣式便可,類型爲text的控件。java
界面代碼以下所示:jquery
<input class="easyui-validatebox" type="text" id="Name" name="Name" /> 或者 <input type="text" ID="txtLoginName" name="txtLoginName" style="width:100px" />
賦值給界面控件代碼以下:web
$("#Name").val(info.Name);
獲取界面控件的值代碼以下:json
var name = $("#Name").val();
若是是標籤Lable控件,這須要把val 使用text替代便可,以下代碼所示:app
$("#Name").text(info.Name);
對於easyui-validatebox樣式的控件,通常來講,有幾個常見屬性能夠設置他們的。框架
//必輸項: <input class="easyui-validatebox" type="text" name="name" data-options="required:true"></input> //格式的驗證: <input class="easyui-validatebox" type="text" name="email" data-options="validType:'email'"></input> <input class="easyui-validatebox" type="text" name="email" data-options="required:true,validType:'url'"></input> //長度範圍的驗證: <input class="easyui-validatebox" data-options="validType:'length[1,3]'">
easyui的界面樣式,可使用easyui-validatebox,或者默認的textarea便可。dom
界面代碼以下所示:
<textarea id="type_Remark" class="easyui-validatebox" required="true" style="height:100px;"></textarea>
或者
<textarea style="height:60px;width:200px" id="type_Remark" name="Remark"></textarea>
賦值給界面控件代碼以下:
$("#type_Remark").val(json.Remark);
獲取界面控件的值代碼以下:
var text = $("#type_Remark").val();
密碼文本框和常規的文本框同樣,只是輸入字符的時候,系統作了屏蔽顯示而已,把它做爲一個來獨立說明,也是由於它也是常見輸入的一種。
界面代碼以下所示:
<input type="password" name="password" style="width:260px;"></input>
賦值給界面控件代碼以下:
var password = '123';
$("#Password").val(password)
獲取界面控件的值代碼以下:
$("#btnLogin").click(function () { var postData = { UserName: $("#UserName").val(), Password: $("#Password").val(), Code: $("#Code").val() };
常見的EasyUI的ComboBox是能夠輸入,也能夠從列表選擇的內容的輸入控件。
界面代碼以下所示:
<input class="easyui-combobox" type="text" id="type_PID1" name="PID" />
綁定下拉列表的數據源代碼以下:
$('#type_PID1').combobox({ url: '/DictType/GetDictJson', valueField: 'Value', textField: 'Text' });
設置控件的選擇的內容代碼以下:
$("#type_PID1").combobox('setValue', json.PID);
獲取界面控件的值代碼以下:
var systemType= $("#txtSystemType_ID").combobox('getValue');
而利用標準的Select控件雖然能夠實現從列表選擇,不過不夠ComboBox控件那麼靈活方便,Select控件的界面代碼以下:
<select id="txtPID" style="width: 100%" > </select>
easyui使用class=‘easyui-datebox’來標識日期控件,從彈出的層中選擇正確的日期,是一種很是常見的界面輸入控件,能夠替代My97DatePicker日期輸入控件。
彈出窗體界面效果以下。
它的界面代碼以下所示:
<input class="easyui-datebox" type="text" ID="txtLastUpdated" name="txtLastUpdated" style="width:100px" />
賦值給界面控件代碼以下:
$("#LastUpdated").datebox('setValue', info.LastUpdated);
獲取界面控件的值代碼以下:
var lastupate = $("#txtLastUpdated").datebox('getValue');
easyui使用樣式easyui-numberbox標識爲數值類型,其表現爲文本框,但只能輸入數值。
界面代碼以下所示:
<input class="easyui-numberbox" data-options="min:10,max:90,precision:2,required:true">
或者使用‘easyui-numberspinner’樣式來標識,能夠上下調節數值。
<input class="easyui-numberspinner" data-options="min:10,max:100,required:true" style="width:80px;"></input>
賦值給界面控件代碼以下:
$('#nn').numberbox('setValue', 206.12);
或者
$('#ss').numberspinner('setValue', 8234725);
獲取界面控件的值代碼以下:
var v = $('#nn').numberbox('getValue');
或者
var v = $('#ss').numberspinner('getValue');
單項選擇Radio控件,是在多項內容裏面選擇一個選項進行保存或者顯示。
界面代碼以下所示:
<tr> <th> <label>數據分開方式:</label> </th> <td> <input name="SplitType" type="radio" class="easyui-validatebox" checked="checked" required="true" value="Split">分隔符方式,多個數據中英文逗號,分號,斜槓或頓號[, , ; ; / 、]分開,或一行一個 <br /> <input name="SplitType" type="radio" class="easyui-validatebox" required="true" value="Line">一行一個記錄模式,忽略全部分隔符號 </td> </tr>
賦值給界面控件代碼以下:
$('input:radio[name="SplitType"][value="Split"]').prop('checked', true);
獲取界面控件的值代碼以下:
$("input[name='SplitType']:checked").val()
或者使用Comobo控件做爲單項選擇的控件也是能夠的,界面效果以下所示。
其界面代碼以下所示:
<select id="cc" style="width:150px"></select> <div id="sp"> <div style="color:#99BBE8;background:#fafafa;padding:5px;">Select a language</div> <input type="radio" name="lang" value="01"><span>Java</span><br/> <input type="radio" name="lang" value="02"><span>C#</span><br/> <input type="radio" name="lang" value="03"><span>Ruby</span><br/> <input type="radio" name="lang" value="04"><span>Basic</span><br/> <input type="radio" name="lang" value="05"><span>Fortran</span> </div> <script type="text/javascript"> $(function(){ $('#cc').combo({ required:true, editable:false }); $('#sp').appendTo($('#cc').combo('panel')); $('#sp input').click(function(){ var v = $(this).val(); var s = $(this).next('span').text(); $('#cc').combo('setValue', v).combo('setText', s).combo('hidePanel'); }); }); </script>
複選框是在一項或多項內容中,選擇零項或者多項的一個輸入界面控件。
界面代碼以下所示:
<input id="chkIsExpire" type="checkbox" >賬號過時
因爲複選框的一些特殊性質,在表單提交的時候,若是沒有勾選的選型,使用serializeArray()方法構造的數據,複選框的值則不會被提交。
基於這個緣由,咱們可使用Select控件進行替代,實現複選項的功能,而不影響
var postData = $("#ffEdit").serializeArray();
以上代碼的使用。
使用Select控件的代碼以下所示。
<select id="Visible1" name="Visible"> <option value="true" selected>正常</option> <option value="false">不可見</option> </select>
賦值給界面控件代碼以下:
$("#Visible1").prop('checked', info.Visible);
獲取界面控件的值代碼以下:
var visible = $("#txtVisible").val();
easyui的列表控件,能夠經過指定table的class屬性爲easyui-datagrid便可實現表格的定義,界面代碼以下所示:
<table class="easyui-datagrid" title="Basic DataGrid" style="width:700px;height:250px" data-options="singleSelect:true,collapsible:true,url:'../datagrid/datagrid_data1.json'"> <thead> <tr> <th data-options="field:'itemid',width:80">Item ID</th> <th data-options="field:'productid',width:100">Product</th> <th data-options="field:'listprice',width:80,align:'right'">List Price</th> <th data-options="field:'unitcost',width:80,align:'right'">Unit Cost</th> <th data-options="field:'attr1',width:250">Attribute</th> <th data-options="field:'status',width:60,align:'center'">Status</th> </tr> </thead> </table>
不過爲了不使用腳本定義datagrid致使屢次初始化的問題,咱們通常只須要指定一個table代碼便可,界面以下所示
<table id="grid" style="width: 1024px" title="用戶操做" iconcls="icon-view"> </table>
而表格控件的數據加載,咱們使用javascript進行初始化,初始化後的表格界面顯示效果以下所示。
Javascript代碼以下所示,其中的width: function () { return document.body.clientWidth * 0.9 }是用來實現寬度自適應的一個操做。
//實現對DataGird控件的綁定操做 function InitGrid(queryData) { $('#grid').datagrid({ //定位到Table標籤,Table標籤的ID是grid url: '/Menu/FindWithPager', //指向後臺的Action來獲取當前菜單的信息的Json格式的數據 title: '功能菜單', iconCls: 'icon-view', height: 650, width: function () { return document.body.clientWidth * 0.9 }, nowrap: true, autoRowHeight: false, striped: true, collapsible: true, pagination: true, pageSize: 100, pageList: [50,100,200], rownumbers: true, //sortName: 'ID', //根據某個字段給easyUI排序 sortOrder: 'asc', remoteSort: false, idField: 'ID', queryParams: queryData, //異步查詢的參數 columns: [[ { field: 'ck', checkbox: true }, //選擇 { title: '顯示名稱', field: 'Name', width: 200}, { title: '圖標', field: 'Icon', width: 150 }, { title: '排序', field: 'Seq', width: 80 }, { title: '功能ID', field: 'FunctionId', width: 80 }, { title: '菜單可見', field: 'Visible', width: 80 }, { title: 'Winform窗體類型', field: 'WinformType', width: 400 }, { title: 'Web界面Url地址', field: 'Url', width: 200 }, { title: 'Web界面的菜單圖標', field: 'WebIcon', width: 120 }, { title: '系統編號', field: 'SystemType_ID', width: 80 } ]], toolbar: [{ id: 'btnAdd', text: '添加', iconCls: 'icon-add', handler: function () { ShowAddDialog();//實現添加記錄的頁面 } }, '-', { id: 'btnEdit', text: '修改', iconCls: 'icon-edit', handler: function () { ShowEditOrViewDialog();//實現修改記錄的方法 } }, '-', { id: 'btnDelete', text: '刪除', iconCls: 'icon-remove', handler: function () { Delete();//實現直接刪除數據的方法 } }, '-', { id: 'btnView', text: '查看', iconCls: 'icon-table', handler: function () { ShowEditOrViewDialog("view");//實現查看記錄詳細信息的方法 } }, '-', { id: 'btnReload', text: '刷新', iconCls: 'icon-reload', handler: function () { //實現刷新欄目中的數據 $("#grid").datagrid("reload"); } }], onDblClickRow: function (rowIndex, rowData) { $('#grid').datagrid('uncheckAll'); $('#grid').datagrid('checkRow', rowIndex); ShowEditOrViewDialog(); } }) };
對於查詢按鈕觸發的數據後臺查詢及數據綁定操做,javascript代碼以下所示:
//綁定查詢按鈕的的點擊事件 function BindSearchEvent() { //按條件進行查詢數據,首先咱們獲得數據的值 $("#btnSearch").click(function () { //獲得用戶輸入的參數,取值有幾種方式:$("#id").combobox('getValue'), $("#id").datebox('getValue'), $("#id").val() //字段增長WHC_前綴字符,避免傳遞如URL這樣的Request關鍵字衝突 var queryData = { WHC_ID: $("#txtID").val(), WHC_Name: $("#txtName").val(), WHC_Icon: $("#txtIcon").val(), WHC_Seq: $("#txtSeq").val(), WHC_FunctionId: $("#txtFunctionId").val(), WHC_Visible: $("#txtVisible").val(), WHC_WinformType: $("#txtWinformType").val(), WHC_Url: $("#txtUrl").val(), WHC_WebIcon: $("#txtWebIcon").val(), WHC_SystemType_ID: $("#txtSystemType_ID").val() } //將值傳遞給 InitGrid(queryData); return false; }); }
經過構造一些查詢參數並傳遞相應的值,後臺根據這些參數,從對應控制器的分頁方法 FindWithPager 獲取相應的分頁數據,並綁定到grid控件中。
另外,若是須要在grid裏面增長一些圖片或者連接什麼的,應該如何操做呢?
以下界面所示的效果:
首先須要在初始化代碼裏面增長列的formatter回調函數,以下所示。
columns: [[ { field: 'ck', checkbox: true }, //選擇 { title: '顯示名稱', field: 'Name', width: 200}, { title: '圖標', field: 'Icon', width: 150 }, { title: '排序', field: 'Seq', width: 80 }, { title: '功能ID', field: 'FunctionId', width: 80 }, { title: '菜單可見', field: 'Visible', width: 80, formatter: function (val, rowdata, index) { if (val) { return '<a class="grid_visible" href="javascript:void(0)" >' + val + '</a>'; } else { return '<a class="grid_unvisible" href="javascript:void(0)" >' + val + '</a>'; } } }, { title: 'Winform窗體類型', field: 'WinformType', width: 400 }, { title: 'Web界面Url地址', field: 'Url', width: 200 }, { title: 'Web界面的菜單圖標', field: 'WebIcon', width: 120 }, { title: '系統編號', field: 'SystemType_ID', width: 80 } ]],
在formatter回調函數裏面添加邏輯代碼,判斷是否可見,其實就是增長兩個圖片按鈕,可是圖片按鈕的樣式設置,必須在加載數據完畢後才能操做,所以須要在函數裏面處理。
onLoadSuccess: function () { $(".grid_visible").linkbutton({ text: '可見', plain: true, iconCls: 'icon-ok' }); $(".grid_unvisible").linkbutton({ text: '不可見', plain: true, iconCls: 'icon-stop' }); },
若是顯示的圖片不完整,設置行的自動調整高度屬性爲true便可。
autoRowHeight: true
雖然easyui也有Tree控件,不過我較喜歡使用zTree這個樹形控件,這個是一個免費的Jquery樹控件。
引用代碼以下所示:
<link href="~/Content/JQueryTools/JQueryTree/css/zTreeStyle/zTreeStyle.css" rel="stylesheet" type="text/css" /> <script src="~/Content/JQueryTools/JQueryTree/js/jquery.ztree.core-3.5.min.js" type="text/javascript"></script>
初始化在Tree樹控件的界面代碼以下所示:
<script type="text/javascript"> <!-- var setting = { data: { simpleData: { enable: true } }, callback: { onClick: onClick, onDblClick: onDblClick } } //從新加載樹形結構(異步) function reloadTree() { $("#loading").show(); $.getJSON("/DictType/GetTreeJson?r=" + Math.random(), function (json) { $.fn.zTree.init($("#treeDemo"), setting, json); $.fn.zTree.getZTreeObj("treeDemo").expandAll(true); var treeObj = $.fn.zTree.getZTreeObj("treeDemo"); var treeNodes = treeObj.getNodes(); if (treeNodes != null) { loadTypeData(treeNodes[0].id); } }); $("#loading").fadeOut(500); } //樹單擊節點操做 function onClick(event, treeId, treeNode, clickFlag) { var id = treeNode.id; loadTypeData(id); } //樹雙擊節點操做 function onDblClick(event, treeId, treeNode) { var id = treeNode.id; loadTypeData(id); ShowDictType('edit'); }
EasyUI經過DIV層來控制佈局的顯示,DIV裏面增長一個Region的屬性用來區分屬於哪一個區域,以下圖是我Web開發框架的界面佈局效果圖。
界面代碼以下所示:
咱們詳細查看主工做區的代碼,以下所示。
<!--主工做區--> <div id="mainPanle" region="center" title="" style="overflow:hidden;"> <div id="tabs" class="easyui-tabs" fit="true" border="false" > </div> </div>
其中字典管理裏面還有子佈局的展現,咱們查看字典管理裏面界面代碼,以下所示。
<div class="easyui-layout" style="width:700px;height:700px;" fit="true"> <div data-options="region:'west',split:true,title:'字典類別',iconCls:'icon-book'" style="width: 300px; padding: 1px;"> <div style="padding: 1px; border: 1px solid #ddd;"> .......................</div> <div> <ul id="treeDemo" class="ztree"> </ul> </div> </div> <div id="tb" data-options="region:'center',title:'字典數據',iconCls:'icon-book'" style="padding:5px;height:auto"> <!-------------------------------詳細信息展現表格-----------------------------------> <table id="grid" style="width: 940px" title="用戶操做" iconcls="icon-view"></table> </div> </div>
EasyUI彈出式對話框用的不少,對話框的界面代碼放在DIV層裏面,通常在界面整個界面加載後中已經初始化了,只是咱們根據條件類似適當的層便可,這樣就造成了彈出式對話框,彈出式對話框有一個遮罩的效果。
界面代碼以下所示:
在常規的Web界面提示裏面,咱們通常用純粹的javascript的alert函數來進行信息的提示,若是在基於EasyUI的界面佈局和演示裏面,使用這個提示顯然會和界面演示不夠匹配,所以咱們使用messager類來進行相應的提示信息處理,簡單的腳本提示代碼以下。
$.messager.alert("提示", "修改爲功");
提示信息也能夠更加豐富,添加圖標等信息,界面代碼以下所示。
<script> function alert1(){ $.messager.alert('My Title','Here is a message!'); } function alert2(){ $.messager.alert('My Title','Here is a error message!','error'); } function alert3(){ $.messager.alert('My Title','Here is a info message!','info'); } function alert4(){ $.messager.alert('My Title','Here is a question message!','question'); } function alert5(){ $.messager.alert('My Title','Here is a warning message!','warning'); } </script>
對於通常的刪除操做,通常有一個提示確認的消息框,這個messager類也進行了封裝處理,效果也不錯。
界面代碼以下所示。
$.messager.confirm("刪除確認", "您確認刪除選定的記錄嗎?", function (deleteAction) { if (deleteAction) { $.get("/DictData/DeletebyIds", postData, function (data) { if (data == "true") { $.messager.alert("提示", "刪除選定的記錄成功"); $("#grid").datagrid("reload"); //當刪除完成以後,第二次刪除的時候還記得上次的信息,這樣是不能夠的,因此咱們須要清除第一次的信息 rows.length = "";//第一種方法 $("#grid").datagrid("clearSelections");//第二種方法 } else { $.messager.alert("提示", data); } }); } });
以上就是我Web開發框架裏面經常使用到的一些界面控件展現以及相關的代碼介紹,有一些不太經常使用的控件可能尚未在本文中介紹,歡迎你們進行補充和討論,之後有時間繼續完善這個文章,做爲基於MVC+EasyUI的框架界面的一個很好的參考。
但願你們喜歡,多多提意見。