Asp.net mvc5引用ExtJS6【全網首發】

来源:http://www.cnblogs.com/edong/archive/2016/11/11/6053729.html
-Advertisement-
Play Games

摘要:VisualStuio2015 asp.net mvc如何引用ExtJS6,使用BundleConfig。 首先下載ExtJS6.0 gpl版。ExtJS有自己的程式框架,但我們需要asp.net mvc5,ExtJS只用作界面庫。 接下來要把下載好的ExtJS6的核心部分抽取出來,目錄結構是... ...


摘要:VisualStuio2015 asp.net mvc如何引用ExtJS6,使用BundleConfig。

首先下載ExtJS6.0 gpl版。ExtJS有自己的程式框架,但我們需要asp.net mvc5,ExtJS只用作界面庫。

接下來要把下載好的ExtJS6的核心部分抽取出來,目錄結構是這樣的:

image

要引用的東西全在build目錄下,這個目錄有400多M,對於vs項目引用太大了。先把build目錄複製到VS項目目錄下重命名為ExtJS60。

1、將目錄examples、welcome,文件index.html、release-notes.html刪除。

2、刪除調試用的文件。這個目錄里有許多*debug.js、*debug.scss文件,刪除之。用Everything

image

這樣一處理就剩下40多M了。可以直接使用我處理好的 http://pan.baidu.com/s/1qYMtE0W 密碼: 1q14。

接下來就是利用@Scripts.Render和@Styles.Render引用ExtJS。MVC提供了BundleConfig.cs文件用於增加js腳本和css樣式,View視圖統一調用,還能對js和css進行壓縮。

\App_Start\BundleConfig.cs

using System.Web;
using System.Web.Optimization;

namespace WebApplication1
{
  public class BundleConfig
  {
    // 有關綁定的詳細信息,請訪問 http://go.microsoft.com/fwlink/?LinkId=301862
    public static void RegisterBundles(BundleCollection bundles)
    {
      bundles.Add(new ScriptBundle("~/bundles/jquery").Include(
                  "~/Scripts/jquery-{version}.js"));

      bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
                  "~/Scripts/jquery.validate*"));

      // 使用要用於開發和學習的 Modernizr 的開發版本。然後,當你做好
      // 生產準備時,請使用 http://modernizr.com 上的生成工具來僅選擇所需的測試。
      bundles.Add(new ScriptBundle("~/bundles/modernizr").Include(
                  "~/Scripts/modernizr-*"));

      bundles.Add(new ScriptBundle("~/bundles/bootstrap").Include(
                "~/Scripts/bootstrap.js",
                "~/Scripts/respond.js"));

      bundles.Add(new StyleBundle("~/Content/css").Include(
                "~/Content/bootstrap.css",
                "~/Content/site.css"));

      //********自己的JavaScript************************
      ScriptBundle Ext_ScriptBL = new ScriptBundle("~/ExtJS");
      Ext_ScriptBL.Include("~/ExtJS60/ext-all.js");
      Ext_ScriptBL.Include("~/ExtJS60/classic/locale/locale-zh_CN.js");                 //中文資源

      ScriptBundle jquery_ScriptBL = new ScriptBundle("~/jquery");
      jquery_ScriptBL.Include("~/Scripts/jquery-2.1.4.min.js");

      Ext_ScriptBL.Transforms.Clear();
      bundles.Add(jquery_ScriptBL);
      bundles.Add(Ext_ScriptBL);

      CssRewriteUrlTransformWrapper crut = new CssRewriteUrlTransformWrapper();
      StyleBundle StyleBL = new StyleBundle("~/ExtJS_CSS_triton");
      StyleBL.Include("~/ExtJS60/classic/theme-triton/resources/theme-triton-all_1.css", crut);
      StyleBL.Include("~/ExtJS60/classic/theme-triton/resources/theme-triton-all_2.css", crut);

      StyleBundle StyleBL2 = new StyleBundle("~/ExtJS_CSS_neptune");
      StyleBL2.Include("~/ExtJS60/classic/theme-neptune/resources/theme-neptune-all_1.css", crut);
      StyleBL2.Include("~/ExtJS60/classic/theme-neptune/resources/theme-neptune-all_2.css", crut);
      
      StyleBundle StyleBL3 = new StyleBundle("~/ExtJS_CSS_gray");
      StyleBL3.Include("~/ExtJS60/classic/theme-gray/resources/theme-gray-all.css", crut);

      bundles.Add(StyleBL);
      bundles.Add(StyleBL2);
      bundles.Add(StyleBL3);
      //********自己的JavaScript END************************
    }
  }

  public class CssRewriteUrlTransformWrapper : IItemTransform
  {
    public string Process(string includedVirtualPath, string input)
    {
      return new CssRewriteUrlTransform().Process("~" + VirtualPathUtility.ToAbsolute(includedVirtualPath), input);
    }
  }
}

Controllers目錄右鍵→添加→控制器 →mvc5控制器 空。控制器名稱ExtTest。增加視圖(不要佈局頁)

image

\Views\ExtTest\Index.cshtml

@{
    Layout = null;
}

<!DOCTYPE html>
<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Index</title>
  @Styles.Render("~/ExtJS_CSS_neptune")
  @Scripts.Render("~/ExtJS")

  <script type="text/javascript">
    Ext.onReady(function ()
    {
      Ext.create('Ext.tab.Panel', {
        width: 450,
        height: 400,
        renderTo: document.body,
        items: [{
          title: '頁面1',
        },
        {
          title: '頁面2',
        }]
      });
      Ext.Msg.alert("Ready", "ExtJS就緒");
    });
  </script>
</head>
<body>
    <div> 
    </div>
</body>
</html>

運行看看效果:

image


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

-Advertisement-
Play Games
更多相關文章
  • ...
  • 由於一直在高校工作,就涉及到招生工作,招生時候又要收集學生圖像採集,所以就隨手寫了一個圖像採集工具,廢話不多說,進入正題。 圖像採集需要調用攝像頭就行拍照操作,網上查了一下資料,需要引用以下3個dll。 看一下運行界面 界面都比較low,主要是功能實現。 保存照片可以選擇自動覆蓋同名照片或者在照片中 ...
  • 目錄: 1.【C#Windows 服務】 《一》初入門 2.【C#Windows 服務】 《二》INI配置文件 一、工具: VS2015+NET Framework4.5。 二、操作: 1、創建INIHelp幫助類 2、豐富幫助類操作 3、windows實例調用 三、代碼: 1、INI幫助類: 2、 ...
  • 客戶端微信在二維碼狀態下,滑鼠滑過,會有一張手機的圖片滑動滑出,從隱藏到顯示,從顯示到隱藏。 思路很簡單:1、設置透明度;2、給個移動的位移 先看下做的效果 整體代碼也不難,就是給Image控制項設置動畫效果。 <Grid x:Name="grid_content" Background="White ...
  • 目錄結構 father |—— subfolder1 |—— subfolder2 當前在 subfolder1, 通過相對路徑的方式獲取 subfolder2的路徑 ...
  • 前言 最近做了一個電子政務的項目,其中用到了公文簽章和自定義報表,這兩個功能很常用,我就收集到自己的開發框架中了,同時也把實現方法分享給大家。 http://www.learun.cn:8090 線上demo 公文簽章 公文簽章是從網上找的一個JS小插件,原理很簡單,就是把印章放到一個div里,然後 ...
  • 【C#Windows 服務】 《一》初入門 目錄: 1.【C#Windows 服務】 《一》初入門 2.【C#Windows 服務】 《二》INI配置文件 一、工具: VS2015+NET Framework4.5。 二、操作: 1、新建windows服務的項目: 2、修改windows服務相關內容 ...
  • volatile多用於多線程的環境,當一個變數定義為volatile時,讀取這個變數的值時候每次都是從momery裡面讀取而不是從cache讀。這樣做是為了保證讀取該變數的信息都是最新的,而無論其他線程如何更新這個變數。 volatile多用於多線程的環境,當一個變數定義為volatile時,讀取這 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...