webpack配置之webpack.config.js文件配置

webpack.config.js webpack resolve 

1.总是手动的输入webpack的输入输出文件路径,是一件非常繁琐的事情。我们尝试用文件的形式将输入输出文件夹配置好。新建一个js文件,并命名为webpack.config.js【目前只能命名为这个,不然程序不识别】


webpack.config.js

2.在webpack.config.js文件内输入以下代码

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

3.由于已经配置好输入输出文件夹,可以直接输入webpack运行指令,但是程序报错。


输入webpac程序报错

nvalid configuration object. Webpack has been initialised using a configuration object that does not match the API schema.

The output directory as absolute path (required)"./dist" is not an absolute path!

The output directory as absolute path (required) #f00

4.这是因为上述文件的output对象的path属性必须是绝对路径,此时我们要引入路径依赖包path。该包有个方法path.resolve(__dirname,'dist')可以将相对路径转成绝对路径。其中__dirname指的是当前文件【webpack.config.js】的上一级路径.

 如webpack.config.js的路径为D:/aaa/bbb/webpack.config.js,
则__dirname为D:/aaa/bbb/,
path.resolve(__dirname,'dist')就是D:/aaa/bbb/dist.

5.引入path包,【该包有个方法path.resolve(__dirname,'dist')可以将相对路径转成绝对路径】并修改output对象的path属性。

const path = require('path'); //1.引入path包
module.exports = {
entry: './src/main.js',
output: {
path: path.resolve(__dirname, 'dist'),//2.修改output对象的path属性
filename: 'bundle.js'
}
}

引入path包,并修改output对象的path属性

6.运行webpack指令,在dist文件夹下获得打包好的包。


运行webpack指令

7.由于我们使用的是npm指令对js项目进行管理,直接使用webpack指令会造成混乱,后期webpack指令过于繁琐或者配置更改后,webpack指令会容易出现错误,所以将通用的指令映射到/写到package.json文件内,是一个明智的选择。找到package.json文件,在其script属性下添加指令键值对,即key:value..由于webpack是打包指令,这里我们设定其key为build,value为webpack.


在其script属性下添加指令

8.运行指令npm run build,输出如下图所示。


运行指令npm run build

9.然后在index.html内用script标签引入,打开浏览器即可.


用script标签引
//test.js
function add(num1, num2) {
return num1 + num2
} function mul(num1, num2) {
return num1 * num2
} module.exports = {
add,
mul
}
//main.js
const { add, mul } = require("./test.js"); console.log(add(20, 30));
console.log(mul(20, 30));

打开浏览器控制台

注意:之前直接在终端或者控制台使用webpack指令,使用的是全局安装的webpack包。不同项目使用的webpack的版本不一致,强行使用全局webpack会导致打包错误.在package.json的script添加webpack指令属于使用本地webpack

让我们再次回顾一下整个打包流程。

当我们在控制台/终端,直接输入webpack命令执行的时候,webpack做了以下几步:

1.首先,webpack发现,我们并没有通过命令的形式,给它指定入口和出口


运行webpack指令,没有指定出入口

2.webpack就会去项目的根目录中,查找一个叫做‘webpack.config.js的配置文件


查找一个叫做‘webpack.config.js

3.当找到配置文件后,webpack会去解析执行这个配置文件,当解析执行完配置文件后,就得到了含有出入口路径的配置对象


获取entry和output属性

4.当webpack拿到配置对象后,就拿到了配置对象中,指定的入口和出口,然后进行打包构建;


文件配置相当于在命令行直接输入webpack 入口url 出口url

webpack配置之webpack.config.js文件配置的更多相关文章

  1. vue-cli3的vue.config.js文件配置,生成dist文件

    //vue.config.jsonconst path = require('path'); // const vConsolePlugin = require('vconsole-webpack-p ...

  2. webpack.config.js文件的高级配置

    一.多个入口文件之前我们配置的都是 一个入口 var webpack = require('webpack'); var commonsPlugin = new webpack.optimize.Co ...

  3. webpack配置:less/sass文件打包和分离、自动处理css前缀、消除未使用的css及完整的webpack.config.js文件

    一.less文件打包和分离 1.要使用less,首先使用npm安装less服务:还需要安装Less-loader用来打包使用. npm install less --save-dev npm inst ...

  4. [转]webpack4.0.1安装问题和webpack.config.js的配置变化

    本文转自:https://blog.csdn.net/jiang7701037/article/details/79403637 The CLI moved into a separate packa ...

  5. 手把手教你webpack、react和node.js环境配置(上篇)

    很多人刚学习react的时候,往往因为繁琐的配置而头疼,这里我将手把手教大家怎么用webpack配置react和redux的环境,这篇教程包括前端react和后台node整个网站的环境配置,对node ...

  6. webpack 4.0 配置文件 webpack.config.js文件的放置位置

    一般webpack.config.js是默认放在根目录的,不在根目录的时候需要在package.json中制定位置,我的配置文件目录是config/webpack.config.js,在package ...

  7. 手把手教你webpack、react和node.js环境配置(下篇)

    上篇我介绍了前端下webpack和react.redux等环境的配置,这篇将继续重点介绍后台node.js的配置. 这里是上篇链接:手把手教你webpack.react和node.js环境配置(上篇) ...

  8. webpack教程(二)——webpack.config.js文件

    首先我们需要安装一个webpack插件html-webpack-plugin,该插件的作用是帮助我们生成创建html入口文件.执行如下命令 npm install html-webpack-plugi ...

  9. wepy build 错误 [Error] 未发现相关 less 编译器配置,请检查wepy.config.js文件。

    [Error] 未发现相关 less 编译器配置,请检查wepy.config.js文件. 缺少less包,npm install less -d

随机推荐

  1. Vue组件通信方式(8种)

    1.一图认清组件关系名词 父子关系:A与B.A与C.B与D.C与E 兄弟关系:B与C 隔代关系:A与D.A与E 非直系亲属:D与E 总结为三大类: 父子组件之间通信 兄弟组件之间通信 跨级通信 2.8 ...

  2. 使用 dataset 管理数据(官网)

    ECharts 4 开始支持了 dataset 组件用于单独的数据集声明,从而数据可以单独管理,被多个组件复用,并且可以基于数据指定数据到视觉的映射.这在不少场景下能带来使用上的方便. ECharts ...

  3. unittest assert断言

    unittest常用的断言方法 1.assertEqual(self, first, second, msg=None) --判断两个参数相等:first == second 2.assertNotE ...

  4. MySQL8连接数据库

    spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://127. ...

  5. host - 使用域名服务器查询主机名字

    SYNOPSIS (总览) host [-l ] [-v ] [-w ] [-r ] [-d ] [-t querytype ] [-a ] host [server ] DESCRIPTION (描 ...

  6. centos7搭建安装superset

    superset官网: https://superset.incubator.apache.org/ 系统环境:system:centos7 一.安装工具及依赖包安装工具包:yum -y instal ...

  7. cacti监控

    cacti监控 cacti简介 Cacti是一套基于php,mysql,snmp及rrdtool开发的网络流量监测图形分析工具.它通过snmpget获取数据,使用rrdtool绘画图形 Cacti轮询 ...

  8. HDU - 1024 Max Sum Plus Plus 最大m段子段和+滚动数组优化

    给定n个数字,求其中m段的最大值(段与段之间不用连续,但是一段中要连续) 例如:2 5 1 -2 2 3 -1五个数字中选2个,选择1和2 3这两段. dp[i][j]从前j个数字中选择i段,然后根据 ...

  9. JSTL标签(转载)

    JSTL标签是一个实现web功能的定制标签库,包括输出功能,条件判断,循环等,使用JSTL标签,为动态编写WEB应用程序提供了很大的方便性,能很好的和Java语言和HTML进行结合.下面我们看看jst ...

  10. 【转】js监听浏览器离开页面操作

    [转]https://www.cnblogs.com/slly/p/7991474.html 序言 大家是否经常遇到在关闭网页的时候,会看到一个确定是否离开当前页面的提示框?想一些在线测试系统.信息录 ...