亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Webpack中loader打包各種文件的方法實例

2019-11-19 10:54:27
字體:
來源:轉載
供稿:網友

前言

使用webpack時,在main.js文件中直接使用如下代碼導入了style.css文件,控制臺中顯示如下錯誤:You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file.

import './css/style.css';

原因是,webpack中默認只能打包.js類型文件,無法打包其他類型文件。如果要打包非.js類型文件,需要手動安裝一些第三方loader加載器。

以下為各種文件類型打包實例:

處理css文件

方式一

在項目中用npm命令本地安裝style-loader和css-loader兩個包

npm install style-loader css-loader --save--dev 

在引用style.css文件時,將import './css/style.css';代碼改為以下代碼:

import 'style-loader!css-loader!./style.css'")'; //先經過css-loader和style-loader處理

重新用webpack打包

npm run dev 

這種方式的缺點是,當需要引入多個css文件,每次引入時都需要加style-loader!css-loader!,比較麻煩,因此推薦使用以下方式:

方式二

在項目中用npm命令本地安裝style-loader和css-loader兩個包

npm install style-loader css-loader --save--dev 

打開webpack.config.js文件,在里面新增一個配置節點module,在module對象中,有一個rules屬性,它是一個數組,里面存放了所有第三方文件匹配和處理規則。如下代碼匹配處理css文件:

module: { // 配置所有第三方loader 模塊 rules: [ // 第三方模塊的匹配規則  { test: //.css$/, use: ['style-loader', 'css-loader'] }, // 處理 CSS 文件的 loader ] }

注意:此處'style-loader'和'css-loader'順序不可替換。因為use中處理順序為從后往前。先用css-loader對css文件進行處理,將處理后的結果交給style-loader作進一步處理,處理為webpack可以進行打包的數據。

引入style.css文件

import './css/style.css';

重新用webpack打包

npm run dev 

以下所有其他類型文件的打包同方式二

處理less文件

在項目中用npm命令本地安裝style-loader和css-loader和less-loader和less三個包(若已有style-loader和css-loader則不必再安裝這兩個)

npm install style-loader css-loader less-loader less --save--dev 

打開webpack.config.js文件,在節點module中rules屬性數組中,新增如下less的規則:

{ test: //.less$/, use: ['style-loader', 'css-loader', 'less-loader'] } // 處理 less 文件的 loader

引入style.less文件

import './css/style.less';

重新用webpack打包

npm run dev 

處理scss文件

在項目中用npm命令本地安裝style-loader和css-loader和sass-loader和node-sass四個包(若已有style-loader和css-loader則不必再安裝這兩個)

npm install style-loader css-loader sass-loader node-sass --save--dev 

打開webpack.config.js文件,在節點module中rules屬性數組中,新增如下scss的規則:

{ test: //.scss$/, use: ['style-loader', 'css-loader', 'sass-loader'] } // 處理 less 文件的 loader

引入style.scss文件

import './css/style.lcss';

重新用webpack打包

npm run dev 

處理url地址

例如,在css樣式中使用background-image:url('...'),webpack默認無法處理url,因此也需要手動安裝第三方loader

在項目中用npm命令本地安裝url-loader和file-loader兩個包

npm install url-loader file-loader --save--dev 

打開webpack.config.js文件,在節點module中rules屬性數組中,新增如下的規則:

{ test: //.(jpg|png|gif|bmp|jpeg)$/, use: 'url-loader' }, // 處理 圖片路徑的 loader{ test: //.(ttf|eot|svg|woff|woff2)$/, use: 'url-loader' }, // 處理 字體文件的 loader 

重新用webpack打包

npm run dev 

處理ES6高級語法

webpack默認只能處理一部分的ES6語法,對于一些更高級的ES6語法,webpack無法處理,如下代碼用webpack打包會報錯。

class Person {	static info = {name:'zlx',age:18}};console.log(Person.info);

webpack需要借助于第三方的 loader,這里使用Babel,將高級的ES6語法轉為低級的語法之后,再將結果進行打包。

用npm命令安裝如下包:

npm i babel-core babel-loader babel-plugin-transform-runtime -Dnpm i babel-preset-env babel-preset-stage-0 -D

打開webpack.config.js文件,在節點module中rules屬性數組中,新增如下的規則:

{ test: //.js$/, use: 'babel-loader', exclude: /node_modules/ }, // exclude是防止node_modules中的js文件被打包

在項目的 根目錄中,新建一個 叫做 .babelrc  的Babel 配置文件,這個配置文件,屬于JSON格式。里面寫入如下代碼:

{ "presets": ["env", "stage-0"], "plugins": ["transform-runtime"]}

重新用webpack打包

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
自拍偷拍亚洲欧美| 日韩在线观看av| 中文字幕久热精品在线视频| 国产美女搞久久| 日本国产欧美一区二区三区| 日韩一区二区在线视频| 久久精品国产亚洲精品2020| 97在线视频一区| 日本久久久久久久久| 久久精品91久久久久久再现| 欧美最猛性xxxx| 国产999在线观看| 日韩在线资源网| 亚洲精品国产品国语在线| 久久精品国产2020观看福利| 欧美一性一乱一交一视频| 精品国产拍在线观看| 亚洲天堂开心观看| 久热在线中文字幕色999舞| 亚洲乱码一区av黑人高潮| 日韩av网站大全| 在线看日韩av| 琪琪亚洲精品午夜在线| 欧美丝袜美女中出在线| 亚洲高清一二三区| 亚洲女成人图区| 欧美电影免费看| 国产日韩在线视频| 日韩精品中文字幕在线观看| 亚洲色图25p| 91在线视频精品| 久久久精品欧美| 亚洲va久久久噜噜噜久久天堂| 久久这里只有精品99| 亚洲第一色在线| 97在线视频免费播放| 91国内精品久久| 狠狠久久五月精品中文字幕| 亚洲欧美三级伦理| 日韩av中文字幕在线免费观看| 久久精品国产成人精品| 欧美精品国产精品日韩精品| 在线观看日韩av| 欧美综合在线观看| 国产精品久久久久av免费| 性色av一区二区咪爱| 欧美猛男性生活免费| 色婷婷av一区二区三区久久| 亚洲美女av黄| 久久精品人人爽| 国产91免费看片| 国产欧美久久久久久| 国产亚洲免费的视频看| 人体精品一二三区| 在线亚洲国产精品网| 欧洲永久精品大片ww免费漫画| 国内精品久久久久影院 日本资源| 两个人的视频www国产精品| 久久免费少妇高潮久久精品99| 亚洲一区二区久久久久久| 日韩高清电影免费观看完整版| 欧美亚洲国产精品| 欧美性猛交xxxx免费看漫画| 欧美一级成年大片在线观看| 欧洲永久精品大片ww免费漫画| 日韩一区二区三区国产| 国产精品久久久久久久久久东京| 最近中文字幕mv在线一区二区三区四区| 91夜夜揉人人捏人人添红杏| 久久久久久久久久国产精品| 国产精品一区二区久久久| 在线丨暗呦小u女国产精品| 亚洲精品国精品久久99热一| 日日狠狠久久偷偷四色综合免费| 久久成人18免费网站| 欧美亚洲一区在线| 国产精品爽爽爽爽爽爽在线观看| 国产成人97精品免费看片| 中文字幕亚洲欧美一区二区三区| 久久久久久噜噜噜久久久精品| 最近中文字幕mv在线一区二区三区四区| 亚洲理论片在线观看| 亚洲天堂男人天堂| 亚洲成色www8888| 欧美日韩亚洲网| 精品动漫一区二区三区| 国产精品第10页| 这里只有精品在线观看| 欧美精品中文字幕一区| 日韩av大片免费看| 国产亚洲精品美女久久久久| 久久影院资源网| 亚洲天堂网在线观看| 精品久久久久久久久久国产| 国产激情久久久久| 亚洲国产又黄又爽女人高潮的| 亚洲国产美女久久久久| 亚洲天堂av在线免费观看| 国外成人免费在线播放| 亚洲成av人影院在线观看| 久久精品国产亚洲一区二区| 亚洲天堂影视av| 日韩欧美亚洲一二三区| 国产精品v日韩精品| 国产精品r级在线| 北条麻妃99精品青青久久| 精品亚洲aⅴ在线观看| 久久成人一区二区| 亚洲男人的天堂在线播放| 亚洲最大福利视频网站| 国产精品一区二区电影| 欧美另类老女人| 欧美日韩电影在线观看| 韩国三级电影久久久久久| 国产亚洲精品久久久久久牛牛| 欧美视频在线观看免费| 欧美激情一区二区三区高清视频| 欧美乱大交xxxxx另类电影| 欧美一级电影免费在线观看| 亚洲999一在线观看www| 国产精品久久久久福利| 亚洲欧美日本另类| 欧美自拍视频在线观看| 亚洲图片欧洲图片av| 成人写真视频福利网| 亚洲人在线观看| 在线观看国产欧美| 亚洲欧洲一区二区三区久久| 在线观看国产成人av片| 一区二区三区无码高清视频| 日韩av一区二区在线观看| 亚洲国产黄色片| 亚洲精品不卡在线| 91久久夜色精品国产网站| 欧美电影在线免费观看网站| 亚洲综合国产精品| 日韩精品中文字幕在线播放| 亚洲激情小视频| 亚洲一区二区久久久久久久| 大桥未久av一区二区三区| 成人国内精品久久久久一区| 久久精品亚洲精品| 亚洲国内精品在线| 成人做爰www免费看视频网站| 亚洲免费高清视频| 久久激情视频久久| 中文字幕无线精品亚洲乱码一区| 亚洲一区二区久久久| 日韩精品视频在线观看网址| 精品国产一区二区三区久久| 亚洲国产日韩一区| 精品女厕一区二区三区| 欧美俄罗斯乱妇| 日本视频久久久| 亚洲精品成人久久久| 国产精品三级在线| 成人淫片在线看| 在线观看国产欧美| 97精品久久久| 亚洲欧美国产日韩中文字幕| 欧美精品福利在线| 国产精品一区二区久久国产| 欧美人与性动交a欧美精品| 欧美最猛黑人xxxx黑人猛叫黄|