Emmet 生成 HTML 的语法

Emmet 使用类似于 CSS 选择器的语法描述元素在生成的文档树中的位置及其属性。

元素

可以使用元素名(如 div 或者 p)来生成 HTML 标签。Emmet 没有预定义的有效元素名的集合,可以把任何单词当作标签来生成和使用:div → <div></div>foo → <foo></foo> 等。

嵌套运算符

嵌套运算符用于以缩写的方式安排元素在生成文档树中的位置:将其放在内部或成为相邻的元素。

子: >

可以使用 > 运算符指定嵌套元素在另一个元素内部:


div>ul>li

生成的结果为:


<div>    <ul>        <li></li>    </ul></div>

兄弟: +

使用 + 运算符将相邻的其它元素处理为同级:


div+p+bq

生成的结果为:


<div></div><p></p><blockquote></blockquote>

上升: ^

使用 > 运算符将会降低所有后续所有元素在生成树中的级别,每一级的兄弟元素也被解析成相同深度的元素:


div+div>p>span+em

将生成:


<div></div><div>    <p><span></span><em></em></p></div>

使用 ^ 运算符,能够提升元素在生成树中的一个级别,并同时影响其后的元素:


div+div>p>span+em^bq

将生成:


<div></div><div>    <p><span></span><em></em></p>    <blockquote></blockquote></div>

可以连续使用多个 ^ 运算符,每次提高一个级别:


div+div>p>span+em^^^bq

将生成:


<div></div><div>    <p><span></span><em></em></p></div><blockquote></blockquote>

重复: *

使用 * 运算符可以定义一组元素:


ul>li*5

将生成:

<ul>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
</ul>

分组: ()

括号用于在复杂的 Emmet 缩写中处理一组子树:


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

将生成:

<div>
    <header>
        <ul>
            <li><a href=""></a></li>
            <li><a href=""></a></li>
        </ul>
    </header>
    <footer>
        <p></p>
    </footer>
</div>

如果想与浏览器 DOM 协同工作,可能想要对文档片段分组:每个组包含一个子树,所有的后续元素都插入到与组中第一个元素相同的级别中。

能够在组中嵌套组并且使用 * 运算符绑定它们:


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

将生成:

<div>
    <dl>
        <dt></dt>
        <dd></dd>
        <dt></dt>
        <dd></dd>
        <dt></dt>
        <dd></dd>
    </dl>
</div>
<footer>
    <p></p>
</footer>

使用分组,可以使用单个缩写逐个写出整页的标签,不过尽量不要这么做。

属性运算符

属性运算符用于编辑所生成的元素的属性,在 HTML 和 XML 中可以快速地为生成元素添加 class 属性。

ID 和 CLASS

在 CSS 中,可以使用 elem#id 和 elem.class 注解来达到为元素指定 id 或 class 属性的目的。在 Emmet 中,可以使用几乎相同的语法来为指定的元素添加这些属性:element:


div#header+div.page+div#footer.class1.class2.class3

生成:


<div id="header"></div><div class="page"></div><div id="footer" class="class1 class2 class3"></div>

自定义属性

可以使用 [attr] 注解(就像在 CSS 中一样)来为元素添加自定义属性:


td[title="Hello world!" colspan=3]

将生成:


<td title="Hello world!" colspan="3"></td>
  • 能够在方括号中放置许多属性,
  • 可以不为属性指定值: td[colspan title] 将生成 <td colspan="" title=""> ,如果你的编辑器支持,可以使用 tab 来跳到每个空属性中填写。
  • 属性可以用单引号或双引号作为定界符。
  • 如果属性不包含空格,不需要用定界符括住它:td[title=hello colspan=3] 是正确的。

编号: $

使用 * 运算符可以重复生成元素,如果带 $ 就可以为它们编号。把 $ 放在元素名、属性名或者属性值中,将为每个元素生成正确的编号:


ul>li.item$*5

将生成:

<ul>
    <li class="item1"></li>
    <li class="item2"></li>
    <li class="item3"></li>
    <li class="item4"></li>
    <li class="item5"></li>
</ul>

使用多 $ 可以填充前导的零:


ul>li.item$$$*5

将生成:

<ul>
    <li class="item001"></li>
    <li class="item002"></li>
    <li class="item003"></li>
    <li class="item004"></li>
    <li class="item005"></li>
</ul>

改变编号的基数和方向

使用 @ ,可以改变数字的走向(升序或降序)和基数(例如起始值)。

在 $ 后添加 @- 来改变数字走向:


ul>[email protected]*5

将生成:

<ul>
    <li class="item5"></li>
    <li class="item4"></li>
    <li class="item3"></li>
    <li class="item2"></li>
    <li class="item1"></li>
</ul>

在 $ 后面添加 @N 改变编号的基数:


ul>[email protected]*5

将生成:

<ul>
    <li class="item3"></li>
    <li class="item4"></li>
    <li class="item5"></li>
    <li class="item6"></li>
    <li class="item7"></li>
</ul>

这些附加的运算符可以同时使用:


ul>[email protected]*5

将生成:

<ul>
    <li class="item7"></li>
    <li class="item6"></li>
    <li class="item5"></li>
    <li class="item4"></li>
    <li class="item3"></li>
</ul>

文本: {}

可以用花括号向元素中添加文本:


a{Click me}

将生成:


<a href="">Click me</a>

注意,这个 {text} 是被当成独立元素解析的(类似于 divp ),但当其跟在其它元素后面时则有所不同。例如, a{click} 和 a>{click} 产生相同的输出,但是 a{click}+b{here} 和 a>{click}+b{here} 的输出就不同了:


<!-- a{click}+b{here} --><a href="">click</a><b>here</b>

<!-- a>{click}+b{here} --><a href="">click<b>here</b></a>

在第二示例中, <b> 元素放在了 <a> 元素的里面。差别如下:当 {text} 写在元素的后面,它不影响父元素的上下文。下面是展示这种差别的重要性的较复杂的例子:


p>{Click }+a{here}+{ to continue}

生成:


<p>Click <a href="">here</a> to continue</p>

在这个例子里, 我们用 > 运算符明确的将 Click here to continue 下移一级,放在 <p> 元素内,但对于 a 元素的内容就不需要了,因为 <a> 仅有 here 这一部分内容,它不改变父元素的上下文。

作为比较,下面是不带有 > 运算符的相同缩写:


p{Click }+a{here}+{ to continue}

生成:


<p>Click </p> <a href="">here</a> to continue

缩写格式的注意事项

当熟悉了 Emmet 的缩写语法后,可能会想要使用一些格式来生成更可读的缩写。例如,在元素和运算符之间使用空格间隔:


(header > ul.nav > li*5) + footer

但是这种写法是错误的,因为空格是 Emmet 停止缩写解析的标识符

请多用户误以为每个缩写都应写在新行上,但是他们错了:可以在文本的任意位置键入和扩展缩写。

(此处原文使用脚本做了一段示例,限于博客的体例,我没有办法将原文的示例脚本放在本文中,因此用截屏工具录下了一段屏幕,放在此处,有兴趣的朋友,可以去原文地址去看原文中的示例)

这也就是为什么当想要停止解析和扩展时,Emmet 需要一些标志的原因。如果你仍然认为复杂的缩写需要一些格式使其更易读:

  • 缩写不是模板语言,它们不需要”易读“,它们必须”可快速扩展和移动“。
  • 不需要写复杂的缩写。不要认为在 web 编程中”键入“是最慢的运算。想快速找出构建单个的复杂缩写比构造和键入一些较短较简单的缩写更慢。
时间: 2024-11-08 11:31:47

Emmet 生成 HTML 的语法的相关文章

使用 Emmet 生成 HTML 的语法详解

生成 HTML 文档初始结构 HTML 文档的初始结构,就是包括 doctype.html.head.body 以及 meta 等内容.你只需要输入一个 "!" 就可以生成一个 HTML5 的标准文档初始结构,你没有看错,输入一个感叹号(当然是英文符号),然后摁下 TAB 键,就会发现生成了下面的结构: <!DOCTYPE html> <html lang="en"> <head> <meta charset="U

【03】emmet系列之CSS语法

[03]CSS语法 单位: 有几个常用值别名: p % e em x ex example: 输入: w100p  输出: width:100% example: 输入: m10p30e5x  输出: margin:10%30em5ex example: 输入: h10p+m5e 输出: height:10%;margin:5em; 颜色值: bd5#0s 输出: border:5px#000 solid 你可以写一个,两个,三个或六个字符的颜色值: #1 #111111 #e0 #e0e0e0

vscode - 更改emmet生成代码

有时候生成的代码,并不适用自己,所以想想改生成代码: 因为windows查找文件/文件内容非常慢,所以借用了一下Linux的搜索命令,查找了一下 ie=edge  ,最后,找到了 expand-full.js  修改过程如下 把名字拷贝一下,然后放入到 用vsCode打开它 原来生成的代码是 后来生成的代码是(chrome=1) 最后重启vscode即可! 原文地址:https://www.cnblogs.com/cisum/p/9382384.html

修改SublimeText3插件Emmet生成HTML中lang属性的默认值

打开Preferences → Package Settings → Emmet → Settings-User,输入如下代码并保存: { "snippets": { "variables": { "lang": "zh-CN" } } } 原文地址:https://www.cnblogs.com/deanjs/p/10512389.html

emmet的使用

http://blog.wpjam.com/m/emmet-grammar/ 使用 Emmet 生成 HTML 的语法详解 开源程序 浏览:21537 2013年05月09日 文章目录[隐藏] 生成 HTML 文档初始结构 生成带有 id .class 的 HTML 标签 生成后代:> 生成兄弟:+ 生成上级元素:^ 重复生成多份:* 生成分组:() 生成自定义属性:[attr] 对生成内容编号:$ 生成文本内容:{} 不要有空格 WPJAM TOC 在上篇文章前端开发神器 Emmet 介绍中,

Emmet 插件使用教程

1)使用 Emmet 生成 HTML 的语法详解生成 HTML 文档初始结构 HTML 文档的初始结构,就是包括 doctype.html.head.body 以及 meta 等内容.你只需要输入一个 “!” 就可以生成一个 HTML5 的标准文档初始结构,你没有看错,输入一个感叹号(当然是英文符号),然后摁下 TAB 键,就会发现生成了下面的结构: <!doctype html> <html lang="en"> <head> <meta c

sulime-text 3 安装以及使用

sublime-text 3 使用了有一段时间了,虽然不是很熟悉,但是已经爱上它了,但是对这个编辑器还是一知半解,所以现在记录下,希望以后能永久的使用这个编辑器. 一,调用 控制台 使用命令 ctrl + ' 或者 View > Show Console 菜单打开控制台 适用于 Sublime Text 3: import  urllib.request,os;pf='Package Control.sublime-package';ipp=sublime.installed_packages_

Emmet语法规则

Emmet插件仿照CSS语法来生成代码,使用emmet语法可以大大提高HTML/CSS代码书写的速度. 下面就来介绍一下Emmet语法到底应该如何书写; 当熟悉了Emmet的缩写语法之后,可能会想一些格式来生成更清晰可读的缩写,例如,在元素和运算符之间使用空格隔开 (header > ul.nav > li*5) + footer 注意:这种写法是错误的,空格是Emmet停止缩写解析的标志符.很多人会误认为每个缩写都应该写在新的一行上,实际上,可以在文本的任意位置输入和扩展缩写. 还有光标定在

Sublime Text插件之Emmet

转载:http://www.w3cplus.com/tools/using-emmet-speed-front-end-web-development.html Emmet插件以前被称作为Zen Coding,是一个文本编辑器的插件,它可以帮助您快速编写HTML和CSS代码,从而加速Web前端开发.早在2009年,Sergey Chikuyonok写过一篇文章,提出编写HTML和CSS的新方法.这一革命性的插件指的就是Zen Coding,经过很多开发者多年来的努力与帮助,现在已达到了一个新的水