欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解RequireJS按需加載樣式文件

 更新時間:2017年04月12日 09:53:01   作者:兩儀  
本篇文章主要介紹了RequireJS按需加載樣式文件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

樣式模塊化的好處

RequireJS被設(shè)計用來加載JavaScript模塊的,可是大家有沒有聯(lián)想到其實樣式文件可以進(jìn)行模塊化處理,那么問題來了,RequireJS能不能像加載腳本文件一樣來加載樣式文件呢?

雖然RequireJS本身沒有實現(xiàn)這個功能,但官網(wǎng)推薦了一些常用的插件供我們使用,官網(wǎng)插件插件地址為:http://requirejs.org/docs/plugins.html,同時在github上也有社區(qū)大量貢獻(xiàn)的插件:https://github.com/jrburke/requirejs/wiki/Plugins

當(dāng)然除了引用第三方插件外,我們也可以動手自己寫一個類似插件,不過我在這里要推薦一個很不錯的樣式模塊加載器require-css,其官網(wǎng)地址為:https://github.com/guybedford/require-css。

那么我們再來談?wù)?,樣式模塊話的好處吧,和腳本模塊化一樣,樣式模塊化也可以做到按需加載,樣式依賴,不過對我來說最大的好處是將腳本的管理放權(quán)到前端管理,為什么這么說呢? 以前我們添加樣式文件都是通過link標(biāo)簽引入的,而被引入的文件基本上都是jsp、php等后臺文件,這樣對與后臺不太熟悉的人來說,如果樣式文件發(fā)生改變,都要麻煩后臺開發(fā)人員。但是最懂樣式的莫過于前端開發(fā)人員了。

require-css的使用介紹

下面我們通過一個簡單的例子,來介紹下require-css的用法,首先下載require-css,去到上面給出的官網(wǎng)地址,在頁面的右下角點擊Download ZIP按鈕,下載完成后解壓,將css.js拷貝復(fù)制到項目中去。

這個簡單示例的目錄如下所示:

假設(shè)我們的目的是,通過加載util模塊時,頁面先加載其依賴的樣式文件1.css。這個需求我們經(jīng)常遇到,比如我們使用JqueryUI時,在加載其腳本模塊時,在頁面我們也會添加上link標(biāo)簽引入其相關(guān)的UI樣式文件。

首先我們在project.html中引入RequireJS和指定配置文件(main.js)的位置。期代碼如下所示:

<!DOCTYPE html>
<html>
<head lang="en">
  <meta charset="UTF-8">
  <title>RequireJS簡單示例</title>
</head>
<body>
  <p id="test">如何處理依賴問題</p>
  <script src="scripts/lib/jquery-1.11.0.min.js"></script>
  <script src="scripts/require.js" data-main="scripts/main"></script>
</body>
</html>

我們進(jìn)入到main.js配置文件。main.js應(yīng)該是頁面的入口文件,在這個入口文件中,指定了入口文件需要加載的模塊,同事也設(shè)置了RequireJS某些具體參數(shù)。其代碼如下所示:

/*入口腳本*/
require.config({
  baseUrl: "scripts/",
  paths: {
    "util": "helper/util"
  },
  waitSeconds: 15,
  map: {
    '*': {
      'css': 'lib/css'
    }
  },
  shim : {
    'util': ['css!../style/1.css']
  }
});

require(["util"], function(util) {
  // todo
});

其中我們要特別注意map和shim的配置,"map"告訴RequireJS在任何模塊之前,都先載入這個模塊,這樣別的模塊依賴于css!../style/1.css這樣的模塊都知道怎么處理了,shim那時干什么用的呢?這這個示例中,他表示util這個模塊在加載之前需要先加載1.css這個樣式文件。當(dāng)然我們也可以在Util模塊里直接設(shè)置他的依賴,下面將會解釋。

下面我們來看看util模塊的代碼,代碼如下所示:

define(function(){
  //alert("Hello RequireJS!!");
  console.log($("#test").text());
});

這個模塊很簡單,就是通過jQuery獲取頁面id為test的值。并且在瀏覽器的控制臺輸出來。這里你可能感覺有點奇怪。為什么你使用了jQuery但是在依賴數(shù)組中且沒有設(shè)置呢?正確的說,我們應(yīng)該這樣寫:

define(['jquery'],function(){
  //alert("Hello RequireJS!!");
  console.log($("#test").text());
});

我這樣做的目的是,用RequireJS打包時,不要將jquery打包進(jìn)去,這樣就可以減少文件的大小了。還有一個上面提出的問題,加入我不用shim這個配置時,可以向依賴JQuery一樣,將樣式文件寫到define的依賴數(shù)組中去。其代碼如下:

define(['css!../style/1.css'],function(){
  //alert("Hello RequireJS!!");
  console.log($("#test").text());
});

不過你應(yīng)該一眼就能看出來,那種寫法比較好吧,我比較推薦,將依賴寫到shim配置中去。

一切配置就緒,在瀏覽器中打開project.html頁面,運行結(jié)果如圖所示:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JS對象類型之Error錯誤對象的用法詳解

    JS對象類型之Error錯誤對象的用法詳解

    error對象是JavaScript的原生對象,當(dāng)程序解析和運行過程中發(fā)生了錯誤,JS引擎就會自動產(chǎn)生并拋出一個error對象的實例,并且程序會終止在錯誤發(fā)生的地方,本文給大家介紹了JS Error錯誤對象的用法,需要的朋友可以參考下
    2024-04-04
  • 原生javascript實現(xiàn)的ajax異步封裝功能示例

    原生javascript實現(xiàn)的ajax異步封裝功能示例

    這篇文章主要介紹了原生javascript實現(xiàn)的ajax異步封裝功能,結(jié)合完整實例形式分析了原生javascript實現(xiàn)的ajax異步交互函數(shù)與相應(yīng)的使用方法,需要的朋友可以參考下
    2016-11-11
  • js代碼實現(xiàn)輪播圖

    js代碼實現(xiàn)輪播圖

    這篇文章主要為大家詳細(xì)介紹了js代碼實現(xiàn)輪播圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • javascript中json基礎(chǔ)知識詳解

    javascript中json基礎(chǔ)知識詳解

    本文主要介紹了json的基礎(chǔ)知識。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • 微信小程序 高德地圖路線規(guī)劃實現(xiàn)過程詳解

    微信小程序 高德地圖路線規(guī)劃實現(xiàn)過程詳解

    這篇文章主要介紹了微信小程序 路線規(guī)劃實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-08-08
  • 前端無感知刷新token以及超時自動退出實現(xiàn)方案

    前端無感知刷新token以及超時自動退出實現(xiàn)方案

    前端需要做到無感刷新token,即刷token時要做到用戶無感知,避免頻繁登錄,下面這篇文章主要給大家介紹了關(guān)于前端無感知刷新token以及超時自動退出的實現(xiàn)方案,需要的朋友可以參考下
    2024-01-01
  • 前端實現(xiàn)讀取word文件并將其原樣式展示的幾種方案

    前端實現(xiàn)讀取word文件并將其原樣式展示的幾種方案

    在前端直接讀取并原樣展示W(wǎng)ord文檔是一個相對復(fù)雜的任務(wù),因為Word文檔的格式(如.doc或.docx)與Web技術(shù)棧使用的格式(HTML、CSS)不兼容,這篇文章主要給大家介紹了關(guān)于前端實現(xiàn)讀取word文件并將其原樣式展示的幾種方案,需要的朋友可以參考下
    2024-08-08
  • Bootstrap模態(tài)框禁用空白處點擊關(guān)閉

    Bootstrap模態(tài)框禁用空白處點擊關(guān)閉

    這篇文章主要為大家詳細(xì)介紹了Bootstrap模態(tài)框禁用空白處點擊關(guān)閉的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • JS HTML圖片顯示Canvas 壓縮功能

    JS HTML圖片顯示Canvas 壓縮功能

    最新需要js 文件壓縮圖片上傳 以前沒搞過,新手把學(xué)習(xí)過程分享,對JS HTML圖片顯示Canvas 壓縮功能感興趣的朋友一起看看吧
    2017-07-07
  • JavaScript標(biāo)準(zhǔn)對象_動力節(jié)點Java學(xué)院整理

    JavaScript標(biāo)準(zhǔn)對象_動力節(jié)點Java學(xué)院整理

    這篇文章主要為大家詳細(xì)介紹了JavaScript標(biāo)準(zhǔn)對象的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06

最新評論