ASP.NET MVC+EF在服務端分頁使用jqGrid以及jquery Datatables的註意事項

来源:http://www.cnblogs.com/M-LittleBird/archive/2016/06/11/5575378.html
-Advertisement-
Play Games

引言: 本人想自己個博客網站出來,技術路線是用ASN.NET MVC5+EF6(Code First)+ZUI+各種Jquery插件,有了這個想法之後就開始選擇UI,看了好多bootstrap的模板之後,發現即使你用了bootstrap還是要自己寫css樣式,都是自學的,前端真的很垃圾,在網上找了很... ...


引言:

本人想自己個博客網站出來,技術路線是用ASN.NET MVC5+EF6(Code First)+ZUI+各種Jquery插件,有了這個想法之後就開始選擇UI,看了好多bootstrap的模板之後,發現即使你用了bootstrap還是要自己寫css樣式,都是自學的,前端真的很垃圾,在網上找了很多UI,以下是各種UI的地址,需要的可以去看看:

H-ui:http://www.h-ui.net/H-ui.admin.shtml ,是一個前端大牛弄得,模仿bootstrap,做適合中國網上的UI。

Amaze UI:http://amazeui.org/ ,中國HTML5 前端框架 對IE老版本相容不好,這個我也是網上看的IE10以上 不錯 如果想相容IE8 官網都說不怎麼好了。

ZUI:http://zui.sexy/ 一個基於Bootstrap深度定製開源前端實踐方案,幫助你快速構現代跨屏應用。

最後選擇了ZUI,因為是Bootstrap定製的 上手也容易點 因為以前也學過Bootstrap的使用 自己寫了些DEMO 感覺不錯,我找了很多模板都是弄好了,國外的多,所以前端自己又垃圾,就改起來也發麻煩,就不放棄了,主要是自己還是垃圾了。

 

1.登錄界面

有了以上的方法之後我就自己開始做了一個登錄界面:

image

雖然被技術群里的大神 嫌棄了很久 但是 我自己做的。

 

2.表格的選擇

不好意思各位,以上好像講的跟要說的東西沒什麼關係,接下來就是表格選擇了,我是一個很糾結的人,真的很糾結,由於ZUI中只有表格的樣式,沒用那種帶有分頁 一共多少條,設置每頁的頁數,按照ZUI的創始人員的說法是,分頁這些可以用js分頁控制項來代替,這樣主要是為了載入數據,這是他們在項目中實踐的結果,但是我還是想要個有這些功能的表格,所以我就想自己在網上找,找到兩個一個是JQGrid和jquery Datatables,就又開始糾結了用哪個了? 因為以前用過jQuery EasyUI 所以一開始選擇了JQGrid:

 

  2.1JQGgird在asp.net MVC下實現過程:

       在JQGgird官網下載js文件,官網地址:http://www.trirand.com/blog/ ,貌似又更新了2016年6月9日,DEMO 地址:http://www.guriddo.net/demo/bootstrap/  Bootstrap風格,另外一個中文demo網站:http://blog.mn886.net/jqGrid/ 然後開始上乾貨:

       1.建立以個JQGridController控制器:

image

       2.建立index頁面 引入相應的js以及CSS樣式:

image

  3.查看插入的參數: rows為一頁多少條記錄 ;page為第幾頁;

image

image

4.查看數據返回的格式 :page為第幾頁;records:為一共多少條數據;rows:為數據集合;total:為一共多少頁

image

5.然後就依葫蘆畫瓢在後臺弄個這樣的數據格式出來:

image

5.1:分頁查詢的方法,使用的是查詢多少條,跳過多少條的思路:

image

6.前端HTML頁面調用以及js部分: 需要說明一點的是:http://www.guriddo.net/demo/bootstrap/ DEMO中的實例使用的是php的後臺數據格式為 datatype: "jsonp";而我這裡MVC返回要改成 datatype:"json",為了這個問題我弄了好久,痛苦。

image

 

7、展示效果:

image

看到的效果之後我,我就開始不舒服了 為什麼左邊會有空白的地方,看著不爽,當載入了數據過多的時候,發現原來是為了滾動條保留的位置

image

然後我就糾結,不喜歡這個樣式了,有接下的jquery Datatables

 

2.2jquery Datatables在asp.net MVC下實現過程:

       同樣在網上找官網:中文官網:http://datatables.club/  (是一個大牛在很早以前用過jquery Datatables之後,發現中文的資料很少,就跟國外的作者聯繫翻譯成中文,很崇拜這種人) ;英文官網 :https://datatables.net/examples/index

      1.首先建立DataTabController控制器:

image 

  2.建立index頁面 引入相應的js以及CSS樣式:

image

3.查看官網實例找參數,以及返回數據格式:

伺服器端分頁demo:https://datatables.net/examples/server_side/jsonp.html

datatables 需要配置"serverSide": true,才能開啟服務端模式;關鍵參數:start為從第幾條開始;length為一頁多少條;draw:為繪製計數器。這個是用來確保Ajax從伺服器返回的是對應的(Ajax是非同步的,因此返回的順序是不確定的)。 要求在伺服器接收到此參數後再返回(具體看下麵);具體參數查詢官網地址http://datatables.club/manual/server-side.html

image

返回數據格式:data為數據集;draw:為繪製計數器;recordsFiltered:為過濾多少條;recordsTotal:為總共多少條

image

4.然後我就開始寫大言不慚的認為自己會用了應該更JQGrid差不多:

image

  5.   前端html以及js代碼:

image

結果是報錯了:

image

弄了很久沒弄出來:因為我的查詢數據返回的格式是跟DEMO中一樣的,我就開始鬱悶了:

image

 

總結:

經過群里的大神指點,終於找到問題了:

因為datatables中傳到後臺的參數是start表示的是從第幾頁條開始跟jqgrid的page第幾頁不同,第一次穿到後臺的是0,從第0條開始,在分頁的時候:傳0過去減1的話就是負數,所以報錯

image

於是做了修改:

先把pagesize做個判斷

image

在分頁的時候也修改了跳過條數的設置

image

然後重新啟動測試頁面:

image

這樣數據就出來了

後續:

         希望我的總結對需要用到JQGrid以及Datatables兩個JS控制項的小伙伴,有幫忙吧,謝謝。另外我會繼續弄我的博客,把裡面用到的知識點,一點一點的分享給大家,博客園的大神太多了,謝謝大神的帖子給我在技術中遇到問題是否的幫助。


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

-Advertisement-
Play Games
更多相關文章
  • 還原成一個可移動磁碟教程,只是在"分區設置"中將 "模式=21" 改為 "模式=3" 即可。 1. 打開:"MPALL_F1_9000_v329_0B"進入量產界面: 2. 點擊"Setting"進入設定畫面: 選擇"New Seting"、"Advance Setting"點"OK",進入設定畫面 ...
  • 這次介紹一下操作系統的進程調度演算法 操作系統的調度分為三種:1.遠程調度(創建新進程);2.中程調度(交換功能的一部分);3.短程調度(下次執行哪個進程) 這次講述的就是短程調度,可以簡單的看作咱們平時所說的進程調度啦 當發生下麵幾種情況的時候會調用短程調度器,然後就看下次執行那個進程啦 時鐘中斷 ...
  • 寫程式的很多人都知道的,Session是伺服器端的東西而Cooike是客戶端的東西。因為B/S模式是無狀態模式,它們的應用都是要存儲客戶端的某些登錄或是加密的信息。 Session存在於伺服器端,當然要占用一些伺服器資源,當有戶數量過多時,不可避免的影響伺服器運行速度與資源。而Cookie存在在客戶 ...
  • 這個是針對ACCESS資料庫操作的類,同樣也是從SQLHELPER提取而來,分頁程式的調用可以參考MSSQL那個類的調用,差不多的,只是提取所有記錄的數量的時候有多一個參數,這個需要註意一下! 推薦:http://www.cnblogs.com/roucheng/p/3521864.html ...
  • 為了適應應對各種資料庫間切換,我們有時想要要自定義寫一個通用的SqlHelper。常用的做法就是在 System.Data.Common.DbProviderFactories.GetFactory(dbProviderName).CreateConnection() ,來返回對應的 資料庫的Con ...
  • 當IE瀏覽器遇到腳本錯誤時,在瀏覽器左下角會出現一個黃色圖標,點擊可以查看腳本錯誤的詳細信息,並不會有彈出的錯誤信息框。我們在用webBrowser編寫的程式打開網頁,遇到腳本有問題是,會彈出一個錯誤提示框,需要確認後才能夠進行執行。如果我們設計的程式是用來自動處理網頁的,那麼在出現這種情況時,程式 ...
  • 字母轉換成數字 byte[] array = new byte[1]; //定義一組數組array array = System.Text.Encoding.ASCII.GetBytes(string); //string轉換的字母 int asciicode = (short)(array[0]) ...
  • 變數定義中類型後帶一個問號,意思是這個數據類型是NullAble類型的。用於給變數設初值的時候,給變數(int類型)賦值為null,而不是0!例子: int? i = 3 等同於Nullable<int> i = new Nullable<int>(3);int?是泛型Nullable<int>的另 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...