使用extract-text-webpack-plugin提取css文件
一、css之上的语言
js之上的语言有jsx、tyepscript、coffescript。 html之上的语言有jade。 css之上的语言有sass、scss、less、stylus,这几种语言区别其实不大,完全不需要纠结到底用那个。
css的缺点:
- 语法不够强大,不能够嵌套书写,不利于模块化开发
- 没有变量和逻辑上的复用机制,导致在css的属性值中只能使用字面量形式,以及不断重复书写重复的样式,导致难以维护。
css预编译语言的特点:
可以使用变量:就像其他编程语言一样,免于多处修改。
Sass:使用$对变量进行声明,变量名和变量值使用冒号进行分割
Less:使用@对变量进行声明
Stylus:中声明变量没有任何限定,结尾的分号可有可无,但变量名和变量值之间必须要有『等号』。作用域:有了变量,就必须得有作用域进行管理。就想js一样,它会从局部作用域开始往上查找变量。 Sass:它的方式是三者中最差的,不存在全局变量的概念
Less:它的方式和js比较相似,逐级往上查找变量
Stylus:它的方式和Less比较相似,但是它和Sass一样更倾向于指令式查找嵌套:对于css来说,有嵌套的写法无疑是完美的,更像是父子层级之间明确关系
postcss并不是一种预处理语言,而是一套插件系统,很多人认为postcss是css的未来。
二、使用lessc命令进行编译
原始的css已经足够优美了,想想开发桌面应用时我们是如何定义控件样式的,通过指令形式指定控件样式更加繁琐。 css之上的语言差别不大,我选less。npm install -g less less-loader 安装完成之后,使用lessc命令就可以编译less文件了。
三、使用extract-text-webpack-plugin插件自动提取css文件
为什么要把css文件单独出去
如果不单独出去,页面加载js会比较慢,用户会看到css加载之前的内容,页面比较丑陋。页面先加载css,再渲染html,最后才执行js。把css作为单独的link标签能够使页面加载时更加美观。
配置
webpack.config.js
var p = require('path')
var process = require('process')
var NODE_PATH=process.env['NODE_PATH']
const ExtractTextPlugin = require("extract-text-webpack-plugin")
module.exports = {
mode: 'development',
entry: { "main.js": "./index.js" },
output: { filename: '[name]' },
module: {
rules:[
{ test:/\.less$/, use:ExtractTextPlugin.extract({ use:['css-loader','less-loader'] }) }
]
},
resolve:{ modules:[NODE_PATH] },
resolveLoader: { modules: [NODE_PATH] },
plugins: [ new ExtractTextPlugin("custom.css"), ]
}
上面的配置中,通过resolve.modules设置寻找模块的路径,使用resolveLoader设置寻找loader的路径,这种方式在使用webpack-dev-server时可能会有问题,最佳方式是建立一个node_modules软连接,把NODE_PATH链接到当前文件夹。
可能遇到的问题
plain Error: Chunk.entrypoints: Use Chunks.groupsIterable and filter by instanceof Entrypoint instead
extract-text-webpack-plugin这个插件目前不支持webpack 4.0,而npm仓库中默认安装的是适用于webpack3.0的插件,解决方案是直接使用下一代extract-text-webpack-plugin插件:
npm install -g extract-text-webpack-plugin@next
参考资料
webpack官网extract-text-webpack插件介绍
https://www.webpackjs.com/plugins/extract-text-webpack-plugin/
关于postcss https://segmentfault.com/a/1190000011595620
npm extract-text-webpack插件
https://www.npmjs.com/package/extract-text-webpack-plugin
使用extract-text-webpack-plugin提取css文件的更多相关文章
- webpack生成的css文件background-image url图片无法加载
之前在使用webpack3构建基于less预处理的项目时,在对指定的元素使用background-image: url(xxx)来设置背景图片时,本地开发是ok的,但是在项目编译产出后背景图片就找不到 ...
- webpack快速入门——CSS文件打包
1.在src下新建css文件,在css文件下新建index.css文件,输入以下代码 body{ background:pink; color:yellowgreen; } 2.css建立好后,需要引 ...
- webpack加载css文件及其配置
webpack加载css文件及其配置 当我们写了几个css文件之后如果想要引用到html中去的话我们最开始的方式就是通过link标签将css文件导入进去,但是如果我们的css文件有很多的话,一个个的导 ...
- webpack配置:css文件打包、JS压缩打包和HTML文件发布
一.CSS文件打包 1.在src下新建css文件,在css文件下新建index.css文件,输入以下代码 body{ color:red; font-size:20px; } 2.css建立好后,需要 ...
- webpack打包提取css到独立文件
将本来镶嵌在bundle.js的css转到外面来,我们需要用到一个插件:extract-text-webpack-plugin 使用方法: 1.安装 npm i extract-text-webpac ...
- vue webpack打包后.css文件里面的背景图片路径错误解决方法
资源相对引用路径 问题描述 一般情况下,通过webpack+vuecli默认打包的css.js等资源,路径都是绝对的. 但当部署到带有文件夹的项目中,这种绝对路径就会出现问题,因为把配置的static ...
- webpack4对第三方库css,项目全局css和vue内联css文件提取到单独的文件(二十二)
在讲解提取css之前,我们先看下项目的架构如下结构: ### 目录结构如下: demo1 # 工程名 | |--- dist # 打包后生成的目录文件 | |--- node_modules # 所有 ...
- webpack快速入门——CSS进阶,Less文件的打包和分离
1.要使用less,首先使用npm安装less服务 cnpm install less --save-dev 还需要安装Less-loader用来打包使用. cnpm install less-loa ...
- webpack快速入门——CSS进阶:SASS文件的打包和分离
1.安裝:因为sass-loader依赖于node-sass,所以需要先安装node-sass cnpm install node-sass --save-dev cnpm install sass- ...
随机推荐
- CSS-页面滑屏滚动原理
现在的网站有的时候为了简洁就是很多的单页滑屏滚动介绍,主要呈现方式有两种,一种是整体的元素一直排列下去,假设有五个需要展示的全屏页面,那么高度是500%,只是展示100%,剩下的可以通过transfo ...
- iOS开发-UIScreenEdgePanGestureRecognizer实战
UIScreenEdgePanGestureRecognizer名字很长,而且关于其文档也是少的的可怜,苹果官方给的唯一的一个属性是edges,文档中的解释是这样的: A UIScreenEdgePa ...
- 关于使用rem单位、css函数calc()进行自适应布局
一.关于css中的单位 大家都知道在css中的单位,一般都包括有px,%,em等单位,另外css3新增加一个单位rem. 其中px,%等单位平时在传统布局当中使用的比较频繁,大家也比较熟悉,不过px单 ...
- Android -- Dialog动画
window_in.xml <?xml version="1.0" encoding="utf-8"?> <set xmlns:android ...
- 使用MultipartEntity对文字、图片、视频进行综合上传
package com.home.upload; import java.io.File; import java.nio.charset.Charset; import java.util.Arra ...
- 【大数据】下载Windows版本的Redis 转
https://www.cnblogs.com/tommy-huang/p/6093813.html 下载Windows版本的Redis 1.打开官网http://redis.io/点击Downl ...
- 最小公倍数 SRM 661 Div1 250: MissingLCM
Problem Statement The least common multiple (denoted "lcm") of a non-empty sequence of pos ...
- Python 各种测试框架简介
转载:https://blog.csdn.net/yockie/article/details/47415265 一.doctest doctest 是一个 Python 发行版自带的标准模块.本篇将 ...
- stl 迭代器失效
1.对于基于连续内存的容器,容器元素的增删,有可能会导致迭代器的失效.考虑: int main(int argc, char* argv[]) { vector<int> intVec; ...
- Oracle聚合连接字符串
问题需求 现有一个数据表,如下: ID CODE NAME 1 A 张三 2 A 李四 3 B 王五 4 C 赵六 5 C 孙七 ...