less解决function中return写法在浏览器被识别成Object导致样式失败的问题

问题描述:

一开始写的是:

复制代码
@baseFontSize: 37.5px;//基于屏幕尺寸/10得出的基准font-size

// return失败,浏览器显示为[object Object],[object Object]
.pxToRem(@px){
  @value: @px / @baseFontSize * 1rem;
  @return @value;
}

使用height: .pxToRem(40px);之后浏览器却是这样:

解决方案一、(不使用return,改成属性名称: 属性值的形式)

复制代码
@baseFontSize: 37.5px;//基于屏幕尺寸/10得出的基准font-size

.px2rem(@name, @px){
  @{name}: @px / @baseFontSize * 1rem;
}

使用.px2rem(height, 40px);就正常了:

解决方案二、(使用自定义函数)

复制代码
.remMixin() {
  @functions: ~`(function(){
    var rem = 37.5;
    this.pxToRem = function(size) {
      return (size / rem) + 'rem';
    }
  })()`;
}
.remMixin();

使用:

复制代码
height: ~`pxToRem(40)`;

我的less插件和less-loader版本为 :

复制代码
"less": "3.13.1",
"less-loader": "5.0.0",

代码仓库地址:

命运推手/my_web

相关推荐
露临霜1 小时前
vue实现AI问答Markdown打字机效果
前端·javascript·vue.js·ai·github
愛芳芳2 小时前
springboot+mysql+element-plus+vue完整实现汽车租赁系统
前端·vue.js·spring boot·后端·mysql·elementui·汽车
m0_zj2 小时前
55.[前端开发-前端工程化]Day02-包管理工具npm等
前端·npm·node.js
xcLeigh5 小时前
HTML5好看的水果蔬菜在线商城网站源码系列模板9
java·前端·html5·网页源码
星仔_X5 小时前
硬件加速模式Chrome(Edge)闪屏
前端·chrome·edge
2501_915373885 小时前
使用 Vue + Axios 构建与后端交互的高效接口调用方案
前端·vue.js·交互
莫问alicia7 小时前
react + antd 实现后台管理系统
前端·react.js·前端框架·antd
七灵微9 小时前
ES6入门---第三单元 模块三:async、await
前端·javascript·es6
七灵微12 小时前
ES6入门---第二单元 模块五:模块化
前端·ecmascript·es6
m0_6161884913 小时前
vue3 - keepAlive缓存组件
前端·vue.js·缓存