网站首页 > 开源技术 正文
作为一名前端开发人员,最为繁琐的就是手写HTML与CSS代码,特别是手动编写 HTML 代码的时候,效率会特别低下,因为需要敲打很多尖括号,而且很多标签都需要闭合标签等。于是,就有了 Emmet(前身是Zen Coding),它可以极大的提高代码编写的效率,它提供了一种非常简练的语法规则,然后立刻生成对应的 HTML 结构或者 CSS 代码,同时还有多种实用的功能帮助进行前端开发。
下载地址:
http://emmet.io/download/
Emmet支持大部分文档编辑器和IDE,
Emmet使用特殊的表达式Abbreviations,也就是缩写:这种特殊的表达式会被Emmet解析并转义成结构化的代码块。Emmet使用类似CSS选择器的语法来描述元素在DOM树节点的位置和属性。
例如:
ul#nav>li.item$*4>a{Item $}
会被转义成
<ul id="nav"> <li class="item1"><a href="">Item 1</a></li> <li class="item2"><a href="">Item 2</a></li> <li class="item3"><a href="">Item 3</a></li> <li class="item4"><a href="">Item 4</a></li> </ul>
这样就看到了 emmet的强大之处了吧。
HTML 元素
在Emmet中可以使用元素名例如 div 或 p 生成HTML标签。Emmet没有预设任何标签名,所以可以使用任何可用名称来生成HTML标签:div → <div></div> 或 foo → <foo></foo>
嵌套操作符
嵌套操作用来生成元素的DOM树中的兄弟节点或子节点,使用 > 生成元素子节点。
div>ul>li
会被转义成
<div> <ul> <li></li> </ul> </div>
Sibling: +
使用 + 生成元素兄弟节点。
div+p+bq
会被转义成
<div></div> <p></p> <blockquote></blockquote>
Climb-up: ^
使用 ^ 在元素父节点生成新的元素节点
操作符 ^ 的作用和 > 刚好相反
用 > 可以在子级生成新的节点
div+div>p>span+em
会被转义成
<div></div> <div> <p><span></span><em></em></p> <blockquote></blockquote> </div>
用n个 ^ ,就可以在第n父级生成新的节点
div+div>p>span+em^^^bq
会被转义成
<div></div> <div> <p><span></span><em></em></p> </div> <blockquote></blockquote>
Multiplication: *
使用 * 生成多个相同元素
ul>li*5
会被转义成
<ul> <li></li> <li></li> <li></li> <li></li> <li></li> </ul>
属性操作符
属性操作符用来修改元素的属性
ID 和 CLASS
Emmet给元素添加ID和CLASS的方法和CSS的语法类似
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>
元素编号
使用 $ 操作符可以对重复元素进行有序编号
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>
文本操作符
Emmet使用 Text:{} 给元素添加文本内容
a{Click me}
会被转义为
<a href="">Click me</a>
注意: {text} 在Emmet中是被当成单独的元素来解析的,但当和其他元素结合使用时会有特殊的含义
例如:
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>
在 a>{click}+b{here} 中, <b> 元素是<a>元素的子节点。这个就是区别:当 {text} 直接写在元素后面时,并不会改变父元素的上下文。
最后,先介绍这么多,emmet的一些其他功能大家自行去看官方文档。
猜你喜欢
- 2024-10-15 Emmet在Intelli idea中的应用(empty test suite idea)
- 2024-10-15 WEB前端工具vscode中Tasks及Emmet的应用
- 2024-10-15 生前演破200部电影!美国男星艾密特沃许心脏骤停逝 享寿88岁
- 2024-10-15 四款被误认为是外国人研发的办公软件,却不被国人所熟悉
- 2024-10-15 今日福利:Emmet 标点方法应用表(标点符号tm)
- 2024-10-15 Emmet 如何提高自己的开发效率(emmet)
- 2024-10-15 前端开发神器Emmet,让你的代码输入效率瞬间翻倍
- 2024-07-08 关于Emmet编辑器插件的详解(emmet插件有什么用)
- 2024-07-08 超现实主义虚拟形象帮助初创企业进入《美国达人秀》决赛
- 2024-07-08 被认为是外国佬研发的四款良心软件,个个都是黑科技
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)