成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

webpack學(xué)習(xí)(二)—— 進(jìn)階

singerye / 2959人閱讀

摘要:上篇文章中簡(jiǎn)單介紹了的最基本用法,且項(xiàng)目結(jié)構(gòu)十分簡(jiǎn)單,只有一個(gè)頁面一個(gè)頁面兩個(gè)文件。本文將介紹如何使用對(duì)具有較為規(guī)范的結(jié)構(gòu)的項(xiàng)目進(jìn)行構(gòu)建。這說明監(jiān)測(cè)到了文件的變化,但是我們的加載的文件并沒有變。后續(xù)還會(huì)更深入地學(xué)習(xí),希望和大家一同進(jìn)步。

上篇文章中簡(jiǎn)單介紹了webpack的最基本用法,且項(xiàng)目結(jié)構(gòu)十分簡(jiǎn)單,只有一個(gè)html頁面、一個(gè)css頁面、兩個(gè)js文件。本文將介紹如何使用webpack對(duì)具有較為規(guī)范的結(jié)構(gòu)的項(xiàng)目進(jìn)行構(gòu)建。主要包括以下幾個(gè)方面:

進(jìn)一步了解webpack.config.js

進(jìn)一步了解webpack-dev-server

使webpack支持es6語法

關(guān)于webpack.config.js

我們以最常用最簡(jiǎn)單的項(xiàng)目結(jié)構(gòu)來演示,如下:

myPro
    - css
    - src
    - node-modules
    - dist
    - index.html
    - webpack.config.js
    

這樣我們的項(xiàng)目結(jié)構(gòu)就很清晰了。css文件夾中存放樣式文件,src文件夾中存放js文件,node-modules中是我們用到的各種包,dist文件存放打包生成的文件?,F(xiàn)在我希望做到以下兩點(diǎn)

css使用less編寫

打包文件到dist目錄下

第一步,在css文件夾中創(chuàng)建以下兩個(gè)文件
index.less

@import "demo.less";

demo.less

body {
    background: yellow;

    .main {
        width: 200px;
        height: 200px;
        border: 10px solid red;
    }
}

第二步,在src文件夾中創(chuàng)建文件
content.js

module.exports = "it works from content.js";

entry.js

require("../css/index.less");
let content = require("./content.js");
alert(content);

第三部,修改index.html如下:



    
        
        webpack demo
    
    
        

webpack demo

至此,我們看到 1、樣式文件使用了less編寫;2、在index.html頁面中js文件路徑為./dist/bundle.js。

配置less-loader

對(duì)于1(樣式文件采用less編寫),我們需要使用加載器來處理。首先,需要安裝less-loader,而less-loader依賴于less,因此需要這樣安裝

$ npm install less-loader less

然后再config文件中配置對(duì)less文件的處理,如下:

module: {
    loaders: [
        {
            test: /.css$/, 
            loader: "style!css"
        },
        {
            test: /.less$/,
            loader: "style!css!less"
        }
    ]
}

這里加入了對(duì)less文件的處理,需要注意loader的順序,為style!css!less,意為先使用less加載器處理,解析為普通的css文件,再處理css文件,最后處理樣式,類似于pipe的概念。

設(shè)置output

在上篇文章中,我們提到了webpack.config.js文件中可以設(shè)置output,作為打包的出口參數(shù)。如下:

output: {
    path: __dirname,
    filename: "bundle.js"
}

這里設(shè)置了兩項(xiàng):pathfilename
其中,path為打包的目錄,__dirname指當(dāng)前目錄,filename指文件名。
這里我們希望將文件打包到dist目錄下,則可以通過配置path來實(shí)現(xiàn),完整配置如下:

let path = require("path");

module.exports = {
    entry: "./src/entry.js",
    output: {
        path: path.join( __dirname, "/dist"), //這里配置打包路徑
        filename: "bundle.js"
    },
    module: {
        loaders: [
            {
                test: /.css$/, 
                loader: "style!css"
            },
            {
                test: /.less$/,
                loader: "style!css!less"
            }
        ]
    }
};

至此,我們完成了兩步,1、對(duì)less文件正確處理; 2、將文件打包到dist目錄下。
打包:

$ webpack

用瀏覽器打開index.html頁面,可以看到:

進(jìn)一步了解webpack-dev-server

上篇文章提到,webpack-dev-server為我們提供了一個(gè)小型的基于node的express服務(wù)器,使我們可以通過http://localhost:8080/webpack-dev-server/來訪問頁面,并且它可以監(jiān)測(cè)文件的變化并在頁面中實(shí)時(shí)顯示出來。現(xiàn)在我們?cè)賮碓囅拢?br>啟動(dòng)webpack-dev-server

$ webpack-dev-server

訪問http://localhost:8080/webpack-dev-server/
修改content.js文件如下:

module.exports = "it is another content from content.js";

可以看到,頁面自動(dòng)進(jìn)行了刷新,但是alert的內(nèi)容卻沒有變。這說明監(jiān)測(cè)到了文件的變化,但是我們的index.html加載的js文件并沒有變。
那問題出在哪里?

webpack-dev-server原理

webpack-dev-server通過sockjs實(shí)現(xiàn)實(shí)時(shí)變化監(jiān)測(cè),當(dāng)文件變化時(shí),服務(wù)器就會(huì)向客戶端發(fā)送通知,客戶端重新渲染。
每次文件變化都會(huì)觸發(fā)webpack-dev-server對(duì)文件進(jìn)行重新編譯,但是這個(gè)編譯后的文件并不會(huì)每次都保存到我們的dist目錄下,而是存放在內(nèi)存中,默認(rèn)情況下,這個(gè)文件的路徑為當(dāng)前路徑。也就是說,每次文件變化后,內(nèi)存中的bundle.js做出了實(shí)時(shí)的變化,而output中配置的文件其實(shí)并沒有變。也就是說,如果我們?cè)?b>index.html中使用./bundle.js則能夠?qū)崿F(xiàn)頁面內(nèi)容的實(shí)時(shí)更新。
那么,如何配置可以使其支持我們當(dāng)前的寫法./dist/bunlde.js呢?就需要用到publicPath這個(gè)屬性。

outputpublicPath屬性

webpack-dev-server默認(rèn)支持文件路徑為當(dāng)前的路徑,可以通過在output中配置publicPath屬性對(duì)其進(jìn)行更改,如下:

output: {
    path: path.join( __dirname, "/dist"),
    publicPath: "/dist/",
    filename: "bundle.js"
}

這樣設(shè)置我們就可以通過./dist/bundle.js路徑訪問到內(nèi)存中的文件,在當(dāng)前路徑下已經(jīng)存在同名文件的情況下,webpack-dev-server會(huì)優(yōu)先使用內(nèi)存中的文件。

至此,我們已經(jīng)實(shí)現(xiàn)了:

使用less編寫樣式文件

將文件打包到指定目錄

監(jiān)測(cè)文件變化并實(shí)時(shí)展示

看到,現(xiàn)在我們還是采用的commonJS的規(guī)范來實(shí)現(xiàn)模塊化,而es6為我們提供了exportimport語法來支持模塊化,如果想要在項(xiàng)目中使用es6,同樣可以通過webpack來配置實(shí)現(xiàn)。

webpack支持es6

使webpack支持es6需要用到babel,它可以幫助我們將es6語法轉(zhuǎn)化為es5的格式,可以在這里測(cè)試。
首先,需要安裝babel

$ npm install babel-loader babel-core

安裝babel-preset

$ npm install babel-preset-es2015

然后,配置webpack.config.js,如下:

module: {
  loaders: [
    { test: /.js$/, exclude: /node_modules/, loader: "babel-loader" }
  ]
}

最后還需要加上babel的配置文件,在項(xiàng)目的根目錄下創(chuàng)建文件.babelrc

{ "presets": ["es2015"] }

這樣,我們的webpack就支持通過es6exportimport實(shí)現(xiàn)模塊化了。
修改content.js內(nèi)容如下:

var content = "it is the origin content from content.js";

export {content};

修改entry.js內(nèi)容如下:

require("../css/index.less");

import {content} from "./content";

let div = document.getElementById("main");
div.innerHTML = content;

可以看到,我們現(xiàn)在通過es6importexport實(shí)現(xiàn)js的模塊化,打包:

$ webpack


打包成功。

結(jié)語

本文介紹了如何使用webpack對(duì)一個(gè)較為系統(tǒng)的項(xiàng)目進(jìn)行打包,并支持less,es6,同時(shí)對(duì)webpack-dev-server的原理進(jìn)行了簡(jiǎn)要說明。后續(xù)還會(huì)更深入地學(xué)習(xí)webpack,希望和大家一同進(jìn)步。

(本文完)

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/88000.html

相關(guān)文章

  • 前端資源系列(4)-前端學(xué)習(xí)資源分享&前端面試資源匯總

    摘要:特意對(duì)前端學(xué)習(xí)資源做一個(gè)匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進(jìn)步。 特意對(duì)前端學(xué)習(xí)資源做一個(gè)匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進(jìn)步。 本以為自己收藏的站點(diǎn)多,可以很快搞定,沒想到一入?yún)R總深似海。還有很多不足&遺漏的地方,歡迎補(bǔ)充。有錯(cuò)誤的地方,還請(qǐng)斧正... 托管: welcome to git,歡迎交流,感謝star 有好友反應(yīng)和斧正,會(huì)及時(shí)更新,平時(shí)業(yè)務(wù)工作時(shí)也會(huì)不定期更...

    princekin 評(píng)論0 收藏0
  • Webpack Loader 高手進(jìn)階(三)

    摘要:相關(guān)的內(nèi)容為這樣對(duì)于一個(gè)處理的第二階段也就結(jié)束了,通過去攔截不同類型的,并返回新的,跳過后面的的執(zhí)行,同時(shí)在內(nèi)部會(huì)剔除掉,這樣在進(jìn)入到下一個(gè)處理階段的時(shí)候,不在使用的范圍之內(nèi),因此下一階段便不會(huì)經(jīng)由來處理。 文章首發(fā)于個(gè)人github blog: Biu-blog,歡迎大家關(guān)注~ Webpack 系列文章: Webpack Loader 高手進(jìn)階(一)Webpack Loader 高手...

    ivydom 評(píng)論0 收藏0
  • 關(guān)于Vue2一些值得推薦的文章 -- 五、六月份

    摘要:五六月份推薦集合查看最新的請(qǐng)點(diǎn)擊集前端最近很火的框架資源定時(shí)更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語。葉上初陽乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門,久作長(zhǎng)安旅。五月漁郎相憶否。小楫輕舟,夢(mèng)入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請(qǐng)::點(diǎn)擊::集web前端最近很火的vue2框架資源;定時(shí)更新,歡迎 Star 一下。 蘇...

    sutaking 評(píng)論0 收藏0
  • 關(guān)于Vue2一些值得推薦的文章 -- 五、六月份

    摘要:五六月份推薦集合查看最新的請(qǐng)點(diǎn)擊集前端最近很火的框架資源定時(shí)更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語。葉上初陽乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門,久作長(zhǎng)安旅。五月漁郎相憶否。小楫輕舟,夢(mèng)入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請(qǐng)::點(diǎn)擊::集web前端最近很火的vue2框架資源;定時(shí)更新,歡迎 Star 一下。 蘇...

    khs1994 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<