Webpack + vue 之抽离 CSS 的正确姿势

导语

最近做了个webpack+vue的项目,发现打包后的页面体积有点超出预期的大。为了减少请求量, 页面的js和css都是内联在html里面的,查看生成的html代码后发现,异步引入的vue模块中的css 也被打在了页面上面。页面体积可是影响加载速度的关键,赶紧google后解决了这个问题。这里记录下。

大部分使用过webpack的朋友都知道,抽离css需要使用到webpack的插件extract-text-webpack-plugin,vue也不例外。官方给的vue-loader的文档里面有这样的描述

module: {
          rules: [
            {     //处理js中引入的css
                  test: /\.css$/,
                  loader: ExtractTextPlugin.extract({
                      use: [
                          {
                              loader: 'css-loader'
                          }
                      ]
                  })
              },
              {
                  test: /\.vue$/,
                  loader: 'vue-loader',
                  options: {loaders:{
                      css: ExtractTextPlugin.extract({
                          use: 'css-loader',
                          fallback: 'vue-style-loader'
                      })
                  }}
              }
          ]
        },
plugins: [ //这个不添加allChunks参数的话,不会抽离chunk的css
new ExtractTextPlugin({filename: 'css/[name].[hash:5].css', allChunks: true})
]

OK,这样打包后,我们把每个entry里面使用到的css代码都单独打包出来了,这时候可以选择

使用html-webpack-plugin生成带css 链接的html,也可以使用html-webpack-inline-source-

plugin把css内联到html里面(减少请求数量,在移动端很有用)

然而会发现,异步引入的vue文件里面import的css,也会被抽离出来,打包内联到html里面,

怎么解决这个问题呢。其实很简单,就是使用loader的include参数,指定loader的作用文件夹,

对不想抽离css的文件,使用style-loader和css-loader。就像这样

module: {
          rules: [
           {
        test: /\.css$/,
        include: [path.resolve(__dirname, "../src/page/"),
        loader: ExtractTextPlugin.extract({
        use: [
        {
            loader: 'css-loader'
                }
        ]
        })
       },
       {
        test: /\.css$/,
        include: path.resolve(__dirname, "../src/components/"),
        loader: ['style-loader','css-loader']
      },
             {
                  test: /\.vue$/,
                  loader: 'vue-loader',
                  options: {loaders:{
                      css: ExtractTextPlugin.extract({
                          use: 'css-loader',
                          fallback: 'vue-style-loader'
                      })
                  }}
              }
          ]
        },
plugins: [ //这个不添加allChunks参数的话,不会抽离chunk的css
new ExtractTextPlugin({filename: 'css/[name].[hash:5].css', allChunks: true})
]

这里配置对page目录下的代码,抽离出css,对components里面引用的代码,内联在js里面。

这样异步加载components的css就不会被打包到首屏的html里面了,页面体积减少,加载速度自然

就上去了。

下面附修改前后的对比。

修改前

修改后

很明显,修改后html的体积变小了,然而值得注意的是,修改后html+js的体积大于修改前,

这是因为css在js里面保存,需要更多的字符去表示,所以总体积变大了。把chunkjs里面的css

把chunkjs里面的css再抽离单独加载也是一个不错的注意。

不过怎么做效果好,还是要实际测试一下。

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java学习网

Android中App安装位置详解

Android中App安装位置详解 Android应用可以安装在本机自带存储,同时也可以安装到外部存储(SD卡)。自从API 8后也就是Android2.2后...

2339
来自专栏iOSDevLog

Action API目录

2829
来自专栏WindCoder

《Linux内核分析》之构造一个简单的Linux系统MenuOS 实验总结

在原来配置的基础上,make menuconfig选中如下选项重新配置Linux,使之携带调试信息

751
来自专栏IT笔记

JavaWeb项目架构之NFS文件服务器

NFS简介 NFS(Network File System)即网络文件系统。 主要功能:通过网络(局域网)让不同的主机系统之间可以共享文件或目录。 主要用途:N...

3606
来自专栏LanceToBigData

MySQL集群(一)之主从复制

前面学完了JDBC,接下来带大家感受一下MySQL集群!其实什么是MySQL集群?简单的说就是一群机器(服务器)的集合,它们连在一起来工作。 其实各种数据库都有...

1945
来自专栏运维小白

12.17 Nginx负载均衡

Nginx负载均衡目录概要 vim /usr/local/nginx/conf/vhost/load.conf // 写入如下内容 upstream qq_co...

1896
来自专栏Java技术

Kafka 单机和分布式环境搭建与案例使用

zookeeper:http://www.apache.org/dyn/closer.cgi/zookeeper/

852
来自专栏博客园

Redis主从复制

     2.Slave同样可以接收其它Slaves的连接与同步请求,这样可以有效的分载Master的同步压力,因此我们可以将Redis的Replication...

913
来自专栏纯洁的微笑

springcloud(七):配置中心svn示例和refresh

上一篇springcloud(六):配置中心git示例留了一个小问题,当重新修改配置文件提交后,客户端获取的仍然是修改前的信息,这个问题我们先放下,待会再讲。国...

3128
来自专栏Java技术分享圈

杨老师课堂之JavaWeb项目架构之NFS文件服务器

当用户A通过互联网上传文件时,经过负载均衡,随机或者定向分配到某个节点。但是当用户B去下载这个文件的时候,并不确定会向哪个节点发送请求,这样会导致用户存在一定几...

723

扫码关注云+社区