webpack知识点整理

作用域

es6里模块化的写法
会存在的问题,变量、方法名字雷同,外部文件调用的时候出现问题
如 a.js里
var a='susan'
b.js里
var a='jack'
问题解决方案,添加包裹
a.js
var a={ name:'susan' }
b.js
var a={ name:'jack' }
调用的时候可以使用console.log(a.name);
以上方法可以解决避免冲突,但是问题是其他文件会更改覆盖原数据的问题
如: b.name='aotoname'
再次使用b.name的值的时候,值就变了,多人开发的时候出现不必要的麻烦

怎么解决??

`var susanModule=(function(){
var name='susan',
var sex='女',
return{
tel:function(){
console.log(sex)
}
}

}
})()`

浏览器里susanModule.tel(); 以上方法模块的实现方法

更为标准的写法,直接放在立即执行函数上,模块化也是对作用域的封装,重用性更高,耦合性更低(解除耦合性)
通过接口的方式,把数据暴露出去,供大家使用,其他人也改变不了我的数据
例如网站上的搜索功能,只写一个搜索功能,其他需要的位置,直接调用我的搜索功能就行,前端工作量减少,而且维护成本降低
js的作用域和闭包的升级,演变到模块化方案
经过了AMD ,commonJS,![]

**AMD **

commonJS,

es6 Module
(https://img2020.cnblogs.com/blog/429510/202101/429510-20210119105149247-39884712.png)

webpack

  1. 安装node
    node -v
    npm -v
    命令查看版本
    2.新建文件夹,初始化项目
    npm init

3。运行项目
npm run test


看这里

4.镜像包
npm config set registry https://registry.npm.taobao.org
npm install loadash --sava (-s 报错版本号在package.json里)
npm install --only=prod (指定生成环境)
npm install --only=dev (指定开发环境)
npm -rf node_modules && npm install(把本地的包卸载,然后重装)


(删包重装不一定能解决问题,如果这个包本来就有问题,即使删了重装也不解决问题)

5.版本号

6.webpack打包命令
安装命令 npm install webpack webpack-cli -g
webpack

如果报错,可能是因为少了打包文件
从新执行
npm install webpack-cli -g

package.json
{
"name": "nodemydemo",
"version": "1.0.0",
"description": "",
"main": "src/index.js",
"scripts": {
"test": "echo "Error: no test specified" && exit 1",
"dev":"webpack-dev-server",
"build":"eslint ./src && webpack"
},
"author": "",
"license": "ISC"
}

升级webpack4.0后,打包报如下错误

WARNING in configuration
The 'mode' option has not been set, webpack will fallback to 'production' for this value. Set 'mode' option to 'development' or 'production' to enable defaults forThe 'mode' option has not been set, webpack will fallback to 'production' for this value. Set 'mode' option to 'development' or 'production' to enable defaults for each environment.
You can also set it to 'none' to disable any default behavior. Learn more: https://webpack.js.org/configuration/mode/

原因是没有指定mode 导致的 ,
解决方法:
1.package.json中设置:

”scripts": {
"dev": "webpack --mode development", // 开发环境
"build": "webpack --mode production", // 生产环境
}

打包不对是因为package.json中配置不对

loader 独立于webpack

cssloader,style-loader安装
npm install css-loader --save-dev
npm install style-loader --save-dev

posted @ 2021-01-19 11:22  zhang305  阅读(92)  评论(0编辑  收藏  举报