用MVC5+EF6+WebApi 做一個考試功能(五) 前端主題

来源:https://www.cnblogs.com/buyixiaohan/archive/2018/01/28/8325822.html
-Advertisement-
Play Games

內容概述 前面絮絮叨叨沒正事,到現在為止也沒有開始寫代碼,不過在考慮下貌似這一節還是開始不了。 B/S架構開發有一個特點,就是用瀏覽器打開,不同的用戶群體可能有不同的風格,不論是管理平臺還是普通的網站,也是有自己的風格。 我們要做這樣一個管理系統,風格上沒有客戶來約束要做什麼樣,那簡單處理,我們採用... ...


內容概述

 

 

前面絮絮叨叨沒正事,到現在為止也沒有開始寫代碼,不過在考慮下貌似這一節還是開始不了。

B/S架構開發有一個特點,就是用瀏覽器打開,不同的用戶群體可能有不同的風格,不論是管理平臺還是普通的網站,也是有自己的風格。

我們要做這樣一個管理系統,風格上沒有客戶來約束要做什麼樣,那簡單處理,我們採用如下處理

  • Bootstrap :據說是Twitter工程師覺得前端工作太麻煩然後就弄了一套框架出來,現在有三個版本並行,2.x,穩定版本是3.x.x,開發中的是v4.x,在2018年1月18號發佈了正式版。在接觸Bootstrap之前,做B/S架構的項目是很麻煩的,首先要找一個美工來設計一套頁面,然後還要考慮各種瀏覽器相容,CSS,Js等等都要考慮。bootstrap首先頁面統一,另外是響應式的、移動端優先的一套框架。尤其適合快速原型等。
  • JQuery:很多年曆史了,當年js很難寫,後來出了JQuery,解決了很多相容性的問題,Dom操作也變得簡單得多。也是有多個版本,1.X相容性比較寬,對IE支持較好。2.X和3.X拋棄了一些對就瀏覽器的相容。所以用jQuery的時候要先確定好客戶端需要的相容性,然後在考慮那個版本。
  • Bootstrap Admin模板:網上有不少基於Bootstrap構建的Admin模板,就看各位在網上查找資源的本領了。Github是一個大寶庫,程式員一定要能利用起來。這裡極少一個MIT開源協議的,基於Bootstrap 3.x版本構建的一套Admin管理模板 。地址:https://adminlte.io/

現在用angular和vue做項目的也有不少,和咱這裡有比較大的區別,因為一個是SPA一個MPA,具體區別大家去查一下。如果自己構造的話,可能會用到各種插件,綜合來說,插件選擇要考慮成本、易用度、是否穩定版本、文檔是否齊全、是否有人維護(有了問題有人修複)。簡單看下本項目中用到兩個前端插件:

  • datatable:基於MIT開源協議,可以隨便用。文檔比較完備,有官網論壇,除了開源版本還有擴展的商業授權版本。缺點:缺少中文文檔。
  • jstree:基於MIT開源協議,可以隨便用。文檔比較完備,有官網論壇,支持插件擴展,如果有能力可以自己寫擴展。缺點:老外寫的, 沒中文文檔。

開始幹活

在MVC項目中,定位到Views/Shared/_Layout.cshtml。打開layout,這個和webform中的模板頁類似,基於Razor語法構建的模板。

<!DOCTYPE html>
<html>
<head>
    <title>@ViewBag.Title</title>
    <link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />
    <script src="@Url.Content("~/Scripts/jquery-1.5.1.min.js")" type="text/javascript"></script>
</head>

<body>
    @RenderBody()
</body>
</html>

這是一個標準的Layout佈局頁,其中,@RenderBody()是模板頁中嵌套部分的標記(語言沒及格,不知道怎麼說了)。可以理解為把一個HTML頁面中挖出一個空來,共用外面的部分,個性化就是裡面的部分。當不同的頁面使用這個layout時候,風格比較統一,公共部分都在layout.cshtml這個頁面上。

如果是使用Bootstrap進行樣式佈局的話,Bootstrap提供了一套標準樣式

<!DOCTYPE html>
<html lang="zh-CN">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 上述3個meta標簽*必須*放在最前面,任何其他內容都*必須*跟隨其後! -->
    <title>Bootstrap 101 Template</title>

    <!-- Bootstrap -->
    <link href="css/bootstrap.min.css" rel="stylesheet">

    <!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
    <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
    <!--[if lt IE 9]>
      <script src="https://cdn.bootcss.com/html5shiv/3.7.3/html5shiv.min.js"></script>
      <script src="https://cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
    <![endif]-->
  </head>
  <body>
    <h1>你好,世界!</h1>

    <!-- jQuery (necessary for Bootstrap's JavaScript plugins) -->
    <script src="https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
    <!-- Include all compiled plugins (below), or include individual files as needed -->
    <script src="js/bootstrap.min.js"></script>
  </body>
</html>

 

把兩者集合到一起,得到我們想要的佈局頁:

@{
    //模板頁也可以再次嵌套模板頁
    Layout = null;
}

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>一個標準的Layout佈局頁</title>
    <link href="css/bootstrap.min.css" rel="stylesheet">

    @* 給繼承頁面預留的樣式視窗 *@
    @RenderSection("styles", false)

    <!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
    <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
    <!--[if lt IE 9]>
      <script src="https://cdn.bootcss.com/html5shiv/3.7.3/html5shiv.min.js"></script>
      <script src="https://cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
    <![endif]-->
</head>
<body>
    <div class="content-wrapper">

        <section class="content">
            @*繼承頁面內容填充到這裡*@
            @RenderBody()
        </section>
    </div>

    <script src="~/Scripts/jquery-1.12.4.min.js"></script>
    <script src="js/bootstrap.min.js"></script>

    @* 給繼承頁面預留的js腳本視窗 *@
    @RenderSection("scripts", false)
</body>
</html>

 

當添加視圖的時候,將“使用佈局頁”勾選,並選擇一個佈局頁,然後書寫代碼如下:

@{

    //說明瞭視圖頁是嵌套在_Layout.cahtml這個佈局頁的
    Layout = "~/Views/Shared/_Layout.cshtml";

    //一般設置頁面的標題,顯示在瀏覽器tab簽上
    ViewBag.Title = "MVC佈局頁的實例";
}

@*
    在這裡設置視圖頁個性化的樣式內容,比如引入一些css文件,編寫一些class等等
    會渲染到於佈局頁中的 @RenderSection("styles", false)的位置
*@
@section styles{
    <style type="text/css">
        h2 {
            font-size: 48px;
        }
    </style>
}

<div class="well">
    <h2>Hello Trump!</h2>
</div>

@*
    在這裡編寫視圖頁的頁面腳本或引入一些js文件。
    內容會渲染到佈局頁中 @RenderSection("scripts", false)的位置
*@

@section scripts{
    <script type="text/javascript">
        $(function () {
            alert("hello ivanka!");
        })
    </script>
}

 

基本上佈局頁的使用就這些,網上各種說明有一大堆,真正用的時候碰到問題可以查找一下,沒有多少問題。

最後看一下我們設計好的後臺首頁,下一節將處理一下EF公共類的問題。

GIF


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

-Advertisement-
Play Games
更多相關文章
  • 任何項目中都會使用到靜態類、靜態方法、靜態成員和實例成員了。那麼這幾個名詞到底有哪些區別呢? 1、靜態成員和實例成員 靜態成員:靜態成員通常和類是相關聯的。它可以作為類中公有的變數,不依賴特定對象的存在。通常我們在訪問它們的時候很簡單,直接通過類名加點操作符再加變數名來進行操作。 實例成員:實例成員 ...
  • 為什麼選擇.NETCore? 在開展話題之前先出一張ASP.NETCore VS Node.js的性能對比圖 ASP.NET Core VS node.js: 繼續正文: 學習新的開發框架是一項巨大的投資。您需要學習如何在新框架中編寫,構建,測試,部署和維護應用程式。作為開發人員,有許多框架可供選擇 ...
  • 首次接觸 ,就感覺非常棒。它節省了我們以前寫SQL語句的過程,同時也讓我們更加的理解面向對象的編程思想。最近學習了EF的增刪改查的過程,下麵給大家分享使用EF對增刪改查時如何處理的。 第一步:創建自定義的 來連接自己的資料庫。 1、新增操作 我們會根據前臺傳過來的實體信息對資料庫的表進行新增操作。對 ...
  • 為什麼要使用任務? 上一篇博客中提到了線程池ThreadPool,可以調用QueueUserWorkItem方法來發起一次非同步的操作。但是這個技術存在許多限制,最大的問題是沒有一個內建的機制讓你知道操作在什麼時候完成,也沒有一個機制在操作完成時獲得一個返回值。 為了剋服這些限制,微軟引入了Task的 ...
  • 使用C#代碼模擬web請求,是一種常用的方法,以前沒專門整理過,這裡暫時貼上自己整理的完整代碼,以後再做梳理: ...
  • NPOI導出EXCEL報_伺服器無法在發送 HTTP 標頭之後追加標頭 ...
  • 對象持久化到文本文件,策略是:將對象的屬性值打散,拆解,分別存儲。 序列化: 保存對象的"全景圖" 序列化是將對象轉換為可保存或可傳輸的格式的過程 三種: 二進位序列器: 對象序列化之後是二進位形式的,通過BinaryFormatter類來實現的,這個類位於System.Runtime.Serial ...
  • 第一部分: 如果在安裝的時候選中的是Window身份驗證,後來需要SQLServer身份驗證登錄,那麼 一、先用window賬號登錄資料庫 二、啟用window身份驗證和sql sever身份驗證方式 2.1 選中“實例”--右鍵--屬性--安全性--伺服器身份驗證--sql sever和windo ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...