webpack模板项目的踩坑记录

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

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

推荐阅读更多精彩内容