CSS预编译器:让样式编写更高效的秘密武器(6)

在现代前端开发中,CSS 预编译器是一种非常有用的工具,它通过扩展 CSS 语言的功能,帮助开发者更高效地编写和维护样式代码。本文将介绍 CSS 预编译器的基本原理,并重点讲解 LESS 的安装和使用方法。

1. 基本原理

编写 CSS 时,受限于 CSS 语言本身,常常难以处理一些问题:

  • 重复的样式值:例如常用颜色、常用尺寸。
  • 重复的代码段:例如绝对定位居中、清除浮动。
  • 重复的嵌套书写:复杂的嵌套选择器。

由于官方迟迟不对 CSS 语言本身做出改进,一些第三方机构开始想办法来解决这些问题。其中一种方案便是预编译器。

预编译器的原理很简单,即使用一种更加优雅的方式来书写样式代码,通过一个编译器,将其转换为可被浏览器识别的传统 CSS 代码。
在这里插入图片描述

目前,最流行的预编译器有 LESSSASS。由于它们两者特别相似,因此只需学习一种即可。本课程将重点介绍 LESS。
在这里插入图片描述

2. LESS 的安装和使用

2.1 安装 LESS

LESS 编译器是基于 Node.js 开发的,可以通过 npm 下载安装。

npm install -D less

安装好了 LESS 之后,它提供了一个 CLI 工具 lessc,通过该工具即可完成编译。

2.2 使用 lessc 编译 LESS 文件

假设你有一个 index.less 文件,内容如下:

// less代码
@red: #f40;.redcolor {color: @red;
}

运行编译命令:

npx lessc index.less index.css

编译之后的 index.css 文件内容如下:

.redcolor {color: #f40;
}

3. LESS 的基本使用

LESS 提供了许多强大的功能,包括变量、混合、嵌套、运算、函数、作用域和注释等。以下是一些基本的使用示例。

3.1 变量

变量可以用来存储常用的值,例如颜色、尺寸等。

@primary-color: #f40;
@font-size: 16px;.body {color: @primary-color;font-size: @font-size;
}

3.2 混合

混合允许你将一组样式定义为一个可重用的块。

.border-radius(@radius: 5px) {border-radius: @radius;-webkit-border-radius: @radius;-moz-border-radius: @radius;
}.box {.border-radius(10px);
}

3.3 嵌套

嵌套允许你更直观地编写嵌套的选择器。

.nav {ul {margin: 0;padding: 0;list-style: none;}li { display: inline-block; }a {display: block;padding: 6px 12px;text-decoration: none;}
}

3.4 运算

LESS 支持基本的数学运算,可以在样式中进行计算。

@base: 10px;
@padding: @base * 2;.box {padding: @padding;width: calc(100% - (@padding * 2));
}

3.5 函数

LESS 提供了许多内置函数,可以用来处理颜色、尺寸等。

@light-blue: lighten(#00b7ee, 20%);.box {background-color: @light-blue;
}

3.6 作用域

LESS 支持作用域,变量和混合在不同的作用域中可以有不同的值。

@color: red;.box {@color: blue;color: @color; // blue
}.text {color: @color; // red
}

3.7 注释

LESS 支持两种注释方式:单行注释和多行注释。

// 单行注释
/* 多行注释 */.box {// 这是一个单行注释color: red; /* 这是一个多行注释 */
}

3.8 导入

LESS 支持导入其他 LESS 文件,方便代码的模块化管理。

// variables.less
@primary-color: #f40;// main.less
@import "variables";.box {color: @primary-color;
}

4. 总结

通过本课程,你已经了解了 CSS 预编译器的基本原理和 LESS 的安装及使用方法。LESS 提供了许多强大的功能,可以帮助你更高效地编写和维护样式代码。

参考资料

  • LESS 官网:http://lesscss.org/
  • LESS 中文文档1(非官方):http://lesscss.cn/
  • LESS 中文文档2(非官方):https://less.bootcss.com/
  • SASS 官网:https://sass-lang.com/
  • SASS 中文文档1(非官方):https://www.sass.hk/
  • SASS 中文文档2(非官方):https://sass.bootcss.com/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/16457.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Vue3中实现插槽使用

目录 一、前言 二、插槽类型 三、示例 四、插槽的分类实现 1. 基本插槽 2. 命名插槽 3. 默认插槽内容 4. 作用域插槽(Scoped Slots) 5. 多插槽与具名插槽组合 一、前言 在 Vue 3 中,插槽(Slot)用于实现组件的内…

爬虫——Requests库的使用

在爬虫开发中,HTTP请求是与服务器进行交互的关键操作。通过发送HTTP请求,爬虫可以获取目标网页或接口的数据,而有效地处理请求和响应是爬虫能够高效且稳定运行的基础。Requests库作为Python中最常用的HTTP请求库,因其简洁、易用和…

如何使用EasyExcel生成多列表组合填充的复杂Excel示例

作者:Funky_oaNiu 一、(需求)生成的表格效果:二、搞一个模板文件三、建立对应的表格实体类四、开始填充五、Vue3前端发起请求下载六、官方文档及AI问答 一、(需求)生成的表格效果: 其中只有顶部…

三、计算机视觉_02计算机视觉领域的四大基本任务

0、前言 计算机视觉是人工智能领域的一个重要分支,它是一个跨学科的领域,涉及计算机科学、人工智能、机器学习、图像处理、神经科学等多个学科的知识 计算机视觉使用计算机技术来模拟人类视觉系统的功能,使计算机能够从图像或多维数据中提取…

Docker: ubuntu系统下Docker的安装

安装依赖 操作系统版本 Ubuntu Kinetic 22.10Ubuntu Jammy 24.04 (LTS)Ubuntu Jammy 22.04 (LTS)Ubuntu Focal 20.04 (LTS)Ubuntu Bionic 18.04 (LTS) CPU架构支持 ARMx86_64 查看我们的系统版本信息 uname -a通过该命令查得cpu架构是x86_64的; cat /etc/*re…

【已解决】 Tomcat10.1.x使用JSTL标签库

IDEA创建Java EE项目,使用Spring Spring MVC MyBatis框架,使用maven管理依赖。项目当前的环境是: Tomat 10.1.28Maven 3.6.3JDK 17 项目的功能:读取数据库的report表中的数据,返回一个List集合对象reportList在JSP…

LeetCode74. 搜索二维矩阵(2024冬季每日一题 6)

给你一个满足下述两条属性的 m x n 整数矩阵: 每行中的整数从左到右按非严格递增顺序排列。每行的第一个整数大于前一行的最后一个整数。 给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false 。…

数据分析24.11.13

Excel 函数 求和 函数 sum() sumif() SUMIF(range, criteria, [sum_range]) sumifs() average() count() max() min() 逻辑 函数 if() iferror() 查询函数 VLOOKUP()

DveOps-Git-版本控制

1. 概述 分布式版本控制系统 版本控制 2. Git极速上手指南 官方传送门:Git - Branching and Merging 2.1 安装 ## windows https: git-scm.com/download/## Linux(CentOS/Fedora/Rocky Linux/RHEL) yum install -y git ## MacOS brew install git## Ubuntu/Debian apt in…

DevOps工程技术价值流:加速业务价值流的落地实践与深度赋能

DevOps的兴起,得益于敏捷软件开发的普及与IT基础设施代码化管理的革新。敏捷宣言虽已解决了研发流程中的诸多挑战,但代码开发仅是漫长价值链的一环,开发前后的诸多问题仍亟待解决。与此同时,虚拟化和云计算技术的飞跃,…

Tensorflow基本概念

简介:本文从Graph讲到Session,同时讲解了tf.constant创建tensor的用法和variable需要初始化的知识点,可以给你打好一个学习Tensorflow的基础。本文都是基于TensorFlow1.14.0的版本下运行。 本专栏将会系统的讲解TensorFlow在1.14.0版本下的各…

【React】响应事件

1.添加事件处理函数 按照如下三个步骤&#xff0c;即可让它在用户点击时显示消息&#xff1a; 在 Button 组件 内部 声明一个名为 handleClick 的函数。实现函数内部的逻辑&#xff08;使用 alert 来显示消息&#xff09;。添加 onClick{handleClick} 到 <button> JSX …

初遇Python-----python/anaconda/PyCharm安装应用问题

作为一名医学生,小编之前从未用过python,一直将R视为数据分析的利器,至于到底R好用还是Python好用,一直是广大网友们争论的热点,小编资历尚浅,对此就不予评价了。最近需要对部分数据进行建模工作,奈何三方工具完全基于python语言编写的,迫不得已小编也只能挠头学习了。本…

基于reads的宏基因组与宏转录组医学分析流程正式上线!

随着生物医学领域的快速发展&#xff0c;宏基因组学和宏转录组学正逐渐成为研究微生物群落及其在人体健康与疾病中作用的关键技术。然而&#xff0c;医学研究样品往往存在微生物含量较低的情况&#xff0c;这给数据分析带来了挑战。为了解决这一难题&#xff0c;并适应不断增长…

使用Aria2实现离线下载

最近有需要BT下载&#xff0c;但有的资源很冷门&#xff0c;速度很慢&#xff0c;总不能一直开着电脑下载&#xff0c;于是想到部署个离线下载。想起之前用雨云服务器拿来部署兰空图床感觉效果不错&#xff0c;发现内存剩的还挺多&#xff0c;所以继续压榨一下&#x1f60f; 提…

第三百二十三节 Java线程教程 - Java同步器

Java线程教程 - Java同步器 同步器对象与一组线程一起使用。 它维护一个状态&#xff0c;根据它的状态&#xff0c;它让一个线程通过或强迫它等待。 本节将讨论四种类型的同步器&#xff1a; SemaphoresBarriersLatchesExchangers 信号量 信号量用于控制可以访问资源的线程…

HTB:Active[WriteUP]

目录 连接至HTB服务器并启动靶机 1.How many SMB shares are shared by the target? 使用nmap对靶机TCP端口进行开放扫描 2.What is the name of the share that allows anonymous read access? 使用smbmap通过SMB服务对匿名用户共享权限情况进行扫描 3.Which file has…

vue3【组件封装】S-icon 图标 ( 集成 iconify )

1. 安装依赖 npm i -D iconify/jsonnpm i --save-dev iconify/vue2. 组件封装 src/components/S-icon.vue <script setup lang"ts"> // 搜索图标 https://icon-sets.iconify.design/ import { Icon } from iconify/vue defineProps({icon: {type: String,requ…

AI视觉小车基础--1.开发前的准备

1. 结束开机大程序 为了能够方便体验小车的APP功能&#xff0c;系统中增加了一个程序&#xff0c;此程序集合了APP的控制功能和玩法&#xff0c;所以称做“大程序”&#xff0c;而且在主板系统开机时&#xff0c;此程序会自动启动&#xff0c;所以称做“开机自启动大程序”。 开…

6.传输层协议、ACL

TCP和UDP协议 TCP/IP协议组的传输层协议 TCP(Transmission Control Protocol ) 传输控制协议 UDP&#xff08;User Datagram Protocol &#xff09; 用户数据报协议 TCP协议 TCP是面向连接的、可靠的进程到进程通信的协议 TCP提供全双工服务&#xff0c;即数据可在同一时间双…