美文网首页
Webpack初步了解(打包,webpack-server)

Webpack初步了解(打包,webpack-server)

作者: 废柴阿W | 来源:发表于2018-11-12 11:43 被阅读0次

    什么是webpack?

    webpack 是前端的一个项目构建工具,它是基于 Node.js 开发出来的一个前端工具;

    1. 使用Gulp, 是基于 task 任务的,适合构建小型项目
    2. 使用Webpack, 是基于整个项目进行构建的;
    • 借助于webpack这个前端自动化构建工具,可以完美实现资源的合并、打包、压缩、混淆等诸多功能。
    • 根据官网的图片介绍webpack打包的过程
    • webpack官网

    webpack安装的两种方式

    1. 运行npm i webpack -g全局安装webpack,这样就能在全局使用webpack的命令
    2. 在项目根目录中运行npm i webpack --save-dev安装到项目依赖中(webpack最新版为4,教程为3)(--save-dev参数缩写为 -D)npm i webpack -D【推荐】
    3. webpack-安装踩坑

    webpack的核心概念

    • Entry

      • 代码的入口
      • 打包的入口
      • 单个或多个
    • Output

      • 打包成的文件(bundle)
      • 一个或多个
      • 自定义规则
      • 配合CDN
    • Loaders

      • 处理文件
      • 转化为模块
    • Plugins

      • 参与打包整个过程
      • 打包优化和压缩
      • 配置编译时的变量
      • 极其灵活

    Entry

    Output

    Loaders

    Plugins

    webpack的基本使用

    打包文件

    1. 建立了目录结构后,使用npm安装jQuery:npm init -y 然后npm i jquery -S
    2. .写main.js后, 输入命令编译js,webpack .\src\main.js -o .\dist\bundle.js

    一些bug

    解决:Error: Cannot find module 'webpack'
    运行webpack报错:Cannot read property 'presetToOptions' of undefined
    Webpack 3.X - 4.X 升级记录
    webpack打包错误 ERROR in multi ./src/main.js ./dist/bundle.js

    webpack基本配置

    • webpack.config.js
    • webpack-dev-server

    为了实现自动打包,监听代码变化


    可能遇到的问题


    解决方案

    webpack-dev-server配置命令的方式

    • --open 自动打开浏览器
    • --port 8000 指定端口
    • --contentBase src 内容的根路径
    • --hot 热重载热更新(不重新生成bundle.js,只生成补丁代码),实现浏览器不刷新重载(否则会页面整体刷新)

    html-webpack-plugin插件

    在内存中生成html页面的插件

    安装

    1.npm i html-webpack-plugin -D 2.在webpack.config.js导入插件
    3.配置

    优点

    • 指定生成页面的名称,重名即可,会自动访问同名的内存的页面。
    • 当使用 html-webpack-plugin之后,不再需要手动处理bundle.js的引用路径, 因为插件自动创建了一个合适的 script, 并引用了正确的路径

    webpack中使用CSS(loader的使用)

    1. 在main.js中import CSS样式表,webpack默认只能打包JS类型的文件,需要手动安装一些合适的第三方loader加载器。
    2. 运行cnpm i style-loader css-loader --save-dev
    3. 修改webpack.config.js这个配置文件:
    module: { // 用来配置第三方loader模块的
            rules: [ // 文件的匹配规则
                { test: /\.css$/, use: ['style-loader', 'css-loader'] }//处理css文件的规则
            ]
        }
    
    1. 注意:use表示使用哪些模块来处理test所匹配到的文件;use中相关loader模块的调用顺序是从后向前调用的;

    使用webpack打包less文件

    1. 运行cnpm i less-loader less -D
    2. 修改webpack.config.js这个配置文件:
    { test: /\.less$/, use: ['style-loader', 'css-loader', 'less-loader'] },
    

    使用webpack打包sass文件

    1. 运行cnpm i sass-loader node-sass --save-dev
    2. webpack.config.js中添加处理sass文件的loader模块:
    { test: /\.scss$/, use: ['style-loader', 'css-loader', 'sass-loader'] }
    

    url-loader处理图片和字体

    默认情况下,webpack无法处理css文件中的url地址,不管是图片还是字体库

    1. 运行cnpm i url-loader file-loader --save-dev (file-loader为url-loader的内部依赖,不需要配置)
    2. webpack.config.js中添加处理url路径的loader模块:
    { test: /\.(png|jpg|gif|jpeg)$/, use: 'url-loader' }
    
    1. url-loader会自动把图片转为base64编码,可以通过limit指定进行base64编码的图片大小;只有小于指定字节(byte)的图片才会进行base64编码:
    • 图片
    { test: /\.(png|jpg|gif)$/, use: 'url-loader?limit=43960' },
    
    • 字体
    {test:/\.(ttf|eot|svg|woff|woff2)$/,use:'url-loader'}
    

    默认改变图片的名字的原因是:防止重名,可以传参改变这一默认行为url-loader?limit=1024&name=[name].[ext],但为了防止重名,可以在原名字前添加hash值url-loader?limit=1024&name=[hash:8]-[name].[ext],hash最大为32位,所以最大只能设为32;

    webpack.config.js 的 rules中的所有loader都能传参

    webpack处理第三方文件的过程

    • 发现处理的文件不是JS,就去配置文件查找有没有对应的第三方loader规则;

    • 如果能发现对应的规则,就会调用对应的loader处理这种文件类型;

    • style-loader 与 css-loader 调用规则是从右到左调用。

    • 当最后的一个loader调用完毕,会把处理的结果交给webpack进行打包合并,最终打包构件;

    相关文章

      网友评论

          本文标题:Webpack初步了解(打包,webpack-server)

          本文链接:https://www.haomeiwen.com/subject/kacjtqtx.html