HTML/CSS 速写神器:Emmet

在前端开发的过程中,一个最繁琐的工作就是写 HTML、CSS 代码。数量繁多的标签、属性、尖括号、标签闭合等,让前端们甚是苦恼。于是,我向大家推荐 Emmet,它提供了一套非常简单的语法规则,书写起来非常爽快,然后只需要敲一个快捷键就立刻生成对应的 HTML 或 CSS 代码,极大提高了代码书写效率。

Emmet 的前身是大名鼎鼎的 Zen coding,它是一个编辑器插件,需要基于指定的编辑器使用,官方网站提供多编辑器支持,目前它支持的编辑器如下:

请参照上面列表安装对应的编辑器插件,我一般使用 Sublime Text 3,下面就以 Sublime Text 3 插件 为例,讲解 Emmet 的安装、基础语法。

在 Sublime text 3 中安装 Emmet

目前,Emmet 已经可以通过 Package Control 安装了。如果你的 Sublime Text 3 还没有安装 Package Control,请参照以下方法安装,已经安装的童鞋请自行跳过。

为 Sublime Text 3 安装 Package Control 组件:

  1. 按 Ctrl + ` 打开控制台,粘贴以下代码到底部命令行并回车:
1
import urllib.request,os; pf = 'Package Control.sublime-package'; ipp = sublime.installed_packages_path(); urllib.request.install_opener( urllib.request.build_opener( urllib.request.ProxyHandler()) ); open(os.path.join(ipp, pf), 'wb').write(urllib.request.urlopen( 'http://sublime.wbond.net/' + pf.replace(' ','%20')).read())
  1. 重启 Sublime Text 3
  2. 在 Perferences->Package Settings 中看到 Package Control,则表示安装成功

使用 Package Control 安装 Emmet 插件:

  1. 在 Package Control 中选择 Install package 或者按 Ctrl+Shift+P,打开命令板
  2. 输入 pci 然后选择 Install Package
  3. 搜索输入 emmet 找到 Emmet Css Snippets,点击就可以自动完成安装。

快速体验 Emmet

Emmet 可以快速的编写 HTML、CSS 以及实现其他的功能。它根据当前文件的解析模式来判断要使用 HTML 语法还是 CSS 语法来解析。例如当前文件的后缀为 .html 那 Sublime text 3 就会用 HTML 的解析模式来解析高亮这个文件,Emmet 遇到里面的指令就会根据 HTML 的语法把它编译成 HTML 结构。如果是在一个 .c 的 C 语言文件中,你写出来的用于编译 HTML 指令就不会被 Emmet 识别编译。

此外,在没有后缀的文件中,你可以按下shift + ctrl + p呼出面板,输入seth就可以设置当前文件的解析模式为 HTML 。了解这些之后,下面我们来见证强大的 Emmet。

如果让你编写下面的这个 HTML 结构,你需要多长时间?

1
2
3
4
5
6
7
8
9
10
<div id="page">
<div class="logo"></div>
<ul id="navigation">
<li><a href="">Item 1</a></li>
<li><a href="">Item 2</a></li>
<li><a href="">Item 3</a></li>
<li><a href="">Item 4</a></li>
<li><a href="">Item 5</a></li>
</ul>
</div>

然而,这一切你只需要编写下面这一句按照 Emmet 语法写出来的语句,然后用 Emmet 编译一下,就可以生成了!

1
#page>div.logo+ul#navigation>li*5>a{Item $}

我们把它复制到 Sublime text 3 中已经打开的 HTML 文件中,这时候紧跟着敲击一下 TAB 键,见证奇迹的时刻到来了。

怎么样?很神奇吧,仅仅写一行代码,就可以生成这么一个复杂的 HTML 结构,而且还可以生成对应的 class 、id 和有序号的内容。而且 Emmet 的语法很简单,虽然你现在可能还看不懂,后面的系列教程会详细讲解它的语法,你现在只需要知道 Emmet 的工作流程:

打开 HTML 或 CSS 文件->按语法编写指令->按下 TAB 键->生成

快速编写HTML代码

生成 HTML 文档初始结构

HTML文档需要包含一些固定的标签,比如 doctype、html、head、body 以及 meta 等等,现在你只需要1秒钟就可以输入这些标签。比如输入!html:5,然后按 Tab 键:

1
2
3
4
5
6
7
8
9
10
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
< title>Document</title>
</head>
<body>
 
</body>
</html>

这就是一个 HTML5 的标准结构,也是默认的 HTML 结构。如果你想生成 HTML4 的过渡型结构,那么输入指令 html:xt 即可生成如下结构:

1
2
3
4
5
6
7
8
9
10
<!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="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
< title>Document</title>
</head>
<body>
 
</body>
</html>

Emmet 会自动把 doctype 给你补全了,怎么样,这样的功能会不会让你动心?

简单总结一下常用的 HTML 结构指令:

  • html:5 或者 ! 生成 HTML5 结构
  • html:xt 生成 HTML4 过渡型
  • html:4s 生成 HTML4 严格型

生成带有 id 、class 的 HTML 标签

Emmet 默认的标签为 div,如果我们不给出标签名称的话,默认就生成 div 标签。生成 id 为 page 的 div 标签,我们只需要编写下面指令:

1
div#page

或者使用默认标签的方式:

1
#page

如果编写一个 class 为 content 的 p 标签,我们需要编写下面指令:

1
p.content

同时指定标签的 id 和 class,如生成 id 为 navigation,class 为 nav 的 ul 标签:

1
ul#navigation.nav

指定多个 class,如上例中还需要给 ul 指定一个 class 为 dropdown:

1
ul#navigation.nav.dropdown

生成的 HTML 结构如下:

1
2
3
<ul id="navigation" class="nav dropdown">
 
</ul>

兄弟:+

生成标签的兄弟标签,即平级元素,使用指令 + ,例如下面指令:

1
div+ul+bq

生成的 HTML 结构如下:

1
2
3
<div></div>
<ul></ul>
<blockquote></blockquote>

后代:>

> 表示后面要生成的内容是当前标签的后代。例如我要生成一个无序列表,而且被 class 为 nav 的 div 包裹,那么可以使用下面指令:

1
div.nav>ul>li

生成的 HTML 结构如下:

1
2
3
4
5
<div class="nav">
<ul>
<li></li>
</ul>
</div>

上级元素:^

上级 (Climb-up)元素是什么意思呢?前面咱们说过了生成下级元素的符号“>”,当使用 div>ul>li 的指令之后,再继续写下去,那么后续内容都是在 li 下级的。如果我想编写一个跟 ul 平级的 span 标签,那么我需要先用 “^” 提升一下层次。例如:

1
div.nav>ul>li^span

就会生成如下结构:

1
2
3
4
5
6
<div class="nav">
<ul>
<li></li>
</ul>
<span></span>
</div>

如果我想相对与 div 生成一个平级元素,那么就再上升一个层次,多用一个 “^” 符号:

1
div.nav>ul>li<sup></sup>span

结果如下:

1
2
3
4
5
6
<div class="nav">
<ul>
<li></li>
</ul>
</div>
<span></span>

重复多份:*

特别是一个无序列表,ul 下面的 li 肯定不只是一份,通常要生成很多个 li 标签。那么我们可以直接在 li 后面 * 上一些数字:

1
ul>li*5

这样就直接生成五个项目的无序列表了。如果想要生成多份其他结构,方法类似。

分组:()

用括号进行分组,表示一个代码块,分组内部的嵌套和层级关系和分组外部无关,例如:

1
div>(header>ul>li*2>a)+footer>p

生成结构如下:

1
2
3
4
5
6
7
8
9
10
11
<div>
<header>
<ul>
<li><a href=""></a></li>
<li><a href=""></a></li>
</ul>
</header>
<footer>
<p></p>
</footer>
</div>

可以看出整个分组成为 div 的后代,并且分组与 footer 平级。此外,分组还可以很方便的结合上面说的 “*” 符号生成重复结构:

1
(div>dl>(dt+dd)*3)+footer>p

生成结构如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
<div>
<dl>
<dt></dt>
<dd></dd>
<dt></dt>
<dd></dd>
<dt></dt>
<dd></dd>
</dl>
</div>
<footer>
<p></p>
</footer>

属性:[attr]

a 标签中往往需要附带 href 属性和 title 属性,如果我们想生成一个 href 为 “http://bubkoo.com” ,title 为“bubkoo’s blog”的 a 标签,可以这样写:

1
a[href="http://bubkoo.com" title="bubkoo's blog"]

此外,也可以生成一些自定义属性:

1
div[data-title="bubkoo's blog" data-content="CUCKOO USHERS SPRING IN"]

就会生成:

1
2
3
<div data-title="bubkoo's blog" data-content="CUCKOO USHERS SPRING IN">
 
</div>

编号:$

例如无序列表,我想为五个个 li 增加一个 class 属性值 item1 ,然后依次递增从 1-5,那么就需要使用 $ 符号:

1
ul>li.item$*5

结构是:

1
2
3
4
5
6
7
<ul>
<li class="item1"></li>
<li class="item2"></li>
<li class="item3"></li>
<li class="item4"></li>
<li class="item5"></li>
</ul>

$ 表示一位数字,只出现一个的话,就从 1 开始,如果出现多个,就从 0 开始。
如果我想生成三位数的序号,那么要写三个 $

1
ul>li.item$$$*5

输出:

1
2
3
4
5
6
7
<ul>
<li class="item001"></li>
<li class="item002"></li>
<li class="item003"></li>
<li class="item004"></li>
<li class="item005"></li>
</ul>

此外,也可以在 $ 后面增加 @- 来实现倒序排列:

1
ul>li.item$@-*5

输出:

1
2
3
4
5
6
7
<ul>
<li class="item5"></li>
<li class="item4"></li>
<li class="item3"></li>
<li class="item2"></li>
<li class="item1"></li>
</ul>

同时,还可以使用 @N 指定开始的序号:

1
ul>li.item$@3*5

那么输出:

1
2
3
4
5
6
7
<ul>
<li class="item3"></li>
<li class="item4"></li>
<li class="item5"></li>
<li class="item6"></li>
<li class="item7"></li>
</ul>

配合上面倒序输出,可以这样写:

1
ul>li.item$@-3*5

就可以生成以 3 为底倒序列表:

1
2
3
4
5
6
7
<ul>
<li class="item7"></li>
<li class="item6"></li>
<li class="item5"></li>
<li class="item4"></li>
<li class="item3"></li>
</ul>

文本内容:{}

生成超链接一般要加上可点击的文本内容,如上面的连接:

1
a[href="http://bubkoo.com" title="bubkoo's blog"]{猛击这里}

就会生成

1
<a href="http://bubkoo.com" title="bubkoo's blog">猛击这里</a>

另外,在生成内容的时候,特别要注意前后的符号关系,虽然 a>{Click me} 和 a{Click me} 生成的结构是相同的,但是加上其他的内容就不一定了,例如:

1
2
3
4
5
<!-- a{click}+b{here} -->
<a href="">click</a><b>here</b>
 
<!-- a>{click}+b{here} -->
<a href="">click<b>here</b></a>

隐式标签

隐式标签表示 Emmet 可以省略某些标签名,例如,声明一个带类的div,只需输入.item,就会生成<div class="item"></div>。另外,Emmet 还会根据父标签进行判定,例如,在中输入ul>.item$*5,就可以生成:

1
2
3
4
5
6
7
<ul>
<li class="item1"></li>
<li class="item2"></li>
<li class="item3"></li>
<li class="item4"></li>
<li class="item5"></li>
</ul>

下面是所有的隐式标签名称:

  • li:用于 ul 和 ol 中
  • tr:用于 table、tbody、thead 和 tfoot 中
  • td:用于 tr 中
  • option:用于 select 和 optgroup 中

不要有空格

在写指令的时候,你可能为了代码的可读性,使用一些空格什么的排版一下。这就会导致代码无法使用。例如下面这句:

1
2
<!-- a{click}+b{here} -->
(header > ul.nav > li*5) + footer

执行结果会不是你所希望的那样,所以,指令之间不要有空格

HTML 简写规则简单总结

  1. E 代表HTML标签。
  2. E#id 代表id属性。
  3. E.class 代表class属性。
  4. E[attr=foo] 代表某一个特定属性。
  5. E{foo} 代表标签包含的内容是foo。
  6. E>N 代表N是E的子元素。
  7. E+N 代表N是E的同级元素。
  8. E^N 代表N是E的上级元素。

飞一般的 CSS 书写

首先,Sublime Text 3 已经提供了比较强大的 CSS 样式所写方法来提高 CSS 编写效率。例如编写 position: absolute; 这一个属性,我们只需要输入 posa 这四个字母即可。可以在平时书写过程中,留意一下 ST3 提供了哪些属性的缩写方法,这样就可以提高一定的效率了。但是 Emmet 提供了更多的功能,请往下看。

简写属性和属性值

比如要定义元素的宽度,只需输入w100,即可生成:

1
width: 100px;

Emmet 的默认设置 w 是 width 的缩写,后面紧跟的数字就是属性值。默认的属性值单位是 px ,你可以在值的后面紧跟字符生成单位,可以是任意字符。例如,w100foo 会生成:

1
width:100foo;

同样也可以简写属性单位,如果你紧跟属性值后面的字符是 p,那么将会生成:

1
width:100%;

下面是单位别名列表:

  • p 表示%
  • e 表示 em
  • x 表示 ex

像 margin 这样的属性,可能并不是一个属性值,生成多个属性值需要用横杠(-)连接两个属性值,因为 Emmet 的指令中是不允许空格的。例如使用 m10-20 可以生成:

1
margin: 10px 20px;

如果你想生成负值,多加一条横杠即可。例如:m10–20 可以生成:

1
margin: 10px -20px;

需要注意的是,如果你对每个属性都指定了单位,那么不需要使用横杠分割。例如使用 m10e20e 可以生成:

1
margin: 10em 20em;

如果使用了横杠分割,那么属性值就变成负值了。例如使用 m10e-20e 就生成:

1
margin: 10em -20em;

如果你想一次生成多条语句,可以使用 “+” 连接两条语句,例如使用 h10p+m5e 可以生成:

1
2
height: 10%;
margin: 5em;

颜色值也是可以快速生成的,例如 c#3 生成 color: #333;,更复杂一点的,使用 bd5#0s 可以生成 border: 5px #000 solid;

下面是颜色值生成规则:

  • ‘#1’ → #111111
  • ‘#e0’ → #e0e0e0
  • ‘#fc0’ → #ffcc00

生成 !important 这条语句也当然很简单,只需要一个 “!” 就可以了。

附加属性

使用 @f 即可生成 CSS3 中的 font-face 的代码结构:

1
2
3
4
@font-face {
font-family:;
src:url();
}

但是这个结构太简单,不包含一些其他的 font-face 的属性,诸如 background-image、 border-radius、 font、@font-face、 text-outline、 text-shadow 等属性,我们可以在生成的时候输入 “+” 生成增强的结构,例如我们可以输入 @f+ 命令,即可输出选项增强版的 font-face 结构:

1
2
3
4
5
6
7
8
9
10
@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;
}

模糊匹配

如果有些缩写你拿不准,Emmet 会根据你的输入内容匹配最接近的语法,比如输入 ov:h、ov-h、ovh 和 oh,生成的代码是相同的:

1
overflow: hidden;

供应商前缀

CSS3 等现在还没有出正式的 W3C 规范,但是很多浏览器已经实现了对应的功能,仅作为测试只用,所以在属性前面加上自己独特的供应商前缀,不同的浏览器只会识别带有自己规定前缀的样式。然而为了实现兼容性,我们不得不编写大量的冗余代码,而且要加上对应的前缀。使用 Emmet 可以快速生成带有前缀的 CSS3 属性。

在任意字符前面加上一条横杠(-),即可生成该属性的带前缀代码,例如输入 -foo-css,会生成:

1
2
3
4
5
-webkit-foo-css: ;
-moz-foo-css: ;
-ms-foo-css: ;
-o-foo-css: ;
foo-css: ;

虽然 foo-css 并不是什么属性,但是照样可以生成。此外,你还可以详细的控制具体生成哪几个浏览器前缀或者先后顺序,使用 -wm-trf 即可生成:

1
2
3
-webkit-transform: ;
-moz-transform: ;
transform: ;

可想而知,w 就是 webkit 前缀的缩写,m 是 moz 前缀缩写,s 是 ms 前缀缩写,o 就是 opera 浏览器前缀的缩写。如果使用 -osmw-abc 即可生成:

1
2
3
4
5
-o-abc: ;
-ms-abc: ;
-moz-abc: ;
-webkit-abc: ;
abc: ;

渐变背景

CSS3 中新增加了一条属性 linear-gradient 使用这个属性可以直接制作出渐变的效果。但是这个属性的参数比较复杂,而且需要添加实验性前缀,无疑需要生成大量代码。而在 Emmet 中使用 lg() 指令即可快速生成,例如:使用 lg(left, #fff 50%, #000) 可以直接生成:

1
2
3
4
5
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);

附加功能

生成Lorem ipsum文本

Lorem ipsum 指一篇常用于排版设计领域的拉丁文文章,主要目的是测试文章或文字在不同字型、版型下看起来的效果。通过 Emmet,你只需输入 loremlipsum 即可生成这些文字。还可以指定文字的个数,比如 lorem10,将生成:

1
2
 
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插件:

快捷键

  • Ctrl+,
    展开缩写

  • Ctrl+M
    匹配对

  • Ctrl+H
    使用缩写包括

  • Shift+Ctrl+M
    合并行

  • Ctrl+Shift+?
    上一个编辑点

  • Ctrl+Shift+?
    下一个编辑点

  • Ctrl+Shift+?
    定位匹配对

最后

Emmet 的官方 API 列表在这里,有一个图片版本可以【点此下载

参考

前端学习笔记之HTML/CSS 速写神器 Emmet的更多相关文章

  1. 【前端学习笔记】关于CSS通过一个块改变另一个块的样式

    <body><div id="a" style="background:#0F0; height:100px; width:100px;"&g ...

  2. 【前端学习笔记】2015-09-10~~~~ css层叠样式表~~格式

    关于颜色的定义: 有几种方式:1.直接接英文单词   2.#16进制  3.rgb(100%:0%:0%)或者里面写像素,此处百分号不能省略. 加多个属性时,用“;”分开 前面如果是定义标签的样式时, ...

  3. HTML/CSS 速写神器 Emmet语法

    Emmet 是高效.快速编写 HTML 和 CSS 代码的一种插件,如果还不了解,请戳Emmet — the essential toolkit for web-developers,再根据你使用的编 ...

  4. 【前端】Web前端学习笔记【1】

    ... [2015.12.02-2016.02.22]期间的学习笔记. 相关博客: Web前端学习笔记[2] 1. JS中的: (1)continue 语句 (带有或不带标签引用)只能用在循环中. ( ...

  5. Web前端学习笔记(001)

    ....编号    ........类别    ............条目  ................明细....................时间 一.Web前端学习笔记         ...

  6. web前端学习笔记

    web前端学习笔记(CSS盒子的定位) 相对定位 使用相对定位的盒子的位置常以标准流的排版方式为基础,然后使盒子相对于它在原本的标准位置偏移指定的距离.相对定位的盒子仍在标准流中,它后面的盒子仍以标准 ...

  7. 【前端】Web前端学习笔记【2】

    [2016.02.22至今]的学习笔记. 相关博客: Web前端学习笔记[1] 1. this在 JavaScript 中主要有以下五种使用场景 在全局函数调用中,this 绑定全局对象,浏览器环境全 ...

  8. 大前端学习笔记整理【一】CSS盒模型与基于盒模型的6种元素居中方案

    概览 CSS盒模型,规定了元素框来处理元素的 内容.内边距.边框和外边距的方式 元素部分是指内容部分,也是最实际的内容,包围内容的称之为内边距,内边距外围是边框,边框外围就是外边距:且外边距是透明的, ...

  9. 前端学习笔记汇总(之merge方法)

    学习笔记 关于Jquery的merge方法 话不多说,先上图 使用jquery时,其智能提示如上,大概意思就是合并first和second两个数组,得到的结果是first+(second去重后的结果) ...

随机推荐

  1. 报错程序包org.springframework.test.context不存在

    在pom.xml文件中找到 加入了依赖,但是maven update 或者Reimport后 启动还是报错 最后使出绝招: 在maven仓库的位置 找到对应的文件夹 更奇怪了 发现明明有jar包啊! ...

  2. mysql 效率 inner join 与 where in

    -- report 123.77k行 report_loss 620 行 -- inner join ;report_loss 索引 all report 索引 eq_ref ; -- total 0 ...

  3. 《IT项目经理成长手记》

    下载地址: https://download.csdn.net/download/h623691640/9109265 读后感: 曾担任过试用期3个月项目经理,遇到的问题确实如书中所说,几乎有一些是一 ...

  4. java.lang.IllegalArgumentException: Invalid character found in the request target.

    java.lang.IllegalArgumentException: Invalid character found in the request target. http参数存在特殊字符: 特殊字 ...

  5. ThinkPHP如果表名有下划线需要用Model应该怎么做?

    最近遇到一个问题,在用TP做系统的时候,我建立的表是 “tp_admin_user” 但是要用到的模型是 “AdminUserModel.model.class.php”,应该如何做? 解决方法: & ...

  6. 树形DP求各点能走到的最远距离

    hdu2196 Computer Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  7. treeview(树加载)

    数据库结构 id:int类型,主键,自增列:     Name:char类型:     paraid:int类型 窗台拖入控件treeview. 1.版本1 using System; using S ...

  8. pta 习题集 5-15 数组循环左移

    本题要求实现一个对数组进行循环左移的简单函数:一个数组aa中存有nn(>0>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向左移mm(≥0≥0)个位置,即将aa中的数据由(a0a ...

  9. hdu2196 Computer【树形DP】【换根法】

    Computer Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  10. #pragma预处理命令详解

    #pragma预处理命令 #pragma可以说是C++中最复杂的预处理指令了,下面是最常用的几个#pragma指令: #pragma comment(lib,"XXX.lib") ...