HTML速写之Emmet语法规则的实现


Posted in HTML / CSS onApril 07, 2021

在前端开发的过程中,最费时间的工作就是写 HTML、CSS 代码。一堆的标签、属性、括号等,头疼。这里推荐一个Emmet语法规则,让你写的时候爽到飞起,能大大提高代码书写,只需要敲一行代码就能生成你想要的完整HTML结构,下面会介绍如何使用。

Emmet是一款插件,只要能安装他的编辑器都能使用,大部分编辑器都可以使用该语法规则,我们平时开发的Sublime TextEclipseNotepad++VS codeAtomDreamweaver等等编辑器都可以使用。

安装方式和平时安装插件一样搜索这个emmet插件安装,每个编辑器安装方式不同,请各自尝试

先来个例子:

HTML速写之Emmet语法规则的实现

这个普通的HTML结构,你需要多久打出来呢?
我只需要几秒钟,写好下面这条语句,按下键盘Tab键即可看到上图中的结构了

div#box>p.title+ul.list>li.child${我是第$个}*3^div#box2

是不是很爽,很快~~啊 ~ 啊~,仅仅一行代码就生成了一个复杂的HTML结构,并且id,class,内容都对应的上

开始讲解语法吧

1:html初始结构

下图中的结构,偷懒的都会直接一个!=> Tab 解决,这样可以快速生成基础的结构,同时防止手写时忘记某个代码块,输入错误的代码。

HTML速写之Emmet语法规则的实现

2:id(#),class(.)

id指令:# ; class指令:.

div#test

<div id="test"></div>

div.test

<div class="test"></div>

3:子节点(>),兄弟节点(+),上级节点(^)

子节点指令:> ; 兄弟节点指令:+ ; 上级节点:^

div>ul>li>p

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

div+ul+p

<div></div>
<ul></ul>
<p></p>

div>ul>li^div (这里的^是接在li后面所以在li的上一级,与ul成了兄弟关系,当然两个^^就是上上级)

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

4:重复(*)

重复指令:*

div*5(*号后面添加数字表示重复的元素个数

<div></div>
   <div></div>
   <div></div>
   <div></div>
   <div></div>

5:分组(())

分组指令:()

div>(ul>li>a)+div>p
括号里面的内容为一个代码块,表示与括号内部嵌套和外面的的层级无关

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

解释:这里如果不加括号的话,猜想下,a+div这样div就是和a是兄弟关系了,会包含在li里面。懂了吧哈哈

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

6:属性([attr])——id,class都有怎么能少了属性呢

属性指令:[]

a[href=’###’ name=‘xiaoA’] (中括号内填写属性键值对的形式,并且空格隔开

<a href="###" name="xiaoA"></a>

###6:编号($)
编号指令:$

ul>li.test$*3 ($代表一位数,后面更上*数字就代表从1递增到填写的数字

<ul>
   <li class="test1"></li>
   <li class="test2"></li>
   <li class="test3"></li>
 </ul>

注意

一个$ 代表一位数,$$就是两位数了,以此类推就可以形成$(1),$$(01),$$$(001)

如果想自定义从几开始递增的话就利用:$@+数字*数字
例如:ul>li*3.test$@3

<ul>
   <li class="test3"></li>
   <li class="test4"></li>
   <li class="test5"></li>
 </ul>

7:文本({})

文本指令:{}

ul>li.test$*3{测试$} ({里面填写内容,可以和$一起组合使用哦}

<ul>
  <li class="test1">测试1</li>
  <li class="test2">测试2</li>
  <li class="test3">测试3</li>
</ul>

8:隐式标签

这个标签没有指令,而是部分标签可以不使用输入标签,直接输入指令,即可识别父类标签。

例如:.test

<div class="test"></div>

例如:ul>.test$*3

<ul>
   <li class="test1"></li>
   <li class="test2"></li>
   <li class="test3"></li>
 </ul>

例如:select>.test$*5

<select name="" id="">
  <option class="test1"></option>
  <option class="test2"></option>
  <option class="test3"></option>
  <option class="test4"></option>
  <option class="test5"></option>
</select>

等等…
隐私标签有如下几个:

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

最后就是:看没用,操作几遍,几分钟你就能掌握这些指令,然后飞快的撸码

到此这篇关于HTML速写之Emmet语法规则的实现的文章就介绍到这了,更多相关HTML Emmet语法内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

 
HTML / CSS 相关文章推荐
详解Css3新特性应用之过渡与动画
Jan 10 HTML / CSS
基于css3实现漂亮便签样式
Mar 18 HTML / CSS
纯CSS3实现手风琴风格菜单具体步骤
May 06 HTML / CSS
CSS3中:nth-child和:nth-of-type的区别深入理解
Mar 10 HTML / CSS
css3 条纹化和透明化表格Firefox下测试成功
Apr 15 HTML / CSS
纯css3实现走马灯效果
Dec 26 HTML / CSS
详解CSS3的图层阴影和文字阴影效果使用
Jun 09 HTML / CSS
css3实现蒙版弹幕功能
Jun 18 HTML / CSS
CSS3实现酷炫的3D旋转透视效果
Nov 21 HTML / CSS
html5 canvas-2.用canvas制作一个猜字母的小游戏
Jan 07 HTML / CSS
Html5监听手机摇一摇事件的实现
Nov 07 HTML / CSS
清除canvas画布内容(点擦除+线擦除)
Aug 12 HTML / CSS
使用Html+Css实现简易导航栏功能(导航栏遇到鼠标切换背景颜色)
Apr 07 #HTML / CSS
html+css 实现简易导航栏功能
Apr 07 #HTML / CSS
css3实现的加载动画效果
CSS3 天气图标动画效果
CSS3 制作精美的定价表
CSS 圆形进度栏
CSS 文字装饰 text-decoration & text-emphasis 详解
You might like
zend framework中使用memcache的方法
2016/03/04 PHP
PHP pthreads v3下同步处理synchronized用法示例
2020/02/21 PHP
基于jQuery判断两个元素是否有重叠部分的代码
2012/07/25 Javascript
Javascript 多物体运动的实现
2014/12/24 Javascript
chrome浏览器当表单自动填充时如何去除浏览器自动添加的默认样式
2015/10/09 Javascript
牛叉的Jquery——Jquery与DOM对象的互相转换及DOM的三种操作
2015/10/29 Javascript
再次谈论React.js实现原生js拖拽效果引起的一系列问题
2016/04/03 Javascript
jquery获取img的src值的简单实例
2016/05/17 Javascript
详解堆的javascript实现方法
2016/11/29 Javascript
canvas的神奇用法
2017/02/03 Javascript
使用Vue.js开发微信小程序开源框架mpvue解析
2018/03/20 Javascript
vue实例中data使用return包裹的方法
2018/08/27 Javascript
解决VUE双向绑定失效的问题
2019/10/29 Javascript
通过实例了解Nodejs模块系统及require机制
2020/07/16 NodeJs
微信小程序开发数据缓存基础知识辨析及运用实例详解
2020/11/06 Javascript
python使用multiprocessing模块实现带回调函数的异步调用方法
2015/04/18 Python
python 计算两个日期相差多少个月实例代码
2017/05/24 Python
python实现简单中文词频统计示例
2017/11/08 Python
Python实现迭代时使用索引的方法示例
2018/06/05 Python
PyCharm在新窗口打开项目的方法
2019/01/17 Python
tensorflow实现训练变量checkpoint的保存与读取
2020/02/10 Python
详解python环境安装selenium和手动下载安装selenium的方法
2020/03/17 Python
python中如何设置代码自动提示
2020/07/15 Python
仿酷狗html5手机音乐播放器主要部分代码
2013/05/15 HTML / CSS
C#的几个面试问题
2016/05/22 面试题
vue+django实现下载文件的示例
2021/03/24 Vue.js
旅游管理专业个人求职信范文
2013/12/24 职场文书
医药工作岗位求职信分享
2013/12/31 职场文书
汽车专业学生自我评价
2014/01/19 职场文书
领导班子对照检查剖析材料
2014/10/13 职场文书
乡镇防汛工作汇报
2014/10/28 职场文书
酒店办公室主任岗位职责
2015/04/01 职场文书
Go语言 go程释放操作(退出/销毁)
2021/04/30 Golang
Linux、ubuntu系统下查看显卡型号、显卡信息详解
2022/04/07 Servers
git中cherry-pick命令的使用教程
2022/06/25 Servers
Redis过期数据是否会被立马删除
2022/07/23 Redis