EasyUI edatagrid插件使用小計

来源:http://www.cnblogs.com/dahuo/archive/2017/11/03/7777004.html
-Advertisement-
Play Games

html片段 1 <table id="menuview" style="width:100%"> 2 <thead> 3 <tr> 4 <th field="ID0" width="5%" fixed="true" checkbox="true"></th> 5 <th field="TOPIC" ...


html片段

 1    <table id="menuview" style="width:100%">
 2         <thead>
 3             <tr>
 4                 <th field="ID0" width="5%" fixed="true" checkbox="true"></th>
 5                 <th field="TOPIC" width="30%" fixed="true" editor="{type:'validatebox',options:{required:true,missingMessage:'目錄名稱不能為空。',height:'100px'}}">目錄名稱</th>
 6                 <th field="WJBH" width="10%" fixed="true" editor="text">文件編號</th>
 7                 <th field="ARCHUSER" width="10%" fixed="true" editor="text">責任者</th>
 8                 <th field="PAGECOUNT" width="5%" fixed="true" editor="numberbox">頁數</th>
 9                 <th field="YH" width="5%" fixed="true" editor="text">頁號</th>
10                 <th field="RQ" width="10%" fixed="true" editor="{ type:'datebox',options:{editable:false}}">日期</th>
11                 <th field="ISSCJNML" width="10%" fixed="true" editor="{ type:'checkbox',options:{on: 1,off:0}}" align="center" formatter="rowCheckBoxFormater">是否生成件內目錄</th>
12                 <th field="BZ" width="15%" fixed="true" editor="text">備註</th>
13             </tr>
14         </thead>
15     </table>
View Code

javascript 片段

  1 $('#menuview').edatagrid({
  2             idField: 'ID0',//主鍵
  3             rownumbers: true,//序號
  4             pagination: false,//是否分類
  5             fitColumns: true,//配合列拖動時,禁止列自適應寬度
  6             singleSelect: false,  //是否單選,
  7             url: "GetCatalogNew?ARCHGID=" + vARCHGID + "&ISSJ=" + vISSJ,//獲取數據url
  8             pageSize: 15,//分頁配置
  9             pageList: [15, 30, 45, 60],//分頁配置
 10             toolbar: '#tb',//工具
 11             autoSave: false,//是否自動報錯
 12             selectOnCheck: true,
 13             checkOnSelect: false,
 14             saveUrl: "CatalogAddYY?ISSJ=" + vISSJ,        //新建,都是eadatagrid封裝好的,把鏈接填好就行,點擊之後會自動發送json數據包
 15             updateUrl: "CatalogAddYY?ISSJ=" + vISSJ,      //保存
 16             destroyUrl: "CatalogAddYY?ISSJ=" + vISSJ,      //刪除
 17             destroyMsg: {
 18                 norecord: {    // 在沒有記錄選擇的時候執行
 19                     title: '警告',
 20                     msg: '沒有要刪除的記錄。'
 21                 },
 22                 confirm: {       // 在選擇一行的時候執行
 23                     title: '確認',
 24                     msg: '您確定要刪除嗎?'
 25                 }
 26             },
 27             onBeforeLoad: function (param) {
 28             },
 29             onLoadSuccess: function (data) {
 30                 $(this).datagrid('enableDnd');
 31             },
 32             onLoadError: function () {
 33             },
 34             onDestroy: function (index, row) {
 35             },
 36             onAdd: function (index, row) {
 37                 row.ARCHGID = vARCHGID;
 38             },
 39             onBeforeSave: function (index) {
 40                 return true;
 41             },
 42             onSave: function (index, row) {
 43                 var $datagrid = $('#menuview');
 44                 if ($datagrid.data('isSave')) {
 45                     //如果需要刷新,保存完後刷新
 46                     $datagrid.edatagrid('reload');
 47                     $datagrid.removeData('isSave');
 48                 }
 49             },
 50             onBeforeDrag: function (row) {
 51                 var vSelectRowIndex = $('#menuview').datagrid('getRowIndex', row);//獲取選擇行索引
 52                 var vEditRowIndex = $('#menuview').datagrid('getEditingRowIndexs')//獲取編輯行索引
 53                 if (vSelectRowIndex == vEditRowIndex) { //防止 編輯行拖動bug
 54                     return false;
 55                 }
 56             },
 57             //拖拽某行到指定位置後觸發
 58             onDrop: function (targetRow, sourceRow, point) {
 59                 //獲取拖拽後的數據行
 60                 var rows = $('#menuview').edatagrid("getRows");
 61                 var id0 = "";
 62                 var vLength = rows.length;
 63                 for (var i = 0; i < vLength; i++) {
 64                     id0 += rows[i].ID0 + ",";
 65                 }
 66                 MaskUtil.mask();
 67                 $.post("UpFileOrder?ID0=" + id0 + "&ISSJ=" + vISSJ, function (response) {
 68                     $('#menuview').edatagrid("reload");
 69                     MaskUtil.unmask();
 70                 });
 71             },
 72             toolbar: [{
 73                 text: '增加',
 74                 iconCls: 'icon-add',
 75                 handler: function () {
 76                     $('#menuview').edatagrid('addRow');
 77                 }
 78             }, {
 79                 text: '保存',
 80                 iconCls: 'icon-save',
 81                 handler: function () {
 82                     //標記需要刷新
 83                     $('#menuview').data('isSave', true).edatagrid('saveRow');
 84                 }
 85             }, {
 86                 text: '合併',
 87                 iconCls: 'icon-save',
 88                 handler: function () {
 89                     //標記需要刷新
 90                     $('#menuview').data('isSave', true).edatagrid('saveRow');
 91                 }
 92             }, {
 93                 text: '分割',
 94                 iconCls: 'icon-save',
 95                 handler: function () {
 96                     //標記需要刷新
 97                     $('#menuview').data('isSave', true).edatagrid('saveRow');
 98                 }
 99             }, '-',
100 
101             '-', {
102                 text: '刪除',
103                 iconCls: 'icon-save',
104                 handler: function () {
105                     delData();
106                 }
107             }, {
108                 text: '刷新',
109                 iconCls: 'icon-reload',
110                 handler: function () {
111                     $('#menuview').edatagrid('reload');
112                 }
113             }]
114         });
115     });
116     /*
117 *  datagrid 獲取正在編輯狀態的行,使用如下:
118 *  $('#id').datagrid('getEditingRowIndexs'); //獲取當前datagrid中在編輯狀態的行編號列表
119 */
120     $.extend($.fn.datagrid.methods, {
121         getEditingRowIndexs: function (jq) {
122             var rows = $.data(jq[0], "datagrid").panel.find('.datagrid-row-editing');
123             var indexs = [];
124             rows.each(function (i, row) {
125                 var index = row.sectionRowIndex;
126                 if (indexs.indexOf(index) == -1) {
127                     indexs.push(index);
128                 }
129             });
130             return indexs;
131         }
132     });
View Code


 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...