webpack項(xiàng)目初始化

開(kāi)發(fā)模式

1、(命令行)安裝

mkdir webpack-demo && cd webpack-demo
npm init -y
npm install webpack webpack-cli --save-dev

最好猛们,使用yarn 安裝(推薦)

mkdir webpack-demo && cd webpack-demo
yarn init -y
yarn add webpack webpack-cli -D

2、配置index文件
(1)yarn add lodash, (命令行)導(dǎo)入lodash。
(2)創(chuàng)建 index.html 和 ./src/index.js
index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>vue項(xiàng)目初始化</title>
</head>
<body>
<script src="app.bundle.js"></script>
</body>
</html>

index.js

import _ from 'lodash';

function component() {
    var element = document.createElement('div');

    // Lodash(目前通過(guò)一個(gè) script 腳本引入)對(duì)于執(zhí)行這一行是必需的
    element.innerHTML = _.join(['Hello', 'webpack'], ' ');

    return element;
}

document.body.appendChild(component());

3琳骡、 配置已經(jīng)生成的package.json文件
// 注意:下面兩個(gè)( dependencies,devDependencies)是yarn add安裝的插件自動(dòng)生成的,當(dāng)然讼溺,也能手動(dòng)導(dǎo)入楣号,執(zhí)行yarn install 安裝
// 注意:下面兩個(gè)是yarn add安裝的插件自動(dòng)生成的,當(dāng)然怒坯,也能手動(dòng)導(dǎo)入炫狱,執(zhí)行yarn install 安裝

{
  "name": "vue-cus",
  "version": "1.0.0",
  "description": "",
  "main": "main.js",
  "author": "pzz",
  "license": "MIT",
  "scripts": {
  "start": "webpack-dev-server --config build/webpack.config.js",
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [],
  "dependencies": {},
  "devDependencies": {
    "@types/lodash": "^4.14.144",
    "lodash": "^4.17.15",
    "webpack": "^4.41.2",
    "webpack-cli": "^3.3.9"
  }
}

4、創(chuàng)建build文件夾剔猿,./build/webpack.config.js 文件

const path = require('path');

module.exports = {
    entry: {
        app:'./src/index.js',
    },
    output: {
        filename: '[name].bundle.js',
        path: path.resolve(__dirname, 'dist')
    }
};

5视译、導(dǎo)入插件 webpack-dev-server

yarn add webpack-dev-server -D

6、運(yùn)行

yarn run start

生產(chǎn)模式

1归敬、將webpack.config.js酷含,build文件夾重新劃分成三個(gè)文件

build
 |- webpack.common.js
 |- webpack.dev.js
 |- webpack.prod.js

2鄙早、(命令行)安裝

yarn add webpack-merge -D

3、修改build內(nèi)的三個(gè)配置文件
webpack.common.js

const path = require('path');

module.exports = {
    entry: {
        app:'./src/index.js',
    },
    output: {
        filename: '[name].bundle.js',
        path: path.resolve(__dirname, 'dist')
    }
};

webpack.dev.js

const merge = require('webpack-merge');
const common = require('./webpack.common.js');

module.exports = merge(common, {
    mode:'development',
    // devtool: 'inline-source-map',
    devServer: {
        contentBase: './dist'
    }
});

webpack.prod.js

const merge = require('webpack-merge');
// const UglifyJSPlugin = require('uglifyjs-webpack-plugin');
const common = require('./webpack.common.js');

module.exports = merge(common, {
    mode:'production',
    plugins: [
        // new UglifyJSPlugin()
    ]
});

4第美、修改package.json文件內(nèi)的scripts

 "scripts": {
    "start": "webpack-dev-server --config build/webpack.common.js",
    "build": "webpack --config build/webpack.prod.js",
    "test": "echo \"Error: no test specified\" && exit 1"
  },

5蝶锋、生成bundle包

yarn run build

注意:如果生產(chǎn)環(huán)境,生成build包什往,最好在打生產(chǎn)包前扳缕,清理dist文件夾下的內(nèi)容,可以使用第三方插件 clean-webpack-plugin

參考:

更加詳細(xì)别威,理解初識(shí)化配置:
webpack指南

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末躯舔,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子省古,更是在濱河造成了極大的恐慌粥庄,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件豺妓,死亡現(xiàn)場(chǎng)離奇詭異惜互,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)琳拭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)训堆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人白嘁,你說(shuō)我怎么就攤上這事坑鱼。” “怎么了絮缅?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵鲁沥,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我耕魄,道長(zhǎng)画恰,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任吸奴,我火速辦了婚禮阐枣,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘奄抽。我一直安慰自己蔼两,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布逞度。 她就那樣靜靜地躺著额划,像睡著了一般。 火紅的嫁衣襯著肌膚如雪档泽。 梳的紋絲不亂的頭發(fā)上俊戳,一...
    開(kāi)封第一講書(shū)人閱讀 51,521評(píng)論 1 304
  • 那天揖赴,我揣著相機(jī)與錄音,去河邊找鬼抑胎。 笑死燥滑,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的阿逃。 我是一名探鬼主播铭拧,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼恃锉!你這毒婦竟也來(lái)了搀菩?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤破托,失蹤者是張志新(化名)和其女友劉穎肪跋,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體土砂,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡州既,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了萝映。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吴叶。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖锌俱,靈堂內(nèi)的尸體忽然破棺而出晤郑,到底是詐尸還是另有隱情敌呈,我是刑警寧澤贸宏,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站磕洪,受9級(jí)特大地震影響吭练,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜析显,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一鲫咽、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧谷异,春花似錦分尸、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至尺上,卻和暖如春材蛛,著一層夾襖步出監(jiān)牢的瞬間圆到,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工卑吭, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留芽淡,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓豆赏,卻偏偏與公主長(zhǎng)得像挣菲,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子河绽,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355