使用asp.net MVC4中的Bundle遇到的問題及解決辦法分享_實用技巧

來源:互聯網
上載者:User

背景 
  之前有過使用MVC3的經驗,也建過MVC4的基本範例看過,知道有bundle這麼一個方法。

  近日想建個網站使用MVC4,但是我覺得在基本範例上改不好,有太多無用的東西,所以就建了一個空白的MVC的程式,然後自己寫需要的東西,

  將程式的目標框架從4.5降到了4.0(我使用的是VS2013),問題就來了。

問題及解決辦法
 1、降了目標框架之後,vs報一個警告:NuGet程式包是使用不同於當前目標框架的目標框架安裝的,需要更新System.Web.Http,之前有用過NuGet,

     但是只是用它來添加需要的程式集, 沒有更新過啊。

     解決:搜尋之,不難找到答案,在NuGet的命令視窗,使用Update-Package 程式包名 來更新,對於只使用管理NuGet程式包視窗的人來說,命令視窗在哪呢?

開啟視窗,使用命令 update-package System.Web.Http 更新即可。


2、第一次見到使用Bundle時候,覺得有這個之後多處引用js或者css的時候寫的就方便了,現在知道了它更大的用處是對js或者css檔案進行合并壓縮。

    具體怎麼用呢,不知道了,好解決,再單獨建立一個mvc4的基本範例程式查看一下。

    問題: 首先需要在App_Star檔案夾下建立一個BundleConfig.cs類,定義RegisterBundles方法,需要BundleCollection對象作為參數,發現沒有BundleCollection類

    解決:程式添加對System.Web.Optimization.dll的引用,類中添加using System.Web.Optimization

    問題:BundleConfig.cs類寫好了,在Global.asax檔案的Application_Start方法中註冊了,那在頁面View中用吧,但是寫@Styles.Render時怎麼也不出提示,

            怎麼沒有呢? 在範例頁面上也沒看到有引用命名空間呢?

    解決:原來這個命名空間是需要在web.config中添加的,在程式目錄下有個web.config ,在View檔案夾下也有個web.config,在兩個檔案中都加上

             <add namespace="System.Web.Optimization"/> ,具體位置你一看web.config就知道了。

   問題:OK,都寫好了運行一下吧,我去,出異常了。第一眼就看見提示“使用相對路徑時,請確保目前的目錄是正確的”,難道說是BundleConfig.cs定義的檔案路徑有問題?

            問題是沒有載入WebGrease

解決:程式添加引用:Antlr3.Runtime.dll 和WebGrease.dll,在程式根目錄下的web.config中添加以下節點

問題:程式運行起來,沒有報錯,以為一切ok了,卻發現Jquery.min.js檔案沒有引用上?

       解決:上邊說到了bundle有對檔案壓縮的功能,檔案名稱中有min它就不引用了,所以把檔案名稱中的min去掉,改成Jquery.js就可以了。

        搜尋過程中有篇文章說

    new ScriptBundle("~/bundles/js/jqueryContent") 中的的名字 不能有特殊符號。。比如 . - 否則無效呀。地址

總結:在使用bunle過程中需要引用三個dll,在web.config中做兩處的配置,我想我如果不從0開始寫,我不會知道這些。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.