Emmet 是高效、快速编写 HTML 和 CSS 代码的一种插件,若是还不了解,请戳[Emmet — the essential toolkit for web-developers](http://docs.emmet.io/),再根据你使用的编辑器(sublime 或 vim 等)下载对应的 Emmet 插件,让你的代码快步如飞吧。下面我记录下经常使用的 Emmet 语法和快捷键。代码区里的均指在编辑器里输入的字符,而后按 “Tab” 键便会生成代码。css
例如 输入`!` 而后按 “tab” 会获得以下所示的HTML文档初始机构,不再用一个字母一个字母敲了,是否是很简单呢?html
## HTML 编写git
1. 生成HTML文档初始机构github
- `html:5` 或者 `!` 生成 HTML5 结构web
1
2
3
4
5
6
7
8
9
|
<!DOCTYPE html>
< html >
< head >
< meta charset = "UTF-8" >
< title >Document</ title >
</ head >
< body >
</ body >
</ html >
|
- `html:xt` 生成 HTML4 过渡型json
1
2
3
4
5
6
7
8
9
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
< html xmlns = "http://www.w3.org/1999/xhtml" xml:lang = "zh-cmn-Hans" >
< head >
< meta http-equiv = "Content-Type" content = "text/html;charset=UTF-8" >
< title >Document</ title >
</ head >
< body >
</ body >
</ html >
|
- `html:4s` 生成 HTML4 严格型bootstrap
1
2
3
4
5
6
7
8
9
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
< html >
< head >
< meta http-equiv = "Content-Type" content = "text/html;charset=UTF-8" >
< title >Document</ title >
</ head >
< body >
</ body >
</ html >
|
2. 任意一个 html 标签输入都会生成完整的闭合标签。vim
例如输入 `p` 按 `tab` 则 生成:`<p></p>`c#
3. 生成带有 id 、class 的 HTML 标签: `#`为 id,`.` 为 class。sublime-text
例如输入 `div#header.section` 则生成 `<div id="header"></div>`
4. 生成后代:`>`
例如输入`p>span` 则生成 `<p><span></span></p>`
5. 生成兄弟标签:`+`
例如输入`p+div` 则生成 `<p></p><div></div>`
6. 生成上级标签: `^`
例如输入`ul>li>a^div` 则生成
1
2
3
4
|
< ul >
< li >< a href = "" ></ a ></ li >
< div ></ div >
</ ul >
|
也可使用多个 `^`,
例如输入`ul>li>a^^div` 则生成
1
2
3
4
|
< ul >
< li >< a href = "" ></ a ></ li >
</ ul >
< div ></ div >
|
7. 重复生成多个标签 `*`
例如输入`ul>li*5` 则生成
1
2
3
4
5
6
7
|
< ul >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
</ ul >
|
8. 生成分组的标签: `()`
例如输入`ul>(li>a)*5` 则生成
1
2
3
4
5
6
7
|
< ul >
< li >< a href = "" ></ a ></ li >
< li >< a href = "" ></ a ></ li >
< li >< a href = "" ></ a ></ li >
< li >< a href = "" ></ a ></ li >
< li >< a href = "" ></ a ></ li >
</ ul >
|
注意和`ul>li>a*5` 生成是不同的
1
2
3
4
5
6
7
8
9
|
< ul >
< li >
< a href = "" ></ a >
< a href = "" ></ a >
< a href = "" ></ a >
< a href = "" ></ a >
< a href = "" ></ a >
</ li >
</ ul >
|
9. 生成自定义属性:`[]`
例如输入`img[https://octodex.github.com/images/codercat.jpg][alt=octcat]` 则生成
1
|
< img src = "https://octodex.github.com/images/codercat.jpg" alt = "octcat" />
|
10. 生成递增的属性标签等: `$`
例如输入`ul>li.item$*5` 则生成
1
2
3
4
5
6
7
|
< ul >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
</ ul >
|
11. 生成多位递增的呢:`$$$`
例如输入`ul>li.item$$$*5` 则生成
1
2
3
4
5
6
7
|
< ul >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
</ ul >
|
想生成几位输入几个`$`
11. 要生成递减的呢:`@-`
例如输入`ul>li.item$@-*5` 则生成
1
2
3
4
5
6
7
|
< ul >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
</ ul >
|
12. 想要从某个特定的顺序开始呢:`@N`
例如输入`ul>li.item$@10*5` 则生成
1
2
3
4
5
6
7
|
< ul >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
</ ul >
|
13. 逆序生成到某个数:`@-`
例如输入`ul>li.item$@-10*5` 则生成
1
2
3
4
5
6
7
|
< ul >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
< li ></ li >
</ ul >
|
14. 生成文本内容:`{}`
例如输入`p{我是paddingme}` 则生成
1
|
< p >我是paddingme</ p >
|
15. 缺省元素:
- 声明一个带class的div 能够不用输入div;
`.header+.footer` 则生成:
1
2
|
< div ></ div >
< div ></ div >
|
- Emmet 还会根据父标签进行断定
例如输入`ul>.item*3` 则生成:
1
2
3
4
5
|
< ul >
< li ></ li >
< li ></ li >
< li ></ li >
</ ul >
|
下面是全部的隐式标签名称:
- li:用于 ul 和 ol 中
- tr:用于 table、tbody、thead 和 tfoot 中
- td:用于 tr 中
- option:用于 select 和 optgroup 中
首先,Sublime Text3 已经提供了比较强大的 CSS 样式所写方法来提升 CSS 编写效率。例如编写 `position: absolute`; 这一个属性,咱们只须要输入 posa 这四个字母便可。能够在平时书写过程当中,留意一下 ST3 提供了哪些属性的缩写方法,这样就能够提升必定的效率了。可是 Emmet 提供了更多的功能,请往下看。
1. 简写属性和属性值
好比要定义元素的宽度,只需输入w100,便可生成:
```
width: 100px;
```
Emmet 的默认设置 w 是 width 的缩写,后面紧跟的数字就是属性值。默认的属性值单位是 px ,你能够在值的后面紧跟字符生成单位,能够是任意字符。例如,`w100foo` 会生成:
```
width:100foo;
```
一样也能够简写属性单位,若是你紧跟属性值后面的字符是`p`,那么将会生成:
```
width:100%;
```
下面是单位别名列表:
- p 表示%
- e 表示 em
- x 表示 ex
像 margin 这样的属性,可能并非一个属性值,生成多个属性值须要用横杠(-)链接两个属性值,由于 Emmet 的指令中是不容许空格的。例如使用 `m10-20` 能够生成:
```
margin: 10px 20px;
```
若是你想生成负值,多加一条横杠便可。例如:`m10--20` 能够生成:
```
margin: 10px -20px;
```
须要注意的是,若是你对每一个属性都指定了单位,那么不须要使用横杠分割。例如使用 m10e20e 能够生成:
```
margin: 10em 20em;
```
若是使用了横杠分割,那么属性值就变成负值了。例如使用 `m10e-20e` 就生成:
```
margin: 10em -20em;
```
若是你想一次生成多条语句,可使用 “+” 链接两条语句,例如使用 h10p+m5e 能够生成:
```
height: 10%;
margin: 5em;
```
颜色值也是能够快速生成的,例如 `c#3` 生成`color: #333`;,更复杂一点的,使用 `bd5#0s` 能够生成 `border: 5px #000 solid`;。
下面是颜色值生成规则:
- ‘#1’ → #111111
- ‘#e0’ → #e0e0e0
- ‘#fc0’ → #ffcc00
生成 `!important` 这条语句也固然很简单,只须要一个 “!” 就能够了。
2. 附加属性
使用 `@f` 便可生成 CSS3 中的 font-face 的代码结构:
```
@font-face {
font-family:;
src:url();
}
```
可是这个结构太简单,不包含一些其余的 font-face 的属性,诸如 background-image、border-radius、font、@font-face、 text-outline、 text-shadow 等属性,咱们能够在生成的时候输入 “+” 生成加强的结构,例如咱们能够输入 `@f+` 命令,便可输出选项加强版的 font-face 结构:
```
@font-face {
font-family: 'FontName';
src: url('FileName.eot');
src: url('FileName.eot?#iefix') format('embedded-opentype'),
url('FileName.woff') format('woff'),
url('FileName.ttf') format('truetype'),
url('FileName.svg#FontName') format('svg');
font-style: normal;
font-weight: normal;
}
```
3. 模糊匹配
若是有些缩写你拿不许,Emmet 会根据你的输入内容匹配最接近的语法,好比输入 `ov:h`、`ov-h`、`ovh` 和 `oh`,生成的代码是相同的:
```
overflow: hidden;
```
4. 供应商前缀
CSS3 等如今尚未出正式的 W3C 规范,可是不少浏览器已经实现了对应的功能,仅做为测试只用,因此在属性前面加上本身独特的供应商前缀,不一样的浏览器只会识别带有本身规定前缀的样式。然而为了实现兼容性,咱们不得不编写大量的冗余代码,并且要加上对应的前缀。使用 Emmet 能够快速生成带有前缀的 CSS3 属性。
在任意字符前面加上一条横杠(-),便可生成该属性的带前缀代码,例如输入 `-foo-`css,会生成:
```
-webkit-foo-css: ;
-moz-foo-css: ;
-ms-foo-css: ;
-o-foo-css: ;
foo-css: ;
```
虽然 foo-css 并非什么属性,可是照样能够生成。此外,你还能够详细的控制具体生成哪几个浏览器前缀或者前后顺序,使用 `-wm-trf` 便可生成:
```
-webkit-transform: ;
-moz-transform: ;
transform: ;
```
可想而知,w 就是 webkit 前缀的缩写,m 是 moz 前缀缩写,s 是 ms 前缀缩写,o 就是 opera 浏览器前缀的缩写。若是使用 `-osmw-abc` 便可生成:
```
-o-abc: ;
-ms-abc: ;
-moz-abc: ;
-webkit-abc: ;
abc: ;
```
5. 渐变背景
CSS3 中新增长了一条属性 `linear-gradient` 使用这个属性能够直接制做出渐变的效果。可是这个属性的参数比较复杂,并且须要添加实验性前缀,无疑须要生成大量代码。而 在 Emmet 中使用 `lg()`指令便可快速生成,例如:使用 `lg(left,#fff,50%,#000)`能够直接生成:
```
background-image: -webkit-gradient(linear, 0 0, 100% 0, color-stop(0.5, #fff), to(#000));
background-image: -webkit-linear-gradient(left, #fff 50%, #000);
background-image: -moz-linear-gradient(left, #fff 50%, #000);
background-image: -o-linear-gradient(left, #fff 50%, #000);
background-image: linear-gradient(left, #fff 50%, #000);
```
6. 附加功能
生成Lorem ipsum文本
Lorem ipsum 指一篇经常使用于排版设计领域的拉丁文文章,主要目的是测试文章或文字在不一样字型、版型下看起来的效果。经过 Emmet,你只需输入 lorem 或 lipsum 便可生成这些文字。还能够指定文字的个数,好比 `lorem10`,将生成:
```
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Explicabo, esse, provident, nihil laudantium vitae quam natus a earum assumenda ex vel consectetur fugiat eveniet minima veritatis blanditiis molestiae harum est!
```
## 定制
你还能够定制Emmet插件:
- 添加新缩写或更新现有缩写,可修改 snippets.json 文件
- 更改Emmet过滤器和操做的行为,可修改 preferences.json 文件
- 定义如何生成HTML或XML代码,可修改 syntaxProfiles.json 文件
如何自定义 Emmet 语法可参考:<http://qianduanblog.com/post/sublime-text-3-custom-emmet-output-bootstrap-widget.html>;github 上 一丝的 [Emment-plus](https://github.com/yisibl/emmet-plus) 也推荐
## 快捷键
- Ctrl+,: 展开缩写
- Ctrl+M: 匹配对
- Ctrl+H: 使用缩写包括
- Shift+Ctrl+M: 合并行
- Ctrl+Shift+?: 上一个编辑点
- Ctrl+Shift+?: 下一个编辑点
- Ctrl+Shift+?: 定位匹配对
Emmet 的官方 API 列表在[这里](http://docs.emmet.io/cheat-sheet/),有一个图片版本能够[点此下载](http://bubkoo.qiniudn.com/emmet-api.jpg)
CSS 部分转自[HTML/CSS 速写神器:Emmet](http://bubkoo.com/2014/01/04/emmet-a-toolkit-for-improving-html-css-workflow/),由于写着写着发现 bubkoo 差很少给我要写的写完了。因此就摘抄下(不要打我),
其他参考:[Emmet官方文档](http://docs.emmet.io/cheat-sheet/)。