[转]Emmet插件使用方法总结
在前端开发的过程中,一大部分的工作是写 HTML、CSS 代码。特别是手动编写 HTML 代码的时候,效率会特别低下,因为需要敲打很多尖括号,而且很多标签都需要闭合标签等。于是,就有了 Emmet(前身是Zen Coding),它可以极大的提高代码编写的效率,它提供了一种非常简练的语法规则,然后立刻生成对应的 HTML 结构或者 CSS 代码,同时还有多种实用的功能帮助进行前端开发。
一、安装emmet
- ctrl+p(sublime)
- 搜索emmet
- 安装即可
二、快速编写HTML代码
基本语法:
1、生成后代元素:> 大于号表示后面要生成的内容是当前标签的后代
命令:nav>ul>li
<nav> <ul> <li>li> ul>nav>
每个命令输完后按下Tab键即可快速得到代码
2、生成兄弟元素:+ 加号表示后面的元素和前面的元素是兄弟元素
命令:div+p+bq 得到代码如下:
<div>div><p>p><blockquote>blockquote>
3、生成上级元素:^ 表示^后面的元素与^前面的元素的父元素是平级,即兄弟元素。一个^表示提升一个层级,两个提升两级
命令:div+div>p>span+em^bq 得到代码如下:
1 <div>div>2 <div>3 <p><span>span><em>em>p>4 <blockquote>blockquote>5 div>
命令:div+div>p>span+em^^bq 得到代码如下:
<div>div><div> <p><span>span><em>em>p>div><blockquote>blockquote>
4、生成类名: . Emmet 默认的标签为 div ,如果我们不给出标签名称的话,默认就生成 div 标签。Emmet会根据父标签进行判定。比如在
- 中输入.item,就会生成。
命令:.container 得到代码如下:
<div class="container">div>
如果想生成多个类名可连续写
命令: .container.wrapper.more 得到代码如下:
<div class="container wrapper more">div>
5、生成ID:#
命令:#container 得到代码如下:
<div id="container">div>
6、生成分组:() 用括号进行分组,这样可以更加明确要生成的结构,特别是层次关系
命令:(.foo>h1)+(.bar>h2) 得到代码如下:
<div class="foo"> <h1>h1>div><div class="bar"> <h2>h2>div>
7、重复生成多份:* *号后面是想重复生成的份数
命令:ul>li*5 得到代码如下:
<ul> <li>li> <li>li> <li>li> <li>li> <li>li>ul>
8、对生成内容依次编号:$ $就表示一位数字,只出现一个的话,就从1开始。如果出现多个,就从0开始。如果我想生成三位数的序号,那么要写三个$
命令: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>
只能这样单调的生成序号?对于强大的 Emmet 来说,肯定不会了,我们也可以在 $ 后面增加 @- 来实现倒序排列:
命令:ul>li.item$@-*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>li.item$@3*5 得到代码如下:
<ul> <li class="item3">li> <li class="item4">li> <li class="item5">li> <li class="item6">li> <li class="item7">li>ul>
至于ul>li.item$@-3*5 生成什么你们自己琢磨吧!
9、生成自定义属性:[attr] 中括号里面的内容是你想添加的属性
命令:td[rowspan=2 colspan=3 title] 得到代码如下:
<td rowspan="2" colspan="3" title="">td>
10、生成文本内容:{} 大括号里面是你想添加的文本内容
命令:a{Click me} 得到代码如下:
<a href="">Click mea>
命令:p>{Click }+a{here}+{ to continue} 得到代码如下:
<p>Click <a href="">herea>to continuep>
到此为止基本语法内容也就这么多,剩下的就是加强理解与练习了。
注意:在写命令的时候,你可能为了代码的可读性,使用一些空格什么的排版一下,这将会导致代码无法使用。但是{}[]中可存在空格
ul>li.item${item$}*3
<ul> <li class="item1">item1li> <li class="item2">item2li> <li class="item3">item3li>ul>
#content>.article>h1.ok[title=parpername][style=color:#000;]+h3.no[title=subname][style=color:#fff;]+p.words
<div id="content"> <div class="article"> <h1 class="ok" title="papername" style="color:#000;">h1> <h3 class="no" title="subname" style="color:#fff;">h3> <p class="words">p> div>div>
练习的过程中我们可以试着反推出命令行
<div class="header"> <ul class="nav"> <li><a href="" style="block"><span>namespan>a>li> <li><a href="" style="block"><span>namespan>a>li> <li><a href="" style="block"><span>namespan>a>li> <li><a href="" style="block"><span>namespan>a>li> <li><a href="" style="block"><span>namespan>a>li> <li><a href="" style="block"><span>namespan>a>li> ul>div>
<table> <thead> <td class="col1">td> <td class="col2">td> <td class="col3">td> <td class="col4">td> thead> <tbody> <tr class="row01"> <td class="col1">td> tr> <tr class="row02"> <td class="col2">td> tr> <tr class="row03"> <td class="col3">td> tr> tbody> <tfoot> <td>td> <td>td> <td>td> <td>td> <td>td> tfoot>table>
<html><head> <title>title> <style type="text/css">style> <script src="abc1.js" type="text/javascript">script> <script src="abc2.js" type="text/javascript">script> <script src="abc3.js" type="text/javascript">script>head><body> <div class="content"> <div class="nav"> <ul> <li><a href=""><span>span>a>li> ul> div> div> <div class="sidebar"> <div class="top">div> <div class="middle">div> <div class="bottom">div> div> <div class="mian"> <div class="article"> <h1>article1h1> div> <div class="article"> <h1>article2h1> div> <div class="article"> <h1>article3h1> div> div>body><div class="footer">copyrightdiv>html>
这些代码的命令你反推出来了吗?
1.命令:.header>ul.nav>li*6>a[style=block]>span{name}
2.命令:table>(thead>td.col$*4)+(tbody>tr.row$$*3>td.col$)+(tfoot>td*5)
3.命令: html>(head>title+style[type=text/css]+script[type=text/javascript][src=abc$.js]*3)+(body>(.content>.nav>ul>li>a>span)+(.sidebar>.top+.middle+.bottom)+(.mian>.article*3>h1{article$}))+(.footer{copyright})
三、emmet在HTML与CSS中的应用
emmet除了能快速编辑出上面的代码以外,还有一些其他代码也可快速编辑,具体的、全面的快速编辑方式,还请浏览emmet官方文档(有详细说明哦!)
下面只列出一些常用的快速编辑方式
命令:link
<link rel="stylesheet" href="" />
命令:script:src
<script src="">script>
命令:img
<img src="" alt="" />
等等。。。
CSS中缩写
单位:
- p 表示%
- e 表示 em
- r表示 rem
宽度:
命令:w100 结果:width:100px; 默认单位px
命令:w100p 结果:width:100%;
高度:
命令:h100r 结果:height: 100rem;
颜色:
命令:c#3 结果: color: #333;
命令:c#e0 结果: color: #e0e0e0;
命令:c#fc0 结果: color: #ffcc00;
CSS3前缀:
- w 表示 -webkit-
- m 表示 -moz-
- s 表示 -ms-
- o 表示 -o-
命令:-wmso-transform
结果:
-webkit-transform: ;
-moz-transform: ;
-ms-transform: ;
-o-transform: ;
transform: ;
属性模糊匹配:
如果有些缩写你拿不准,Emmet会根据你的输入内容匹配最接近的语法,比如输入ov:h、ov-h、ovh和oh,生成的代码是相同的:
所以在平时使用的时候可留意emmet的提示
命令:h10p+m5e 结果:height: 10%;margin: 5em;
四、定制Emmet插件
- 添加新缩写或更新现有缩写,可修改snippets.json文件
- 更改Emmet过滤器和操作的行为,可修改preferences.json文件
- 定义如何生成HTML或XML代码,可修改syntaxProfiles.json文件
这里都是英文文档,没有英语基础的同学可就有点抓瞎了。
相关链接:http://www.cnblogs.com/jesse131/
---------------------
作者:南珂丶一梦
来源:CNBLOGS
原文:https://www.cnblogs.com/leeke98/p/11208878.html
版权声明:本文为作者原创文章,转载请附上博文链接!