[less] Operation on an invalid type

我这个是升级项目的时候遇到的,要从 scss 升级到 less,然后代码中就报了这个错误

我说一下代码的错误过程,但是这里没有复现,因为我原本报错的代码要复杂很多,而且是公司代码,不方便透露,这是我自己写的,虽然没有复现,但我是这样解决的,大家可以参考一下,如果对 scss 和 less 的混合不熟悉的可以看文章 scss中的@include讲解以及关于scss和less中mixin的应用-CSDN博客

如果不想看过程的,也可以直接看最后的总结错误

在使用 scss 的时候

组件文件:

复制代码
<script setup lang="ts"></script>
<template>
  <div>
    <h1>这个是实验的</h1>
    <div class="one">one</div>
  </div>
</template>

<style lang="scss" scoped>
@import './scss/main.scss';
</style>

在组件文件的同级目录有文件夹 scss,scss文件夹中有两个文件,分别是 mixins.scss 和 main.scss

mixins.scss文件:

复制代码
@mixin trim-minxins(
	$width,
	$number,
	$color
	){
	$height:($number - $width) / 2;
	width: $width;
	height: $height*3;
	background-color: $color;
	}

main.scss文件:

复制代码
@import './mixins.scss';

.one{
	@include trim-minxins(100px,300px,pink)
 }

运行项目,发现没有报错

接下来我们使用less的写法:

组件文件:

复制代码
<script setup lang="ts"></script>
<template>
  <div>
    <h1>这个是实验的</h1>
    <div class="one">one</div>
  </div>
</template>

<style lang="less" scoped>
@import './less/main.less';
</style>

在组件文件的同级目录有文件夹 less,less文件夹中有两个文件,分别是 mixins.less 和 main.less

mixins.less文件:

复制代码
.trim-minxins(
	@width,
	@number,
	@color
	) {
  @height: (@number - @width) / 2;
  width: @width;
  height: @height*3;
  background-color: @color;
}

main.less文件:

复制代码
@import './mixins.less';

.one {
  .trim-minxins(100px,300px,pink);
}

此时运行代码,我的项目代码中就报错了,这里没有报错,但是没有得到我预期的效果

如果我们把mixins.less文件改为如下就好了:

复制代码
.trim-minxins(
	@width,
	@number,
	@color
	) {
  // 下面这行代码相比刚才的加了一个括号
  @height: ((@number - @width) / 2);
  width: @width;
  height: @height*3;
  background-color: @color;
}

总结错误原因:

在scss中,我们使用 除号 / 的时候,不用加上 括号(),但是在less中,我们使用 除号/ 的时候,需要加上 括号(),否则对less的写法就是错的

相关推荐
zhanshuo30 分钟前
不依赖框架,如何用 JS 实现一个完整的前端路由系统
前端·javascript·html
火柴盒zhang31 分钟前
websheet在线电子表格(spreadsheet)在集团型企业财务报表中的应用
前端·html·报表·合并·spreadsheet·websheet·集团财务
khalil33 分钟前
基于 Vue3实现一款简历生成工具
前端·vue.js
拾光拾趣录40 分钟前
浏览器对队头阻塞问题的深度优化策略
前端·浏览器
用户81221993672240 分钟前
[已完结]后端开发必备高阶技能--自研企业级网关组件(Netty+Nacos+Disruptor)
前端
万少1 小时前
2025中了 聊一聊程序员为什么都要做自己的产品
前端·harmonyos
abigale033 小时前
webpack+vite前端构建工具 -11实战中的配置技巧
前端·webpack·node.js
专注API从业者3 小时前
构建淘宝评论监控系统:API 接口开发与实时数据采集教程
大数据·前端·数据库·oracle
Joker`s smile3 小时前
Chrome安装老版本、不同版本,自制便携版本用于前端调试
前端·chrome
weixin_416639973 小时前
爬虫工程师Chrome开发者工具简单介绍
前端·chrome·爬虫