LESS字符串拼接,多出一个空格怎么办?

发布于 2022-09-06 19:48:55 字数 645 浏览 28 评论 0

首先我设置一个function

.generate-font-size(@n, @i: 1) when (@i =< @n) {
    .font-size-@{i} {
        font-size: @i+px;
    }
    .generate-font-size(@n, (@i + 2));
}

然后执行

.generate-font-size(24,12);

结果中字符串拼接中间多了个空格

.font-size-12 {
    font-size: 12 px;
}
.font-size-14 {
    font-size: 14 px;
}
.font-size-16 {
    font-size: 16 px;
}
.font-size-18 {
    font-size: 18 px;
}
.font-size-20 {
    font-size: 20 px;
}
.font-size-22 {
    font-size: 22 px;
}
.font-size-24 {
    font-size: 24 px;
}

要怎么才能去掉空格???

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

白云不回头 2022-09-13 19:48:55
font-size: unit(@i,px)
心的位置 2022-09-13 19:48:55

可以不需要使用 " + " 进行拼接,
使用
font-size: @i * 1px;
或者
font-size: @i + 0px;
就可以了。
向 less 拼接单位之类的可以直接是下面这些方式:
width: @{变量名}+50px;
并不需要这样:width:(@{变量名} + 50) + px;这样就会多出空格。

万人眼中万个我 2022-09-13 19:48:55

解决多个空格的问题可以使用字符串转义函数e(),e()原样返回不带引号的字符串:

.font-size-@{i} {
  font-size: e('@{i}px');
}

或者再更复杂点使用%()格式函数也可以:

.font-size-@{i} {
  font-size: e(%('%dpx',@i));
}

参考less中文网

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文