美文网首页
webpack模板项目的踩坑记录

webpack模板项目的踩坑记录

作者: 伐樱大魔 | 来源:发表于2018-10-04 16:04 被阅读0次

    1. 初始化一个空项目

    1. 创建一个空文件夹 mkdir webpack-test

    2. 进入这个文件夹 cd webpack-test

    3. 创建如下所示的文件夹以及文件

      3.1 src文件夹

      3.1.1 css文件夹:用来存放css样式文件

      3.1.2 images文件夹:用来存放图片

      3.1.3 index.html:我们能够看到的主页面

      3.1.4 main.js:js打包入口文件

    4. 添加一个package.json文件

      npm init -y
      
    5. 在index.html里面随便写一个代码

      <div>hahhaha</div>
      
    6. 并且加上这一段代码的样式,在css文件下面,新建一个index.css文件,以及images文件夹里面添加一个要用到的图片

      div{
          background: url('../images/wallpaper.png');
          background-size: cover;
          font-size: large;
          height: 500px;
          width: 500px;
      }
      
    7. 新建一个文件webpack.config.js

      const path = require('path')
      module.exports={
          entry: path.join(__dirname, './src/main.js'),
          output: {
              path: path.join(__dirname, './dist'),
              filename: 'bundle.js'
          }
      

      设置我们的入口文件是main.js文件,当我们打包后,我们的出口文件是dist文件夹下面的bundle.js。

    8. 添加jquery的依赖

      yarn add jquery
      

      为什么要用yarn而不用npm?

      yarn和npm都是可以用的,但是yarn下载要快一点。

    9. 在main.js文件里面,引入jquery,并且简单的操作一下

      import $ from 'jquery'
      
      $(function () {
          $('div').css('color','pink')
      })
      
    10. 此刻我想要运行我的项目了,我该怎么运行呢?

      • 安装webpack

        yarn add webpack --dev
        
      • 安装webpack-dev-server 以及 html-webpack-plugin

        yarn add webpack-dev-server html-webpack-plugin --dev  
        
      • 在package.json里面设置一下dev环境下面webpack server开始项目,以及我们的端口号,热加载

        "dev": "webpack-dev-server --open --port 3000 --hot",
        
      • 配置完毕,我们运行项目的命令就是:

        npm run dev
        
    11. 但是,这个时候,还没有到开启项目的时候。我们之前安装了html-webpack-plugin,这个插件的用处就是让我们项目开启的时候第一眼能看见我们的index.html文件,而不是我们的项目目录。所以,打开webpack.config.js配置:

      plugins: [
              new htmlWebpackPlugin({
                  template: path.join(__dirname, './src/index.html'),
                  filename: 'index.html'
              //    默认会打开index。html这个首页
              })
          ],
      
    12. 我们现在可以尝试开启项目,但是会失败哦!因为我们运用了css,url但是没有配置他们的加载器。要在webpack.config.js配置加载器:

      module: {
              rules: [
                  {test: /\.css$/, use:['style-loader','css-loader']},
                  {test:/\.scss$/,use:['style-loader','css-loader','sass-loader']},
                  {test:/\.(png|gif|bmp|jpg)$/,use:['url-loader?limit=5000']},
              ]
      

      并且安装他们的加载器:

      yarn add style-loader css-loader sass-loader node-sass url-loader file-loader --dev 
      
    13. 如果我们想要运行es6的高级语法呢?

      • 安装babel

        yarn add babel-core babel-loader babel-plugin-transform-runtime babel-preset-env babel-preset-stage-0 --dev
        
      • 新建.babelrc文件

        {
          "presets": ["env","stage-0"],
          "plugins": ["transform-runtime"]
        }
        
      • 配置babel的加载器

        {test:/\.js$/,use:'babel-loader',exclude:/node_modules/}
        
    14. 起项目!

    15. 好了,现在我们准备发布了!发布环境与我们的开发环境是不一样的哦,发布环境要复杂的多。所以,我们先复制一下webpack.config.js文件改名为webpack.pub.config.js。

    16. 在package.json文件下面配置一个发布,告诉程序,发布的配置文件是webpack.pub.config.js。

      "pub": "webpack --config webpack.pub.config.js"
      
    17. 发布的命令是:

      npm run pub
      

      当我们发布的时候,会生成了一个dist文件夹,文件夹里们有我们的bundle.js以及图片等。

    18. 此刻,我们决定把打包好了的图片都放到一个images文件夹里面,在webpack.pub.config.js里面配置:

      test: /\.(png|gif|bmp|jpg)$/, use: ['url-loader?limit=5000&' +
                      'name=images/[hash:8]-[name].[ext]']
      
    19. 重新运行npm run pub我们就重新打包发布了,我们发现dist文件下面出现了一个images文件夹,我们的图片也在images文件夹下面,但是,之前dist目录下班的图片依旧遗留在此,没有处理掉。于是,我想要每次打包发布的时候都先删除dist文件,再重新生成一个。

      • 安装插件

        yarn add clean-webpack-plugin --dev 
        
      • 在webpack.pub.config.js里面配置,告诉插件我们删除的文件夹是哪个

        const CleanWebpackPlugin = require('clean-webpack-plugin');
        
        plugins: [
            ...,
            new CleanWebpackPlugin(['dist'])
        ]
        
        
    20. npm run pub

    21. 此刻我们可以优化一下我们的项目,压缩一下。mini-css-extract-plugin

      • 安装插件(注意:踩坑!

         yarn add extract-text-webpack-plugin --dev   
        

        为什么踩坑?因为我的webpack4以上已经不用这个插件了,我们有更好的插件来替代:

         yarn add  mini-css-extract-plugin --dev 
        
      • 配置(压缩css,并且放在css文件夹下面)

        const MiniCssExtractPlugin = require("mini-css-extract-plugin");
        
        plugins: [
          new MiniCssExtractPlugin({
                    filename: "css/[name].css",
                    chunkFilename: "css/[id].css"
                })
        ],
         rules: [
                    {
                        test: /\.css$/,
                        use: [
                            {
                                loader: MiniCssExtractPlugin.loader,
                                options: {
                                    publicPath: '../'
                                }
                            },
                            "css-loader"
                        ]
                    },
        ]
        

        publicPath: '../' 的作用就是:当我们打包发布了之后,因为我们的图片是在一个images文件夹下面,所以图片的相对地址就相对于默认情况下的相对地址,改变了。那么我们就需要配置一下相对地址。

      • 压缩(html压缩)

        plugins: [
                new htmlWebpackPlugin({
                    template: path.join(__dirname, './src/index.html'),
                    filename: 'index.html',
                    
                    minify: {//压缩html文件
                        collapseWhitespace: true,//移除空格
                        removeComments: true,//移除注释
                        removeAttributeQuotes: true//移除属性上的双引号
                    }
                }),
        
    22. 如何在打包的时候,把我们的代码与我们所依赖的包相分离,把依赖的东西提取出来呢?配置:

       entry: {
              app: path.join(__dirname, './src/main.js'),
              vendors1: ['jquery']//把要抽离的第三方的包的报名,放入这个数组里面
          }, 
      
      optimization: {
              splitChunks: {
                  cacheGroups: {
                      commons: {
                          name: "vendors1",
                          filename: "js/vendors.js",
                          chunks: "initial",
                          minChunks: 2
                      }
                  }
              }
          }
      

      把我们需要排斥的依赖,设置在entry里面,

      dist文件夹下面vendors.js就是我们所排除的依赖。

    23. npm run pub

    相关文章

      网友评论

          本文标题:webpack模板项目的踩坑记录

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