上一篇文章 体验了webpack的打包过程,其中js文件不需要我们手动配置就可以成功解析,可其它类型的文件,比如css、less呢?

css-loader

首先,创建一个空文件夹,通过 npm init -y 初始化项目,项目结构如下

demo
├─ src
│ ├─ css
│ │ └─ index.css
│ ├─ js
│ │ └─ component.js
│ └─ index.js
├─ index.html
└─ package.json

在component.js 中创建一个div元素并设置class,index.css 中 定义样式,最后在 index.js 中引入 component.js 及 index.css 文件

// component.js
const divEl = document.createElement("div");
const text = document.createTextNode("hello webpack");
divEl.appendChild(text);
divEl.setAttribute("class", "element");
document.body.appendChild(divEl); // index.css
.element {
  font-size: 20px;
  font-weight: bold;
} // index.js
import "./js/component";
import "./css/index.css";

在package.json 中配置 build 指令后,使用 npm run build 运行项目

但此时是不能被编译通过,它报错提示“You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file.”

用于处理css资源的loader是css-loader。npm i css-loader -D 在项目中安装后,在项目根目录新建 webpack.config.js 文件,在 module 对象中 rules 里配置,test 通过正则表达式匹配文件后缀,use 表示使用的 loader。

const path = require("path");
module.exports = {
  entry: "./src/index.js",
  output: {
    path: path.resolve(__dirname, "dist"),
    filename: "bundle.js",
  },
  module: {
    rules: [
      {
        test: /\.css$/,
        use: ["css-loader"],
      },
    ],
  },
};

再次 npm run build 运行项目,此时已经可以编译通过了~

index.html 引入打包后的 bundle.js,通过 Live Server 运行 html 文件

style-loader

可以在html页面中看到 div 标签,但 css 没有生效,这是因为 css-loader 只负责解析 css,但不会将 css 插入到页面中,这个操作需要 style-loader 来完成。

通过 npm i style-loader -D 安装后,在 webpack.config.js 中配置。

对于 css 文件,需要先通过 css-loader 解析后再通过 style-loader 插入页面。而 loader 的执行顺序是从后往前,所以 style-loader 放在 css-loader 前面。

module: {
    rules: [
      {
        test: /\.css$/,
        use: ["style-loader", "css-loader"],
      },
    ],
  },

此时 css 文件中的样式就可以生效啦,可以看到 style-loader 的作用就是创建了一个 style 标签,并将 css-loader 解析完的 css 内容插入

less-loader

在 css 文件夹下增加一个 index.less 文件,在 index.js 中引入

// index.less
@color: red; .element {
  color: @color;
} // index.js
import "./css/index.less";

运行后同样会提示没有合适的loader

处理 less文件使用 less-loader,但实际上 less-loader 需要借助 less 这个工具,直接通过 less 工具就可以将 less 文件里的代码处理为浏览器可识别的 css 代码

执行 npx less ./src/css/index.less > ./src/css/revert.css 命令使用 less 工具将 index.less 文件解析成 revert.css

在webpack.config.js中只需要将 less-loader 配置上就行,less-loader 需要最先将 less 资源处理成 css ,所以放置最后面

 module: {
    rules: [
      {
        test: /\.css$/,
        use: ["style-loader", "css-loader"],
      },
      {
        test: /\.less$/,
        use: ["style-loader", "css-loader", "less-loader"],
      },
    ],
  },

重新编译后就可以浏览器上看到less设置的样式生效啦,以及 css 和 less 分别使用 style-loader 创建了两个 style 标签。

PostCSS

PostCSS是一个通过JavaScript来转换样式的工具,帮助我们进行一些CSS的转换和适配,比如自动添加浏览器前缀、css样式的重置,但是PostCSS不能直接实现,需要借助对应的插件。

比如以下css代码,某些浏览器可能不兼容,自己手动添加浏览器前缀使之兼容也可以,但太过麻烦,而且也不知道需要兼容哪些版本的浏览器,使用工具是比较好的方案。

.content {
  user-select: none;
  color: #12345678;
  transition: all 2s ease;
}

通过 postcss-cli 可以对文件进行解析处理,通过指令 npx postcss -o result.css ./src/css/component.css 进行编译

虽然编译没有报错,但是编译后并没有对文件进行兼容处理,因为没有指定插件,分别指定两种插件,来看看编译结果

npx postcss --use autoprefixer -o autoprefixer.css ./src/css/component.css
npx postcss --use postcss-preset-env -o preset.css ./src/css/component.css

autoprefixer 只负责增加浏览器前缀

postcss-preset-env css做转换,如16进制颜色转换成rgb,并且内置了autoprefixer

postcss-loader

在webpack环境下,使用postcss-loader来对css进行兼容性的处理,同时需要配置插件, autoprefixer 和 postcss-preset-env 都可以。

{
test: /\.css$/,
use: [
"style-loader",
"css-loader",
{
loader: "postcss-loader",
options: {
postcssOptions: {
plugins: [require("postcss-preset-env")],
},
},
},
],
},

添加前缀和样式转换后的代码就可以被添加到浏览器中

browsersList

通过postcss对css代码兼容性进行了处理,但我们可以看到上面定义了css3中的属性 transition,某些浏览器有可能存在兼容性问题,但在这里没有添加浏览器前缀。

这是因为没有指定浏览器兼容版本,对于编译支持的浏览器版本采取了默认配置,默认配置中的浏览器已经都能够支持 transition 属性。

我们可以通过 browsersList 来指定浏览器兼容性版本,可配置在 package.json 或者 .browserslistrc 文件中

> 0.1%,
last 4 version,
not dead

.browserslistrc 文件配置表示浏览器使用率大于0.1%,每个浏览器的最后四个版本、以及没有“死亡”的浏览器,扩大了需要兼容的浏览器版本。

此时编译后的代码就会帮我们添加浏览器前缀。

webpack处理样式资源,通过 css-loader、style-loader 解析 css 语法browsersList、postcss 方式,处理兼容性问题。

以上是和样式资源有关的编译配置,更多有关webpack的内容可以参考我其它的博文,持续更新中~

webpack是如何处理css/less资源的呢的更多相关文章

  1. Webpack干货系列 | 怎么运用 Webpack 5 处理css/scss/sass、less、stylus样式资源

    程序员优雅哥简介:十年程序员,呆过央企外企私企,做过前端后端架构.分享vue.Java等前后端技术和架构. 本文摘要:主要讲解webpack 5 如何高效处理CSS 资源.scss/sass 资源.l ...

  2. NanUI文档 - 打包并使用内嵌式的HTML/CSS/JS资源

    NanUI文档目录 NanUI简介 开始使用NanUI 打包并使用内嵌式的HTML/CSS/JS资源 使用网页来设计整个窗口 如何实现C#与Javascript相互掉用(待更新...) 如何处理Nan ...

  3. Webpack 2 视频教程 012 - 理解Webpack 中的 CSS 作用域与 CSS Modules

    原文发表于我的技术博客 这是我免费发布的高质量超清「Webpack 2 视频教程」. Webpack 作为目前前端开发必备的框架,Webpack 发布了 2.0 版本,此视频就是基于 2.0 的版本讲 ...

  4. vue webpack 打包后css背景图路径问题

    最近在写vue-webpack项目时,打包后遇到了css背景图片路径报错的问题 奇怪的是,通过img标签引入的图片路径却没有问题,看来是webpack在打包后,读取css中图片的相对路径出错了. 稍微 ...

  5. webpack快速入门——CSS进阶:自动处理CSS3前缀

    为了浏览器的兼容性,有时候我们必须加入-webkit,-ms,-o,-moz这些前缀.目的就是让我们写的页面在每个浏览器中都可以顺利运行. 1.安装 cnpm i postcss-loader aut ...

  6. webpack快速入门——CSS文件打包

    1.在src下新建css文件,在css文件下新建index.css文件,输入以下代码 body{ background:pink; color:yellowgreen; } 2.css建立好后,需要引 ...

  7. webpack快速入门——CSS中的图片处理

    1.首先在网上随便找一张图片,在src下新建images文件夹,将图片放在文件夹内 2.在index.html中写入代码:<div id="pic"></div& ...

  8. webpack快速入门——CSS分离与图片路径处理

    1.在终端安装extract-text-webpack-plugin 2.引入插件 const extractTextPlugin = require("extract-text-webpa ...

  9. webpack快速入门——CSS进阶,Less文件的打包和分离

    1.要使用less,首先使用npm安装less服务 cnpm install less --save-dev 还需要安装Less-loader用来打包使用. cnpm install less-loa ...

  10. webpack快速入门——CSS进阶:SASS文件的打包和分离

    1.安裝:因为sass-loader依赖于node-sass,所以需要先安装node-sass cnpm install node-sass --save-dev cnpm install sass- ...

随机推荐

  1. 音视频八股文(6)-- ffmpeg大体介绍和内存模型

    播放器框架 常用音视频术语 • 容器/文件(Conainer/File):即特定格式的多媒体文件, 比如mp4.flv.mkv等. • 媒体流(Stream):表示时间轴上的一段连续数据,如一 段声音 ...

  2. 2020-12-15:mysql的回滚机制是怎么实现的?

    福哥答案2020-12-15:[答案来自此链接:](https://www.cnblogs.com/ld-swust/p/5607983.html)在 MySQL 中,恢复机制是通过回滚日志(undo ...

  3. 云端炼丹,算力白嫖,基于云端GPU(Colab)使用So-vits库制作AI特朗普演唱《国际歌》

    人工智能AI技术早已深入到人们生活的每一个角落,君不见AI孙燕姿的歌声此起彼伏,不绝于耳,但并不是每个人都拥有一块N卡,没有GPU的日子总是不好过的,但是没关系,山人有妙计,本次我们基于Google的 ...

  4. Python连接es笔记一之连接与查询es

    本文首发于公众号:Hunter后端 原文链接:Python连接es笔记一之连接与查询es 有几种方式在 Python 中配置与 es 的连接,最简单最有用的方法就是定义一个默认的连接,如果系统不是需要 ...

  5. Redash 可视化BI系统部署安装及简单使用

    这篇文章主要为介绍一下Redash的使用和安装 概览 Redash 主要使用的语言为 Python 和 TypeScript 这个安装主要是基于Docker 来安装的,官网教程基本没有不是基于Dock ...

  6. 5.5. Java并发工具类(如CountDownLatch、CyclicBarrier等)

    5.5.1 CountDownLatch CountDownLatch是一个同步辅助类,它允许一个或多个线程等待,直到其他线程完成一组操作.CountDownLatch有一个计数器,当计数器减为0时, ...

  7. 上下文管理者(ServletContext)

    作用1.获取全局初始化参数2.资源共享(servlet通信) 能让上下文呢的Servlet相互关联起来3.获取资源文件 生命周期创建服务器启动的时候会为每个项目创建一个servletContext上下 ...

  8. 在 RedHat 使用 gdc-client 下载 TCGA 数据

    今天,只聊一下 RedHat/CentOS 下 gdc-client 安装的那些事. gdc-client,官网地址:https://gdc.cancer.gov/access-data/gdc-da ...

  9. SQL注入三连实战绕过WTS-WAF

    一键三连,sql注入 一次无意之间发现的sql注入,主要是因为有一个WTS-WAF,在此记录一下 只是友好测试,并非有意为之.... 牛刀小试1 手注 判断字段数 测试到order by 15的时候出 ...

  10. 一分钟学一个 Linux 命令 - ps

    前言 大家好,我是 god23bin.欢迎来到<一分钟学一个 Linux 命令>系列,每天只需一分钟,记住一个 Linux 命令不成问题.今天要说的是 ps 命令. 什么是 ps 命令? ...