Vue.js进阶系列(15)--Webpack基本使用和配置文件

  就在昨天,经过小编没日没夜的辛勤付出,终于怂恿到了Webpack成功入驻我们的Vue项目中,有句俗话说的好:“是你的就是你的”。既然Webpack已经入驻我们Vue项目了,那总要干点活才能体现它的人生价值,下面我们一起来看看Webpack是如何工作的吧。


image.png

一、Webpack 基本工作

1.Webpack产生的原因

  大家是否还记得“模块化”一族的故事,他们一族一直想要通过巴结“浏览器”来咸鱼翻身,但是“浏览器”是个什么角色,根本不买他们的帐,只买我Webpack的帐,所以呢,好人做到底,送佛送到西,我的任务也就变成了帮助“模块化”一族和“浏览器”大哥拉近关系。
【在开发过程中,模块化的代码时不能够被浏览器识别的,必须经过webpack的打包才能被浏览器识别】

2.Webpack工作流程

  每次帮“模块化”跟“浏览器”大哥拉近关系之前,我都会叫“模块化”他们将礼物都送到src先生哪里,然后我就从src先生哪里接过礼物,送到“浏览器”大哥的小弟dist中。
①项目结构:在项目开发的时候,一般有会两个文件夹:src和dist。src主要存放开发时写的源代码;dist主要存放要部署到服务器上的文件,当浏览器要解析某些文件时,直接将dist下的文件全部发送到服务器中即可】

image.png

②工作原理:将src下的js文件通过webpack命令发送到dist中,当浏览器要解析某些文件时,直接引用dist下的文件即可。比如:】
  2.1 在src下创建了三个文件:index.html index.js main.js 。index.js中用ES6模块化的思想定义了两个简单的函数add和mul。main.js则是调用index.js中的两个函数:
image.png

image.png

  2.2 通过webpack打包文件:在终端(cmd命令行)先进入到自己项目的目录,输入命令:webpack 入口文件 出口文件。比如webpack ./src/main.js ./dist/bound.js,是将src下的main.js文件打包到dist下的bound.js文件。
image.png

image.png

  2.3 引入dist下的文件: 在index.html中听通过script引入文件 bound.js。我们不能直接在index.html中引用main.js文件,因为一些浏览器是不指出ES6模块化开发的。
image.png

结果.png

  上面呢就是我webpakc最最基本的工作。所谓能力越大责任也越大,所以下面我为你们讲述一下我还有那些高强度的工作。

二、webpack配置文件

1.出入口文件的配置:webpack.config.js

  日子久了之后,我就发现,每次都需要从src哪接过礼物,然后再通过dist传递给“浏览器”大哥,工作效率十分低下,所以我也决定,雇佣 config小弟来帮我跑跑腿。
①config产生的原因:每次我们都需要在终端输入 “webpack 入口文件 出口文件”的命令,才能将入口文件打包后部署到服务器中。所以我们希望直接在终端输入“webpack”就能自动帮我们打包好相应的文件】
其实config小弟的工作也很简单,只需要知道礼物从哪里来又要走什么样的路到哪里去就行啦。
②config工作思路:将入门文件和出口文件放到config中,然后直接在终端输入“webpack”实现自动打包,所以我们需要知道哪个是入口文件,哪个是出口文件以及出口文件的路径】
③ 创建config步骤:1.创建 webpack.config.js文件 2.引入入口文件和出口文件 3. 动态获取webpack.config.js文件的路径 4.执行webpack命令】
3.1 创建 webpack.config.js文件
  文件名一定一定一定是webpack.config.js

image.png

3.2 引入入口文件和出口文件
  通过CommomJS模块化导入文件,entry代表入口文件,值是文件名;output代表出口文件,值必须是对象,对象内部有两个属性 pathfilename,分别代表出口文件的路径和文件名,具体代码如下图所示:

module.exports={
    //入口文件
    entry:"./src/main.js",
    //出口文件
    output:{
        path:"./dist",
        filename:"bundle.js"
    }
}

image.png

  结果告诉我们 ./dist 不是绝对路径。绝对路径嘛,简单吖,直接改成“C:\Users\jer-pc\Desktop\Vue\01-Vue引入\Webpack配置文件”。小编可以很负责的告诉你,这样子更是大错特错。因为不是所有用户的路径都符合你上述的路径。因此我们需要通过node语法来动态获取当前 webpack.config.js的路径
3.3 动态获取webpack.config.js文件的路径
  首先,导入path模块。通过node的语法导入path模块,该模块中存在一个名字叫“path”的包,这个包并不是我们开发人员创建的,是一个依赖node而存在的包,所以我们需要通过npm init 初始化来导入我们所需要的包 [ 在初始化之后就会生成一个json文件,当我们想要单独依赖node环境时,就需要创建这个文件 ]。初始化时,目前只需要填写文件名,最后确认即可。具体看下面的代码图:

//导入 path模块
const path = require('path')

npm init 初始化过程.png

成功创建json文件.png

  然后,填写具体的路径。在path模块中有个叫resolve的函数,它的作用拼接两个文件的地址,第一个参数是node中自带的全局变量__dirname,它的作用是获取当前项目中webpack.config.js的路径;第二个参数是出口文件所放的目录。具体见下面的代码:

//导入path模块
const path = require('path')
//填写路径
module.exports={
    entry:"./src/main.js",
    output:{
        path:path.resolve(__dirname,'./dist'),
        filename:"bundle.js"
    }
}

3.4 执行webpack命令
  在终端输入“webpack”命令,就可以实现自动化打包相应的文件,具体见下图:

终端输入webpack命令.png

console控制台打印的结果.png

2.局部安装webpack

①为什么要局部安装?
  webpack版本很多,并不是所有的项目都适合用一个版本的webpack,所以为了适应项目的需求,一般都会采用局部的webpack【局部的webpack也叫本地webpack】,和人要穿适合自己尺码的衣服一个道理。
②如何使用局部webpack
  打开package.json文件,找到script所在的位置,然后用变量来存放webpack,最后再终端通过输入“npm run 变量名”执行。

image.png

image.png

  以上就是今天小编要带给大家的webpack基本使用和webpack配置文件,配置文件主要通过config配置了出入口文件和局部安装webpack。内容似乎有点杂乱,还请大家多多包容小编的文笔O(∩_∩)O哈哈

❤记得给小编点赞唷❤

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,542评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,596评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,021评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,682评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,792评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,985评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,107评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,845评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,299评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,612评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,747评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,441评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,072评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,828评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,069评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,545评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,658评论 2 350

推荐阅读更多精彩内容