英语是渣渣,想学英语,又不想花钱报培训班。看不懂的文章,还是翻译一下留着自己看吧。

引自   :  https://github.com/bendc/frontend-guidelines

HTML

语义

HTML5提供了语义元素的目的是精确描述的内容很多。确保你的词汇丰富的效益。

<!-- bad -->
<div id="main">
<div class="article">
<div class="header">
<h1>Blog post</h1>
<p>Published: <span>21st Feb, 2015</span></p>
</div>
<p>…</p>
</div>
</div> <!-- good -->
<main>
<article>
<header>
<h1>Blog post</h1>
<p>Published: <time datetime="2015-02-21">21st Feb, 2015</time></p>
</header>
<p>…</p>
</article>
</main>

确保你了解你所使用的元素的语义。更糟糕的是在一个错误的方式使用语义元素比保持中立。

<!-- bad -->
<h1>
<figure>
<img alt=Company src=logo.png>
</figure>
</h1> <!-- good -->
<h1>
<img alt=Company src=logo.png>
</h1>

简洁

保持代码的简洁。忘记你的旧的XHTML的习惯。

<!-- bad -->
<!doctype html>
<html lang=en>
<head>
<meta http-equiv=Content-Type content="text/html; charset=utf-8" />
<title>Contact</title>
<link rel=stylesheet href=style.css type=text/css />
</head>
<body>
<h1>Contact me</h1>
<label>
Email address:
<input type=email placeholder=you@email.com required=required />
</label>
<script src=main.js type=text/javascript></script>
</body>
</html> <!-- good -->
<!doctype html>
<html lang=en>
<meta charset=utf-8>
<title>Contact</title>
<link rel=stylesheet href=style.css> <h1>Contact me</h1>
<label>
Email address:
<input type=email placeholder=you@email.com required>
</label>
<script src=main.js></script>
</html>

(head,body标签都省略掉)

可访问性

可访问性不应该是一个事后的想法。你不一定作为一名 WCAG 专家来优化您的网站,你可以立即开始通过修复小事带来巨大的改变。
例如:

1适当的学习使用alt属性

2确保你的链接和按钮标志等这样标记的(不是<div class=”按钮>暴行)

3不专门依赖于颜色来传达信息

4明确标记的表单控件

<!-- bad -->
<h1><img alt="Logo" src="logo.png"></h1> <!-- good -->
<h1><img alt="My Company, Inc." src="logo.png"></h1>

语言

在定义语言和字符编码是可选的,它的建议总是声明在文档级别的,即使他们在你指定的HTTP头。支持UTF-8字符编码的任何其他。

<!-- bad -->
<!doctype html>
<title>Hello, world.</title> <!-- good -->
<!doctype html>
<html lang=en>
<meta charset=utf-8>
<title>Hello, world.</title>
</html>

性能

除非有一个正当的理由需要在你的内容之前加载脚本,否则不要阻止你的网页的渲染。如果你的样式表内容比较多,就需要在开始的时候延迟加载,在一个单独的样式表里第二次声明加载。两次HTTP请求有一个明显的加载缓慢,但速度感知是最重要的因素。

<!-- bad -->
<!doctype html>
<meta charset=utf-8>
<script src=analytics.js></script>
<title>Hello, world.</title>
<p>...</p> <!-- good-->
<!doctype html>
<meta charset=utf-8>
<title>Hello, world.</title>
<p>...</p>
<script src=analytics.js></script>

CSS

分号

虽然从技术上说是CSS分号分隔,始终把它作为一个终结者。

/* bad */
div {
color: red
} /* good */
div {
color: red;
}

盒模型

盒模型在理想的情况下应该跟整个文档是相同的。通配符* {box-sizing: border-box;}是好的,没有必要的话,就不要在特定的元素上更改默认的盒模型。

/* bad */
div {
width: 100%;
padding: 10px;
box-sizing: border-box;
} /* good */
div {
padding: 10px;
}

没必要的话,就不要更改默认属性。就这样保持元素在正常文档流。例如,去除一张图片下面的白色空间不应该改变它的默认显示:

/* bad */
img {
display: block;
} /* good */
img {
vertical-align: middle;
}

同样,如果你能避免,就不要让文档脱离正常文档流了。(绝对定位 脱离正常文档流)

/* bad */
div {
width: 100px;
position: absolute;
right:;
} /* good */
div {
width: 100px;
margin-left: auto;
}

定位

在css中有很多方法来定位元素。除非你想尝试把自己限制在属性/值下。

按照优先级顺序:

display: block;
display: flex;
position: relative;
position: sticky;
position: absolute;
position: fixed;

选择器

减少选择器与DOM紧密耦合。

当你的选择器超过3个伪类选择器,后代或兄弟选择器的时候, 在你想要匹配的元素上添加一个类选择器。
(那么复杂的翻译真是够了,这句话意思是不要滥用后代、兄弟选择器。超过3个选择器的时候不如考虑给元素加CLASS标签。)
/* bad */
div:first-of-type :last-chid > p ~ * /* good */
div:first-of-type .info
在不必要的情况下,应避免重复添加元素选择器。
/* bad */
img[src$=svg], ul > li:first-child {
opacity:;
} /* good */
[src$=svg], ul > :first-child {
opacity:;
}

不要让值和选择器硬覆盖。减少id的使用,避免!important的使用。

/* bad */
.bar {
color: green !important;
}
.foo {
color: red;
} /* good */
.foo.bar {
color: green;
}
.foo {
color: red;
}

重写

重写样式选择器和调试更加困难了。尽可能的避免。

/* bad */
li {
visibility: hidden;
}
li:first-child {
visibility: visible;
} /* good */
li + li {
visibility: hidden;
}

继承

不重复的样式声明是可以继承的。

/* bad */
div h1, div p {
text-shadow: 0 1px 0 #fff;
} /* good */
div {
text-shadow: 0 1px 0 #fff;
}

简洁

保持代码的简洁。使用速记属性,避免使用多个属性时。

/* bad */
div {
transition: all 1s;
top: 50%;
margin-top: -10px;
padding-top: 5px;
padding-right: 10px;
padding-bottom: 20px;
padding-left: 10px;
} /* good */
div {
transition: 1s;
top: calc(50% - 10px);
padding: 5px 10px 20px;
}

语言

多使用英语而不是数学语言

/* bad */
:nth-child(2n + 1) {
transform: rotate(360deg);
} /* good */
:nth-child(odd) {
transform: rotate(1turn);
}

浏览器私有前缀

积极地干掉过时的浏览器私有前缀前缀,如果需要使用,就在标准属性之前插入。

/* bad */
div {
transform: scale(2);
-webkit-transform: scale(2);
-moz-transform: scale(2);
-ms-transform: scale(2);
transition: 1s;
-webkit-transition: 1s;
-moz-transition: 1s;
-ms-transition: 1s;
} /* good */
div {
-webkit-transform: scale(2);
transform: scale(2);
transition: 1s;
}

动画

避免不透明度和变换的属性进行动画处理。

/* bad */
div:hover {
animation: move 1s forwards;
}
@keyframes move {
100% {
margin-left: 100px;
}
} /* good */
div:hover {
transition: 1s;
transform: translateX(100px);
}

单位

当你可以用没有单位的值。如果你使用相对单位选择rem。喜欢秒超过毫秒。

/* bad */
div {
margin: 0px;
font-size: .9em;
line-height: 22px;
transition: 500ms;
} /* good */
div {
margin:;
font-size: .9rem;
line-height: 1.5;
transition: .5s;
}

颜色

如果需要使用透明的颜色,就用rgba,否则,就使用十六进制格式。

/* bad */
div {
color: hsl(103, 54%, 43%);
} /* good */
div {
color: #5a3;
}

制图

当资源可以用css实现的时候,避免http请求。

/* bad */
div::before {
content: url(white-circle.svg);
} /* good */
div::before {
content: "";
display: block;
width: 20px;
height: 20px;
border-radius: 50%;
background: #fff;
}

Hacks

不使用

/* bad */
div {
// position: relative;
transform: translateZ(0);
} /* good */
div {
/* position: relative; */
will-change: transform;
}

个人翻译水平实在太渣,有问题希望有大神来指点出来,跪谢。。。

前端的指导方针---css篇的更多相关文章

  1. web前端面试试题总结---css篇

    CSS 介绍一下标准的CSS的盒子模型?低版本IE的盒子模型有什么不同的? (1)有两种, IE 盒子模型.W3C 盒子模型: (2)盒模型: 内容(content).填充(padding).边界(m ...

  2. YUI前端优化之javascript,css篇

    三.JavaScript和CSS篇 JavaScript和CSS也是我们页面中经常用到的内容,对它们的优化也提高网站性能的重要方面:CSS:把样式表置于顶部避免使用CSS表达式(Expression) ...

  3. 前端高频面试题 CSS篇

    通过从网上看到的面经,总结的一些高频的前端CSS面试题,有很多不会,于是找资料,并通过代码实现,自己提供了一些参考答案. 目录 1.怎样会产生浮动? 2.如何清除浮动? 3.盒子模型,以及IE和其他浏 ...

  4. 前端开发面试题 — css篇

    1.介绍一下标准的CSS的盒子模型?低版本IE的盒子模型有什么不同的? (1)有两种, IE 盒子模型.W3C 盒子模型: (2)盒模型: 内容(content).填充(padding).边界(mar ...

  5. web前端面试试题总结---html篇

    HTML Doctype作用?标准模式与兼容模式各有什么区别? (1).<!DOCTYPE>声明位于位于HTML文档中的第一行,处于 <html> 标签之前.告知浏览器的解析器 ...

  6. web前端面试试题总结---javascript篇

    JavaScript 介绍js的基本数据类型. Undefined.Null.Boolean.Number.String. ECMAScript 2015 新增:Symbol(创建后独一无二且不可变的 ...

  7. BAT及各大互联网公司2014前端笔试面试题--Html,Css篇

    很多面试题是我自己面试BAT亲身经历碰到的.整理分享出来希望更多的前端er共同进步吧,不仅适用于求职者,对于巩固复习前端基础更是大有裨益. 而更多的题目是我一路以来收集的,也有往年的,答案不确保一定正 ...

  8. 面试题2:BAT及各大互联网公司2014前端笔试面试题:HTML/CSS篇

    BAT及各大互联网公司2014前端笔试面试题:HTML/CSS篇 Html篇: 1.你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么? IE: trident内核 Firefox:gecko内 ...

  9. BAT及各大互联网公司前端笔试面试题--Html,Css篇

    注意 转载须保留原文链接(http://www.cnblogs.com/wzhiq896/p/5931347.html )作者:wangwen896 整理分享出来希望更多的前端er共同进步吧,不仅适用 ...

随机推荐

  1. 【学习笔记】深入理解js原型和闭包(9)—— 简述【执行上下文】下

    继续上一篇文章(https://www.cnblogs.com/lauzhishuai/p/10078231.html)的内容. 上一篇我们讲到在全局环境下的代码段中,执行上下文环境中有如何数据: 变 ...

  2. Verilog设计中的锁存器

    问题: 什么是锁存器? 什么时候出现锁存器? 锁存器对电路有什么影响? 如何在FPGA设计中避免锁存器? 在FPGA设计中应该避免锁存器.实际上,锁存器与D触发器实现的逻辑功能基本相同,都有暂存数据的 ...

  3. 计数器:counter

    组成:2属性,1方法 属性1: counter-reset 命名 属性2: counter-increment 启动/自增 方法 : counter()/counters() 调用方法 1.计数器 命 ...

  4. PE基础1

    PE文件概述 文件格式 .png ..mp4..gif..dll等等,这些文件都具有不同格式 不能随意修改这些文件,否则将无法打开 PE文件(可执行文件) 学习PE文件目标 掌握PE文件就掌握wino ...

  5. Linux之用户权限管理

    chmod(更改目录或文件权限) 在linux中,文件的权限分为3中,拥有者,群组,其他人.而chmod则是对权限更改的命令. u 表示该文件的拥有者,g 表示与该文件的拥有者属于同一个组,o 表示其 ...

  6. log4j.xml 精选的log4j.xml文档,比较详细,网上的版本很多,这个版本相对而言比较完整

    <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE log4j:configuration PUB ...

  7. ubuntu18.04server 真机无法自动获取IP解决方法

    输入命令ip a,查看自己网卡编号,比如我的就是ens33 因为此图为虚拟机搭建的,所以网卡名称为ens33,如果是真机的话则是enp0s**的名字 2.修改netwlpan文件 1 sudo vim ...

  8. delphi 新版数组操作

    https://www.cnblogs.com/xalion/p/4283491.html

  9. Swift详解之NSPredicate

    言:谓词在集合过滤以及CoreData中有着广泛的应用.本文以Playground上的Swift代码为例,讲解如何使用NSPredicate. 准备工作 先在Playground上建立一个数组,为后文 ...

  10. viewport移动端适配,读文笔记

    文章地址: viewport移动端适配 笔记: 移动端适配目的: 希望在屏幕尺寸大小不同的手机上进行访问页面时,页面显示的效果能合理的展示,我们期望的是在手机屏幕较大时显示的内容比较大一些,手机屏幕小 ...