• 技术文章 >web前端 >css教程

    css3的calc在less编译时如果被计算应该如何解决

    php中世界最好的语言php中世界最好的语言2018-01-30 09:55:07原创1448
    这次给大家带来css3的calc在less编译时如果被计算应该如何解决,解决css3的calc在less编译时如果被计算的注意事项有哪些,下面就是实战案例,一起来看一下。

    对于前端er来说,Less或Sass已经是一项必备的基本技能,有了这个利器,可以省下前端开发者的很多编码时间,让你写CSS如行云流水一般,然后最近我在Less里加入calc时确发现了有点问题,我在Less中这么写:

    div {width : calc(100% - 30px);}

    结果Less把这个当成运算式去执行了,结果给我解析成这样:

    div {width: calc(70%);}

    当时我就郁闷了,怎么会产生这样的现象呢?后来各种查,是由于less的计算方式跟calc方法有重叠,两者在一起有冲突,于是,我在Less中把calc的写法改写成下面这样:

    div {width : calc(~"100% - 30px");}

    OK,解析结果正常: 

    div {width: calc(100% - 30px);}

    然而,把30px替换为一个变量,怎么写呢?

    div {
    @diff : 30px;
    width : calc(~"100% - " + @diff);
    }

    这么写Webstorm没有报错,但grunt-less报错了:

    C:\Users\zhong\WebstormProjects\test>grunt less
    Running "less:development" (less) task
    >> ParseError: Unrecognised input in style.less on line 4, column 2:
    >> 3    @diff : 30px;
    >> 4    width : calc(~"100% - " + @diff);
    >> 5 }
    Warning: Error compiling style.less Use --force to continue.
    Aborted due to warnings.

    于是这么写:

    div {
    @diff : 30px;
    width : calc(~"100% - " @diff);
    }

    顺利编译过去,但Webstorm却老是提示语法错误,虽然也能编译但看着文件有一个错误提示心里老

    感觉不爽,找半天也没发现Webstorm如何调试语法提示错误设置

    于是,改成如下写法:

    div {
    @diff : 30px;
    width : calc(~"100% - @{diff}");
    }

    这种写法又能编译,Webstorm里又不报错,所以我比较喜欢用这种写法,如此,便不会再有任何问题了。

    相信看了这些案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

    相关阅读:

    html5怎样做出图片转圈的动画效果

    在h5里手机端页面缩放应该如何实现

    一定要注意常见的3种HTML5错误用法

    以上就是css3的calc在less编译时如果被计算应该如何解决的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:sass css3 less
    上一篇:CSS使用Grid布局构建网站首页 下一篇:CSS的经典三栏布局如何实现
    php培训_php实战培训【立即报名】-php中文网第20期

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• CSS变量是怎么工作的?如何使用内联CSS变量进行布局?• 一文了解CSS3中的新属性object-view-box• css3怎样实现不是直角的菱形效果• css样式中有文字描边吗• 12个值得收藏的 CSS 技巧!!
    1/1

    PHP中文网