css进阶问题,CSS进阶指引

你不要觉得CSS没什么重要可言?最近几年他成为一个热门的话题,很多人都在讨论他。CSS并不是一个简单的事情,前端开发者可以使用他将页面制作的更佳漂亮。看得更远一些,我们更关心的是网站的性能以及如何制作出更好的网站。在本文中,我想分享我最近几个月的学到的有关于CSS编码的知识。作为一个程序员,我真正感兴趣的事情是框架(Architectural)部分。我觉得写CSS应该需要去改变,为此我深挖了很多知识。我搜索了好的程序、工作流和原则。这篇文章将带领大家和CSS一起旅行,很多人都说写CSS并不是编程,我就不同意,我说写CSS同样是有趣的,富有挑战性的。

CSS预处理器

让我们一起面对吧,在世界上写CSS并不是一件可笑的事情。CSS预处理器看起来就像CSS,但他更像一个魔术师一样,使用一些魔法会产生有效的CSS代码。这让你的样多和浏览器之间新增加了一层,这样不是更加的糟糕吗?看上去是这样,但事实不是这样的,因为CSS预处理器提供了一些真正有用的特性。

连接(Concatenation)

我认为最有价值的东西是连接你的文件。我相信,你知道使用@import来引用你的.css文件,告诉浏览器获取这个文件。这样做,浏览器需要增加一个请求,这样有点麻烦,因为你可能有很多个这样的文件。增加额外的请求,使你的程序性能变得更低。如果您使用CSS预处理器语言,这个问题将不会存在。他们只会编译你样式文件中单个.css文件。

扩展(Extending)

LESS和Sass是最主要的两个CSS预处理器。我们都支持扩展。虽然他们的工作方式略有不同,但他们的想法是一样的。你可以做一个基本的类(通常称为mixin)和一群属性,然后在另一个选择器导入这些属性,如:

CSS Code复制内容到剪贴板

// less

.bordered(@color:#000) {

border:dotted2px@color;

}

.header { .bordered; }

.footer { .bordered(#BADA55); }

// 编译出来的CSS

.header {

border:dotted2px#000000;

}

.footer {

border:dotted2px#bada55;

}

这里的问题是,如果你没有定义一个参数的mixin,例如刚才的示例:

CSS Code复制内容到剪贴板

.bordered {

border:dotted2px#000;

}

这是最后编译的CSS文件,无论你是否使用都没有任何关系。因为他是一个有效的选择器。在Sass中我们可以做得更灵活一些。他有混合(mixins)、扩展(extends)和占位选择器(placeholders)(如果您想看到他们之间的区别,我强烈建议您阅读这篇文章)。接下来我们简单看看Sass是如何工作和编译的:

CSS Code复制内容到剪贴板

// sass

@mixin bordered($color:#000) {

border:dotted2px$color;

}

.header { @include bordered; }

.footer { @include bordered(#BADA55); }

//编译的CSS

.header {

border:dotted2pxblack;

}

.footer {

border:dotted2px#bada55;

}

它看起来和前面几乎相同,但如果我们秋看第二个placeholder的用例:

CSS Code复制内容到剪贴板

// sass

%bordered {

border:dotted2px#000;

}

.header {

@extend %bordered;

}

.footer {

@extend %bordered;

}

// 编译的CSS

.header, .footer {

border:dotted2px#000;

}

这个有两个优势,首先不会编译出.bordered类名,其次会使用组合选择器,合并相同的样式,使代码变得更加简洁。

配置(Configuration)

LESS和Sass都支持变量,你可以调用这些变量,将将他们作为属性的值:

CSS Code复制内容到剪贴板

// sass

$brand-color:#009f0A;

...

h1 {

color: $brand-color;

}

这是一个很好的特性,因为你可以储存一些重要的东西,比如说颜色或者网格的宽度,将他们存放在同一个地方,如果你需要修改一些不经常改动的代码,会变得非常的简便。

另一个好处理,可以使用变量的插值,如下面演示的方法:

CSS Code复制内容到剪贴板

// sass

@mixinborder($side) {

border-#{$side}:solid1px#000;

}

.header {

@includeborder("left");

}

// 编译的CSS

.header {

border-left:solid1px#000;

}

针对预处理器(Against the preprocessors)

预处理器是一种工具,您要使用得先要有一个适合的环境。如果你思念将其集成到你的应用程序中,也需要额外的编码。

如果你不想让你的代码变得混乱,你需要有一个观察机制,用来监测你的文件。如果这样,你每个项目开始时就需要运行这个监测机制。

通常开发人员只看到.less或.sass文件,但是输出是什么非常重要。你可能有写得很好的Sass代码,但这并不意味着,你最终会有很好的CSS代码。可能会有一些特异性的问题,所以需要定期检测编译的版本。

BEM好的,我找到了一个新的好玩工具。这个预处理器可以节省大量的时间,但他不能为你写出好的结构。首先,我开始考虑是一个命名约定,让我们来看以下的HTML标签:

XML/HTML Code复制内容到剪贴板

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值