MVC無刷新查詢,PagedList分頁控制項使用,導出Excel

来源:http://www.cnblogs.com/tanpeng/archive/2017/02/04/6293879.html
-Advertisement-
Play Games

使用MVC開發也有一段時間了,總結下無刷新部分視圖的使用、PagedList分頁控制項的使用。 @using PagedList @model StaticPagedList<T> <style type="text/css"> .tab-title { background-color: #efef ...


使用MVC開發也有一段時間了,總結下無刷新部分視圖的使用、PagedList分頁控制項的使用。

@using PagedList
@model StaticPagedList<T>
<style type="text/css">
    .tab-title {
        background-color: #efefef;
        width: 10%;
    }

    .btn-custom {
        padding: 6px 24px !important;
        color: #ffffff !important;
        border-radius: 5px;
        font-weight: 500;
        text-transform: uppercase;
        letter-spacing: 0.04em;
    }
</style>
@{

}
<section>
    <div class="container" style="margin-top:10px;padding-top:2em;padding-bottom:4em;">
        @using (Ajax.BeginForm("Index", "Hscode", null,
                        new AjaxOptions()
                        {
                            HttpMethod = "Post",
                            InsertionMode = InsertionMode.Replace,
                            UpdateTargetId = "div-result",
                            OnComplete = "regJs"
                        },
                        new { @class = "form-horizontal", role = "form", id = "ajax-form" }))
        {  <div class="form-group">
            <div class="col-sm-4">
                <input type="text" class="form-control" id="hscode" name="hscode" placeholder="商品編碼">
            </div>
            <div class="col-sm-4">
                <input type="text" class="form-control" id="gname" name="gname" placeholder="商品名稱">
            </div>
            <div class="col-sm-4">
                <button type="submit" class="btn btn-custom btn-sm">
                    <span class="glyphicon glyphicon-search"></span> 查詢
                </button>
                <a href="javascript:void(0)" class="btn btn-custom btn-sm" id="btnExport"><span class="glyphicon glyphicon-download"></span> 導 出</a>
            </div>
        </div>
        }
        <div id="div-result">
            @Html.Partial("_Index", Model)
        </div>
    </div>
</section>

@section scripts{
    <script src="~/Scripts/jquery.nicescroll.min.js"></script>
    <script type="text/javascript">
        function regJs() {
            $("#pager > .pagination-container > .pagination > li > a").click(function () {
                var pageUrl = $(this).attr("href");
                var queryStr = $("#ajax-form").serialize();
                $(this).attr("href", pageUrl + "&" + queryStr);
            });

        }

        regJs();

        $("html").niceScroll({
            cursorcolor: "#ddd",
            cursoropacitymax: 1,
            touchbehavior: false,
            cursorwidth: "10px",
            cursorborder: "0",
            cursorborderradius: "5px"
        });

        $("#btnExport").click(function () {
            var queryStr = $("#ajax-form").serialize();
            location.href = "/Hscode/Export?" + queryStr;
        });
    </script>
}
主視圖
  • 使用@Html.Partial("_Index", Model)在主視圖進行部分視圖的渲染
  • PagedList點擊分頁時如何提交查詢條件?這個問題困擾了下我。

     經網上查資料用如下方法解決:

     $("#pager > .pagination-container > .pagination > li > a").click(function () {
                var pageUrl = $(this).attr("href");
                var queryStr = $("#ajax-form").serialize();
                $(this).attr("href", pageUrl + "&" + queryStr);
            });

       即將表單內容通過URL查詢字元串進行傳遞。

  • 無刷新查詢需要使用的js有:jquery.unobtrusive-ajax
  • 無刷新查詢後會導致js失效,使用OnComplete進行js方法的重新註冊。
@using PagedList
@using PagedList.Mvc
@model StaticPagedList<Hscode>

@if (Model != null && Model.Count > 0)
{

    foreach (var hscode in Model)
    {
        <table class="table table-condensed">
            <tbody>
                <tr>
                    <td class="tab-title" style="border-top:1px dashed #000;">商品編碼</td>
                    <td colspan="5" style="border-top:1px dashed #000;color:#ff0000;">@hscode.Hscode1</td>
                </tr>
                <tr>
                    <td class="tab-title">商品名稱</td>
                    <td colspan="5">@hscode.GName</td>
                </tr>
                <tr>
                    <td class="tab-title">申報要素</td>
                    <td colspan="5">@hscode.DeclarationElements</td>
                </tr>
                <tr>
                    <td class="tab-title">法定第一單位</td>
                    <td>@hscode.Unit1</td>
                    <td class="tab-title">法定第二單位 </td>
                    <td>@hscode.Unit2</td>
                    <td colspan="2"></td>

                </tr>
                <tr>
                    <td class="tab-title">最惠國進口稅率</td>
                    <td>@hscode.ZHGJKSL</td>
                    <td class="tab-title">普通進口稅率</td>
                    <td>@hscode.PTJKSL</td>
                    <td class="tab-title">暫定進口稅率</td>
                    <td>@hscode.ZDJKSL</td>
                </tr>
                <tr>
                    <td class="tab-title">消費稅率</td>
                    <td>@hscode.XFSL</td>
                    <td class="tab-title">出口關稅率</td>
                    <td>@hscode.CKGSL</td>
                    <td class="tab-title">出口退稅率</td>
                    <td>@hscode.CKTSL</td>
                </tr>
                <tr>
                    <td class="tab-title">增值稅率</td>
                    <td>@hscode.ZZSL</td>
                    <td class="tab-title">海關監管條件</td>
                    <td>@hscode.HGJGTJ</td>
                    <td class="tab-title">檢驗檢疫類別</td>
                    <td>@hscode.JYJYLB</td>
                </tr>
                <tr>
                    <td class="tab-title" style="border-bottom:1px dashed #000;">商品描述</td>
                    <td colspan="5" style="border-bottom:1px dashed #000;">@hscode.ProductDesc</td>
                </tr>
            </tbody>
        </table>
    }

    <div style="width:100%;text-align:center">每頁 @Model.PageSize 條記錄,共 @Model.PageCount 頁,當前第 @Model.PageNumber 頁,合計 @Model.TotalItemCount 條記錄</div>
    <div style="width:100%;text-align:center" id="pager">
        @Html.PagedListPager(Model, page => Url.Action("Index", new
   {
       page
   }), PagedListRenderOptions.EnableUnobtrusiveAjaxReplacing(new AjaxOptions
   {
       HttpMethod = "Post",
       InsertionMode = InsertionMode.Replace,
       UpdateTargetId = "div-result",
       OnComplete = "regJs"
   }))
    </div>
}
else
{
    <table class="table table-condensed">
        <thead>
            <tr>
                <th class="text-center">不存在符合條件的數據!</th>
            </tr>
        </thead>
    </table>

}
部分視圖
public class HscodeController : Controller
    {
        private BasicModels dbContext = new BasicModels();

        public ActionResult Index(int? page)
        {
            return Query(page);
        }

        [HttpPost]
        public ActionResult Index(int? page, FormCollection form)
        {
            return Query(page, true);
        }

        private ActionResult Query(int? page, bool ajaxQuery = false)
        {
            int pageIndex = page ?? 1;
            int pageSize = Pager.PageSize;

            IQueryable<Hscode> list = Query();

            int totalItemCount = list.Count();
            list = list.OrderBy(o => o.Id).Skip((pageIndex - 1) * pageSize).Take(pageSize);

            StaticPagedList<Hscode> pageData = new StaticPagedList<Hscode>(list, pageIndex, pageSize, totalItemCount);

            if (ajaxQuery)
            {
                return PartialView("_Index", pageData);
            }
            else
            {
                return View("Index", pageData);
            }
        }

        private IQueryable<Hscode> Query()
        {
            IQueryable<Hscode> list = dbContext.Hscode;

            string hscode = Request["hscode"];
            if (hscode != null && !string.IsNullOrEmpty(hscode.Trim()))
            {
                list = list.Where(w => w.Hscode1.Contains(hscode.Trim()));
            }

            string gname = Request["gname"];
            if (gname != null && !string.IsNullOrEmpty(gname.Trim()))
            {
                list = list.Where(w => w.GName.Contains(gname.Trim()));
            }

            return list;
        }

        public void Export()
        {
            IQueryable<Hscode> list = Query();

            DataTable dt = list.Convert();
            string strFileName = string.Format("申報要素_{0}", DateTime.Now.ToString("yyyyMMddHHmmssffffff"));

            ExcelHelper.ExportXlsxByWeb(dt, strFileName);
        }
    }
控制器代碼
  • 分頁控制項在視圖中的使用如下

 

  • 使用Entity Framework時,因為要根據查詢條件進行查詢。

     早先使用IEnumerate<Hscode> list = dbContext.Hscode;導致表中全部內容載入到記憶體中,查詢很慢。

     怎麼沒使用延遲載入了?最後經同事指正如下才能做到延遲載入:

     IQueryable<Hscode> list = dbContext.Hscode;

  • 查詢條件過濾數據

     if (Request["hscode"] != null && !string.IsNullOrEmpty(Request["hscode"].Trim()))
     {
            list = list.Where(w => w.Hscode1.Contains(Request["hscode"].Trim()));
      }

      這種寫法是有問題的。不知道大家開發的時候有沒有遇到過?

      有條件查詢的時候會報錯LINQ to Entities 不識別方法 System.String get_Item(System.String)

     修正方法如下:

      string hscode = Request["hscode"];
      if (hscode != null && !string.IsNullOrEmpty(hscode.Trim()))
      {
            list = list.Where(w => w.Hscode1.Contains(hscode.Trim()));
      }


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

-Advertisement-
Play Games
更多相關文章
  • 創建Visual Studio插件,項目模板,項目創建嚮導等原來也是如此簡單。本文通過開發Prism的Plugin實例講解其中的實現過程與註意事項。 ...
  • using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Data;using System.Data.SqlClient;using System.Data.Commo ...
  • Xamarin寫Android程式時,通常要使用按中文首字母分組顯示(如通訊錄) 。 於是需要被迫包含CJK,不過包含後包肯定是會變大的,於是。。。。自己寫了一個硬枚舉的中文轉拼音的類。 原理是這樣的: 源碼: https://github.com/chsword/PinYinUtil/blob/m ...
  • 在本節中,您將創建一個新的MoviesController類,併在這個Controller類里編寫代碼來取得電影數據,並使用視圖模板將數據展示在瀏覽器里。 在開始下一步前,先Build一下應用程式(生成應用程式)(確保應用程式編譯沒有問題) 用滑鼠右鍵單擊Controller文件夾,並創建一個新的  ...
  • 前言 本節主要介紹非同步編程中Task、Async和Await的基礎知識。 什麼是非同步? 非同步處理不用阻塞當前線程來等待處理完成,而是允許後續操作,直至其它線程將處理完成,並回調通知此線程。 非同步和多線程 相同點:避免調用線程阻塞,從而提高軟體的可響應性。 不同點: 非同步操作無須額外的線程負擔,並且使 ...
  • asp.net程式開發,用戶根據角色訪問對應頁面以及功能。 項目結構如下圖: 根目錄 Web.config 代碼: admin文件夾中 Web.config 代碼: teacher文件夾中 Web.config 代碼: student文件夾中 Web.config 代碼: Login.aspx中登錄 ...
  • 寫在前面 全部手打,沒有多餘的話,全部乾貨,基本上用到的我就記錄了。 一、什麼是JSON JSON:JavaScript Object Notation,是一種輕量級的數據交互格式,主要用於數據傳輸。 二、JSON語法規則 1、數據由鍵值對(映射)關係表示,使用 “:” 表示; 例子:"name" ...
  • 創建型模式靜態工廠模式(Factory Pattern)靜態方法返回實例抽象工廠模式(Abstract Factory Pattern)介面方式返回實例建造者模式(Builder Pattern)每次返回多個實例單例模式(Singleton Pattern)類只有一個實例原型模式(Prototype ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...