LESS 编译报错 pixel or percentage expected 的解决方式

问题描述

在使用 LESS 编写 CSS 样式的过程中,有时候会遇到以下报错信息:

------ ----- -- ---------- -------- -- ---- - -- ---------

这个报错信息的意思是在 LESS 编译的过程中,解析器在某一行代码中遇到了一个不符合要求的单位或者数值类型,例如在需要输入像素或百分比的地方输入了一个字符串或者一个无单位的数值。

这个问题可能会发生在 LESS 编译的过程中的任何一个阶段,例如在使用 lessc 命令行工具编译 LESS 文件,或者在使用 Gulp、Webpack 等构建工具编译 LESS 文件的过程中。

解决方式

检查代码

当遇到这个问题时,首先需要检查代码中是否存在不符合要求的单位或者数值类型。例如,在需要输入像素或百分比的地方输入了一个字符串或者一个无单位的数值。

以下是一些常见的错误示例:

-- --------------------------
---- -
  ------ ----
-

-- -------------------------
---- -
  ------ ------
  ------- ----
-

-- -----------------------
---- -
  ------ ------
  ------- -------
-

在检查代码的过程中,可以使用 LESS 的内置函数 unit() 来获取一个数值的单位,例如:

-- ---------
------- ------
------ ------------- -- ----- --- ----

检查变量

另外,如果在代码中使用了变量,也需要检查变量的值是否符合要求。例如,如果一个变量的值是一个字符串或者一个无单位的数值,那么在使用这个变量的地方也会出现上述报错信息。

以下是一个错误示例:

-- -------------------
----------- -----
------------- --------
----- -
  ----- ---------- -------------
-

在这个示例中,变量 @font-family 的值是一个字符串,因此在使用这个变量的地方也会出现上述报错信息。

使用 calc() 函数

如果在代码中需要进行一些复杂的数学运算,例如计算两个值的和或者差,可以使用 LESS 的内置函数 calc()

calc() 函数可以接收任意的数值或者变量,并且可以进行加、减、乘、除等运算。

以下是一个示例:

-- -- ------ ---------
------- ------
--------- -----
---- -
  ------ ----------- - ----------
-

在这个示例中,使用 calc() 函数计算了变量 @width@padding 的和,并且将结果赋值给了 width 属性。

使用 mixin

如果在代码中需要多次使用相同的数值或者单位,可以考虑使用 LESS 的 mixin。

Mixin 是一种将一组属性集合封装起来,可以在需要的地方进行调用的方式。在 mixin 中可以使用变量、数值或者计算表达式等。

以下是一个示例:

-- ----------- -----
----------------------- ----- ------------- ------ -
  ---------- -----------
  ------------ -------------
  ------ -----
-

-- -- -----
----- -
  ----------------- -------------
-

在这个示例中,定义了一个名为 text-style 的 mixin,包含了三个属性:font-sizefont-familycolor。在使用 mixin 的时候,可以传入不同的参数来改变属性的值。

总结

在使用 LESS 编写 CSS 样式的过程中,遇到 pixel or percentage expected 的报错信息时,首先需要检查代码中是否存在不符合要求的单位或者数值类型。如果代码中使用了变量,也需要检查变量的值是否符合要求。如果需要进行复杂的数学运算,可以使用 LESS 的内置函数 calc()。如果需要多次使用相同的数值或者单位,可以考虑使用 LESS 的 mixin。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/65fcdf71d10417a22283cdef


猜你喜欢

  • 使用 Jest 进行打包工具测试的技巧总结

    在前端开发中,打包工具是不可或缺的一部分。然而,随着打包工具的不断发展和升级,测试打包工具的正确性变得越来越重要。在这篇文章中,我们将介绍如何使用 Jest 进行打包工具测试的技巧总结,包括如何编写测...

    7 个月前
  • SASS 中快速生成多个样式规则代码的方法

    SASS 是一种 CSS 预处理器,它可以让前端开发人员更高效地编写 CSS 代码。在 SASS 中,我们可以使用循环、函数等高级语法,快速生成多个样式规则代码,从而大幅提高开发效率。

    7 个月前
  • 如何保证 Server-sent Events 的稳定可靠

    Server-sent Events(SSE)是一种基于 HTTP 协议的服务器推送技术,它能够在服务器端向客户端推送实时数据,而无需客户端发起请求。SSE 在前端实时数据推送中发挥着重要作用,但是如...

    7 个月前
  • Kubernetes 应用管理

    在现代化的云原生应用开发中,Kubernetes 已经成为了一个非常重要的工具。它可以帮助我们管理容器化的应用程序,提供强大的自动化和伸缩性。在本文中,我们将介绍 Kubernetes 应用管理的基本...

    7 个月前
  • Redis 缓存预热的几种实现方式

    前言 在前端开发中,我们经常需要使用 Redis 缓存来提升应用程序的性能。而在 Redis 缓存中,预热是一种常见的优化方式,它可以在应用程序启动时,将一些热门数据提前加载到 Redis 缓存中,以...

    7 个月前
  • 如何避免在使用 ECMAScript 2015(ES6)时遇到的常见错误

    随着 JavaScript 的发展,ECMAScript 2015(ES6)已经成为了前端开发中必须掌握的技能之一。然而,在学习和使用 ES6 的过程中,我们也会遇到一些常见的错误。

    7 个月前
  • Node.js 中 MySQL 模块安装及使用方法详解

    在 Node.js 中,使用 MySQL 数据库是非常常见的操作。为了方便 Node.js 开发者使用 MySQL 数据库,社区开发了一个 MySQL 模块,可以方便地在 Node.js 中使用 My...

    7 个月前
  • 使用 JMeter 测试 Java Web 应用程序性能

    什么是 JMeter JMeter 是一个功能强大的开源性能测试工具,它可以模拟高负载的用户访问,测试 Web 应用程序的性能、负载、并发等指标。JMeter 可以测试多种应用程序,包括 Web 应用...

    7 个月前
  • Vue.js 中的父子组件通信详解

    在 Vue.js 中,组件是构建用户界面的基本单元,而组件之间的通信则是非常重要的一部分。在父子组件通信中,父组件可以向子组件传递数据,而子组件也可以向父组件传递数据。

    7 个月前
  • 解决 React 项目中兼容性问题的方法

    React 是一款非常流行的前端框架,它可以帮助我们快速构建高效的用户界面。然而,由于不同的浏览器和设备之间存在差异,React 项目的兼容性问题也是不可避免的。在本文中,我们将探讨一些解决 Reac...

    7 个月前
  • 详解 CSS Reset 常见使用技巧

    什么是 CSS Reset? CSS Reset 是一种常见的前端开发技术,它的作用是在不同浏览器之间建立统一的样式基础。由于不同浏览器对 HTML 元素的默认样式有所不同,因此在进行前端开发时,我们...

    7 个月前
  • PM2 异常处理:如何处理 PM2 进程中出现的异常?

    在前端开发中,我们经常会使用 PM2 来管理 Node.js 进程。不过,有时候我们的进程会出现异常,这时候就需要对异常进行处理。本文将介绍如何在 PM2 中处理进程异常,以及如何避免出现异常。

    7 个月前
  • 如何在 Chai 中进行模糊相等比较

    在前端开发中,我们经常需要进行比较操作。而在测试过程中,常常需要对比较的结果进行模糊相等比较。这时候,Chai 是一个非常好用的工具。本文将介绍如何在 Chai 中进行模糊相等比较。

    7 个月前
  • Enzyme 测试 React 组件时如何模拟用户输入

    Enzyme 测试 React 组件时如何模拟用户输入 在 React 的开发中,测试是一个非常重要的环节。而 Enzyme 是一个非常好用的 React 组件测试工具,它可以帮助我们轻松地测试 Re...

    7 个月前
  • AngularJS: 如何处理带参数的 URL

    在前端开发中,处理 URL 参数是一个常见的任务。在 AngularJS 中,我们可以使用 $routeParams 服务来方便地获取 URL 参数。本文将介绍如何在 AngularJS 中处理带参数...

    7 个月前
  • 使用 HTML5 History API 实现 SPA 页面路由

    单页应用(SPA)是一种流行的 Web 应用程序开发模式,它能够提供更好的用户体验和更快的页面加载速度。SPA 通常使用 AJAX 和 JavaScript 动态更新页面内容,而不是在每个页面之间进行...

    7 个月前
  • RESTful API 中的数据格式规范

    RESTful API 是一种基于 HTTP 协议的 API 设计风格,它通过统一的 URI 和 HTTP 方法来实现资源的访问和操作。在 RESTful API 中,数据格式规范是非常重要的一环,它...

    7 个月前
  • Mongoose 实现数据分组查询的方法详解

    Mongoose 是一个优秀的 Node.js ORM 框架,它可以帮助我们更方便地操作 MongoDB 数据库。在实际开发中,我们经常需要对数据库中的数据进行分组查询,以便更好地了解数据的分布情况和...

    7 个月前
  • Socket.io 解决 WebSocket 连接不稳定和断开问题的方法

    在前端开发中,WebSocket 是一个非常重要的技术,它可以实现实时通信,但是在使用过程中,我们可能会遇到连接不稳定或者断开的问题,这时候我们可以使用 Socket.io 来解决这些问题。

    7 个月前
  • 解决 Android Material Design NavigationView 控件滑动卡顿的问题

    在 Android Material Design 中,NavigationView 是一个常用的侧滑菜单控件。它具有良好的交互性和美观的设计,但在实际使用中,我们可能会遇到滑动卡顿的问题,影响用户体...

    7 个月前

相关推荐

    暂无文章