Emmet快速开发
标签元素关系展开
div.wrap>div.content>(div.inner_l+div.inner_r)^div.sider ------缩写展开如下---------------------------------------------- <div class="wrap">
<div class="content">
<div class="inner_l"></div>
<div class="inner_r"></div>
</div>
<div class="sider"></div>
</div>
从这个html代码缩写里面我们可以看到使用了4个符号,分别是:
> 后面代表子元素
+ 后面代表下一个兄弟元素
^ 代表返回父级元素
() 小括号代表代表一个缩写集合
具有特定结构的标签展开
ul+ ------缩写展开如下---------------------------------------------- <ul>
<li></li>
</ul>
这类特定的标签,缩写时在后面添加一个 +(加号),展开时会默认生成其子元素。类似的标签还有 map、dl、ol、table 等。
标签元素添加属性
table[cellpadding=0 cellspacing=0 width=100%] ------缩写展开如下---------------------------------------------- <table cellpadding="0" cellspacing="0" width="100%"></table>
标签元素的属性写在标签后紧跟的中括号内,属性之间用空格隔开,如果某个属性中有空格,那么属性值就需要添加引号。
id 和 class 属性是不需要写在中括号里面的,直接写 #idName 和 .className 就可以了,并且可以写多个 className,如:div#a.b.c
标签元素内添加文本节点
div{我是文本节点}
------缩写展开如下----------------------------------------------
<div>我是文本节点</div>
文本节点写在标签元素后面紧跟的大括号里面,并且,大括号里面可以用 $ 符号写入递增数字。
一些省略标签的展开方式,如:
在行内元素中省略子标签
span>.c
strong>.c
b>.c ------缩写展开如下---------------------------------------------- <span><span class="c"></span></span>
<strong><span class="c"></span></strong>
<b><span class="c"></span></b>
由此可以看出,在行内元素内省略子元素标签,子元素标签就会默认为 span 标签。
后续测试,p 元素默认的子元素也是 span 元素。而 h1-h6 标题标签默认的则是 div 元素,这和div元素的默认子元素是一样的。
因此可以得出一个结论,行内元素和p这个不能插入块元素的标签的默认子元素就是 span 元素。而除特定标签外的块元素默认插入的子元素则是div元素。
生成多个类似元素
ul>li.item-${$}*5
------缩写展开如下----------------------------------------------
<ul>
<li class="item-1">1</li>
<li class="item-2">2</li>
<li class="item-3">3</li>
<li class="item-4">4</li>
<li class="item-5">5</li>
</ul>
我们可以在标签后面添加 *number 来生成我们需要标签的个数,同时还可以使用 $ 来递增改变数字部分,如 class 值中也可以使用这一符号。并且可以同时使用多个 $ 符号,如:
ul>li.item-$$${$$}*5
------缩写展开如下----------------------------------------------
<ul>
<li class="item-001">01</li>
<li class="item-002">02</li>
<li class="item-003">03</li>
<li class="item-004">04</li>
<li class="item-005">05</li>
</ul>
生成多个类似元素,指定递增初始数
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[title]{文本节点}*5
------缩写展开如下----------------------------------------------
<ul>
<li class="item7" title="">文本节点</li>
<li class="item6" title="">文本节点</li>
<li class="item5" title="">文本节点</li>
<li class="item4" title="">文本节点</li>
<li class="item3" title="">文本节点</li>
</ul>
缩写代码后缀
这里只举前端用到的那部分,主要讲到 |e、|c 、|s、|t 这四个后缀
|e 后缀
div.box>div.inner{▪¥×}|e
------缩写展开如下----------------------------------------------
<div class="box">
<div class="inner">▪¥×</div>
</div>
|e 后缀的作用就是将缩写里面的特殊字符转义成字符编码
|c 后缀
div.box>div.inner{▪¥}>div|c
------缩写展开如下----------------------------------------------
<div class="box">
<div class="inner">▪¥
<div></div>
</div>
<!-- /.inner -->
</div>
<!-- /.box -->
|c 后缀的作用就是给每个有 class 或 id 的元素添加结束注释。
|s 后缀
div.box>div.inner{▪¥}|s
------缩写展开如下----------------------------------------------
<div class="box"><div class="inner">▪¥</div></div>
|s 后缀的作用就是将缩写代码在一行中展开。
以上三种后缀可以同时使用多个,可以达到多个效果结合。
|t 后缀
最后来说下 |t 后缀,该后缀和上面其他的后缀有所不同,他使用的主要是给带有数字开头的文本节点包标签,并去掉开始的数字(可以带有小数点或中华线),如:
12-3文本节点1
45-文本节点2
78、文本节点3
7.文本节点4
7,文本节点4
s文本节点4 ------缩写展开如下---------------------------------------------- <ul>
<li>文本节点1</li>
<li>文本节点2</li>
<li>、文本节点3</li>
<li>文本节点4</li>
<li>,文本节点4</li>
<li>s文本节点</li>
</ul>
操作方法是,先选中这段文本,按下 ctrl+shift+g 快捷键(Wrap with Abbreviation),再输入 ul>li*|t 回车,就会展开这个结果了。由此可以看出,|t 可以将这些文本节点前面的数字删除掉。
最后介绍一个自动生成测试文本的代码
自动生成文本节点的代码是 lorem 或 lipsum 字符串,这两个字符串后面可跟一个数字,用于确定生成多少个单词,默认生成30个单词。如:
p>lorem10 或 p>lipsum10 ------缩写展开如下---------------------------------------------- p>lipsum10|e
lorem只能跟在 >(右括号)的后面,表示前一个标签的内容。
如果 lorem 后面还跟着 class 、 id 或 *number,那么就会在父标签里面创建一个默认标签,并未这个标签添加这个 class 或 id ,最后把生成的文本节点放到子标签里面。如:
ul>lorem*5
或
ul>li*5>lorem
------缩写展开如下---------------------------------------------- <ul>
<li>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Saepe, nulla, asperiores quod ea facilis nostrum tempora dolores suscipit odio quasi doloribus nemo provident est deleniti molestias culpa ipsam assumenda! Doloremque.</li>
<li>Eligendi, recusandae vitae tempore deleniti omnis alias distinctio asperiores commodi veritatis obcaecati id totam porro culpa earum rerum voluptatum cupiditate adipisci eos minima nesciunt eius modi repellendus minus eum doloribus?</li>
<li>Aliquam, iure, eaque, accusantium vero modi est quam deserunt rerum minima in quisquam aut culpa odio quasi quibusdam optio pariatur suscipit cumque enim cum placeat quas vitae sed ullam fugiat!</li>
<li>Deleniti, iusto, officia, sunt optio reiciendis error nihil sit amet dolorem debitis perferendis vel quia hic minus obcaecati ducimus consequatur aliquid sapiente at nam dolorum ipsum harum impedit vero tempora!</li>
<li>Dicta earum aspernatur praesentium accusantium nam. Ipsam, ducimus corporis reiciendis laudantium iste consequatur debitis error tempora labore in. Fugit, quos eaque deserunt cupiditate et beatae provident ipsa expedita vel nam.</li>
</ul>
可以到ul>lorem*5和ul>li*5>lorem展开后的代码是一样的。
Emmet官网:http://emmet.io/
Emmet缩写集合:http://docs.emmet.io/cheat-sheet/
Emmet缩写设置-配置文件:http://docs.emmet.io/customization/snippets/
Emmet快速开发的更多相关文章
- 我也来谈谈使用Zen Coding快速开发html和css原理
zen coding 是一种仿css选择器的语法来快速开发html和css的开源项目.现已更名为Emmet.可以到github上下载拜读.在这个都想偷懒的世界里,此方法可以极大的缩短开发人员的开发时间 ...
- arcpy+PyQt+py2exe快速开发桌面端ArcGIS应用程序
前段时间有一个项目,大体是要做一个GIS数据处理工具. 一般的方法是基于ArcObjects来进行开发,因为我对ArcObjects不太熟悉,所以就思考有没有其他简单快速的方法来做. 在查看ArcGI ...
- 快速开发Grunt插件----压缩js模板
前言 Grunt是一款前端构建工具,帮助我们自动化搭建前端工程.它可以实现自动对js.css.html文件的合并.压缩等一些列操作.Grunt有很多插件,每一款插件实现某个功能,你可以通过npm命名去 ...
- winform快速开发平台->让有限的资源创造无限的价值!
最近一直在维护一套自己的快速开发平台. 主要应对针对C/S架构下的项目.然而对winform这快,还真没有看到过相对好的快速开发平台, 何为快速,在博客园逛了了好久, 预览了很多通用权限管理系统. 确 ...
- winform快速开发平台 -> 通用权限管理之动态菜单
这几个月一直忙APP的项目,没来得及更新项目,想想该抽出时间整理一下开发思路,跟大家分享,同时也希望得到宝贵的建议. 先说一下我们的权限管理的的设计思路,首先一个企业信息化管理系统一定会用到权限管理, ...
- winform快速开发平台 -> 工作流组件(仿GooFlow)
对于web方向的工作流,一直在用gooflow对于目前我的winform开发平台却没有较好的工作流组件. 针对目前的项目经验告诉我们.一个工作流控件是很必要的. 当然在winform方面的工作流第三 ...
- winform快速开发平台 -> 快速绑定ComboBox数据控件
通常我们在处理编辑窗体时.往往会遇到数据绑定.例如combobox控件绑定数据字典可能是我们经常用到的.然而在我的winform快速开发平台中我是如何处理这个频繁的操作呢? 首先,我们要绑定combo ...
- winform快速开发平台 -> 基础组件之分页控件
一个项目控件主要由及部分的常用组件,当然本次介绍的是通用分页控件. 处理思想:我们在处理分页过程中主要是针对数据库操作. 一般情况主要是传递一些开始位置,当前页数,和数据总页数以及相关关联的业务逻辑. ...
- 使用GizwitsOpenAPI,快速开发轻应用
导读:使用机智云提供的Open API(Http / WebSocket),可以快速开发网页或微信应用等基于html的轻应用,用于管理和控制智能设备.机智云 Open API 主要帮助开发者通过 HT ...
随机推荐
- PHP中CURL技术模拟登陆抓取网站信息,用与微信公众平台成绩查询
伴随微信的红火,微信公众平台成为许多开发者的下一个目标.笔者本身对于这种新鲜事物没有如此多的吸引力.但是最近有朋友帮忙开发微信公众平台中一个成绩查询的功能.于是便在空余时间研究了一番. 主要的实现步骤 ...
- Spark Streaming揭秘 Day28 在集成开发环境中详解Spark Streaming的运行日志内幕
Spark Streaming揭秘 Day28 在集成开发环境中详解Spark Streaming的运行日志内幕 今天会逐行解析一下SparkStreaming运行的日志,运行的是WordCountO ...
- Spark Streaming揭秘 Day27 Job产生机制
Spark Streaming揭秘 Day27 Job产生机制 今天主要讨论一个问题,就是除了DStream action以外,还有什么地方可以产生Job,这会有助于了解Spark Streaming ...
- AWK 介绍
一.模式和动作 awk脚本是由模式和操作组成的:pattern {action} pattern与{action}两者是可选的.如果没有模式,则action应用到全部记录,如果没有action,则输出 ...
- LM算法
最小二乘法的概念 最小二乘法的目标:求误差的最小平方和,对应有两种:线性和非线性. 线性最小二乘的解是closed-form即x=(A^T A)^{-1}A^Tb, 而非线性最小二乘没有closed- ...
- 【转】perl如何避免脚本在windows中闪一下就关闭
写好了perl程序,运行后,准备等待结果输出时,结果双击后,看到屏幕闪了一下,然后什么都没有了,根本没有机会然你看到输出的结果 当你刚开始学习perl的时候,写好了程序,准备兴高采烈的等待结果输出时, ...
- MySQL 5.6.21 最新版的安装
上一篇 写了对于入门者来说困难的事情,博主最近装了mysql软件,下面来看看mysql的安装. 下载mysql软件安装程序,我的是在百度软件中心上下载的,选择百度是因为里面没有什么捆绑软件: 下载完了 ...
- WCF 傻瓜教程
第一步,新建WCF服务应用程序 第二步,定义接口: 修改接口类,定义你要的方法接口默认文件名:IService1.cs 第三步,实现接口: 在svc文件里实现接口方法,默认文件名:Service1.s ...
- 【socket】一分钟理清 socket udpsocket tcpsocket tcplistener TCPClient和 UDPClient
socket 套接字接口是各种语言tcp udp的网络操作的基础. 直接用socket 对象开发 可以选择 udpsocket 或者 tcpsocket ,两者在使用上仅一些方法和参数不同,所有的底 ...
- EXTJS 4.2 资料 控件之btn设置可否点击
1.下面是一个btn按钮的代码,默认不可以点击 { id: 'skipStep3', disabled: true,//默认不可点击 text: "跳转第三步", handler: ...