码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Webpack--CSS、Sass、Scss的import中~(波浪线)的作用


    原文网址:Webpack--CSS、Sass、Scss的import中~(波浪线)的作用_IT利刃出鞘的博客-CSDN博客

    简介

    说明

            本文介绍CSS、Sass、Scss的import中~(波浪线)的作用。

    官网网址

    处理资源路径 | Vue Loader

    解析(Resolve) | webpack 中文文档

    css-loader | webpack 中文文档

    ~ 概述

    引用自Vue官网

    资源 URL 转换会遵循如下规则:

    • 如果路径是绝对路径 (例如 /images/foo.png),会原样保留。
    • 如果路径以 . 开头,将会被看作相对的模块依赖,并按照你的本地文件系统上的目录结构进行解析。
    • 如果路径以 ~ 开头,其后的部分将会被看作模块依赖。
      • 这意味着你可以用该特性来引用一个 Node 依赖中的资源:
    • 如果路径以 @ 开头,也会被看作模块依赖。
      • 如果你的 webpack 配置中给 @ 配置了 alias,这就很有用了。一般会将 @ 指向 /src。

    尤大是这样说的:

            vue-html-loader和css-loader把不以/开头的路径作为相对路径处理,如果需要使用模块路径,需要在路径前加一个波浪线~。

    原文:

    vue-html-loader and css-loader translates non-root URLs to relative paths. In order to treat it like a module path, prefix it with ~

    用法1:别名(alias)

    说明

            如果路径以 ~ 开头,其后的部分将会被看作模块依赖。可以给路径配置别名,比如:将 @ 指向 /src。这样一来,@import "~@/xx/yy";  实际对应的就是:@import "/src/xx/yy";

    别名的配置方法见:vue--配置根目录(用@代表src目录)_IT利刃出鞘的博客-CSDN博客

    示例

    Xxx.vue

    1. <template>
    2. template>
    3. <script>
    4. script>
    5. <style lang="scss" scoped>
    6. @import "~@/styles/mixin.scss";
    7. @import "~@/styles/variables.scss";
    8. style>

    Scss文件: 

    用法2:模块

    官网网址

    解析(Resolve) | webpack 中文文档

    用法

    @import导入样式文件时,路径前加上波浪线 ~,比如:

    import “~bootstrap/less/bootstrap.less”;

            就是告诉 webpack 以模块的方式去加载这个样式文件:去对应的 resolve.modules 定义的文件夹中去寻找对应的样式文件。

    配置详解

    配置方法(webpack.config.js):

    1. module.exports = {
    2. //...
    3. resolve: {
    4. modules: ['node_modules'],
    5. },
    6. };

            告诉 webpack 解析模块时应该搜索的目录。

            绝对路径和相对路径都能使用,它们之间有一点差异。

            通过查看当前目录以及祖先路径(即 ./node_modules, ../node_modules 等等), 相对路径将类似于 Node 查找 'node_modules' 的方式进行查找。

            使用绝对路径,将只在给定目录中搜索。

    如果想添加一个目录到模块搜索目录,此目录优先于 node_modules/ 搜索,方法如下:

    webpack.config.js

    1. const path = require('path');
    2. module.exports = {
    3.   //...
    4.   resolve: {
    5.     modules: [path.resolve(__dirname, 'src'), 'node_modules'],
    6.   },
    7. };

  • 相关阅读:
    【鸿蒙OH-v5.0源码分析之 Linux Kernel 部分】003 - vmlinux.lds 链接脚本文件源码分析
    《DevOps实践指南》- 读书笔记(九)
    钟控D触发器
    Activiti——流程的挂起与激活
    RFID管理方案有效提升电力物资管理效率与资产安全
    AutoRunner自动化测试工具
    NIO的浅了解
    vite 依赖预构建-依赖扫描
    华为云云耀云服务器L实例评测|老用户回归的初印象
    电子学会C/C++编程等级考试2021年12月(一级)真题解析
  • 原文地址:https://blog.csdn.net/feiying0canglang/article/details/126333176
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号