Emmet:HTML/CSS代码快速编写神器

article/2025/9/22 10:18:37
Emmet的前身是大名鼎鼎的Zen coding,如果你从事Web前端开发的话,对该插件一定不会陌生。它使用仿CSS选择器的语法来生成代码,大大提高了HTML/CSS代码编写的速度,比如下面的演示: 

 
Zen coding下的编码演示


去年年底,该插件已经改名为Emmet。 但Emmet不只改名,还带来了一些新特性。本文就来直观地演示给你。 

一、快速编写HTML代码 

1.  初始化 

HTML文档需要包含一些固定的标签,比如<html>、<head>、<body>等,现在你只需要1秒钟就可以输入这些标签。比如输入“!”或“html:5”,然后按Tab键: 



  • html:5 或!:用于HTML5文档类型
  • html:xt:用于XHTML过渡文档类型
  • html:4s:用于HTML4严格文档类型
2.  轻松添加类、id、文本和属性 

连续输入元素名称和ID,Emmet会自动为你补全,比如输入p#foo: 



连续输入类和id,比如p.bar#foo,会自动生成: 

Html代码 
  1. <p class="bar" id="foo"></p>  

下面来看看如何定义HTML元素的内容和属性。你可以通过输入h1{foo}和a[href=#],就可以自动生成如下代码:

Html代码 
  1. <h1>foo</h1>  
  2. <a href="#"></a>  



3.  嵌套 

现在你只需要1行代码就可以实现标签的嵌套。 

  • >:子元素符号,表示嵌套的元素
  • +:同级标签符号
  • ^:可以使该符号前的标签提升一行
效果如下图所示: 



4.  分组 

你可以通过嵌套和括号来快速生成一些代码块,比如输入(.foo>h1)+(.bar>h2),会自动生成如下代码: 

Html代码 
  1. <div class="foo">  
  2.   <h1></h1>  
  3. </div>  
  4. <div class="bar">  
  5.   <h2></h2>  
  6. </div>  



5.  隐式标签 

声明一个带类的标签,只需输入div.item,就会生成<div class="item"></div>。 

在过去版本中,可以省略掉div,即输入.item即可生成<div class="item"></div>。现在如果只输入.item,则Emmet会根据父标签进行判定。比如在<ul>中输入.item,就会生成<li class="item"></li>。 



下面是所有的隐式标签名称: 

  • li:用于ul和ol中
  • tr:用于table、tbody、thead和tfoot中
  • td:用于tr中
  • option:用于select和optgroup中
6.  定义多个元素 

要定义多个元素,可以使用*符号。比如,ul>li*3可以生成如下代码: 

Html代码 
  1. <ul>  
  2.   <li></li>  
  3.   <li></li>  
  4.   <li></li>  
  5. </ul>  




7.  定义多个带属性的元素 

如果输入 ul>li.item$*3,将会生成如下代码: 

Html代码 
  1. <ul>  
  2.   <li class="item1"></li>  
  3.   <li class="item2"></li>  
  4.   <li class="item3"></li>  
  5. </ul>  




二、CSS缩写 

1.  值 

比如要定义元素的宽度,只需输入w100,即可生成 

Css代码 
  1. width: 100px;  



除了px,也可以生成其他单位,比如输入h10p+m5e,结果如下: 

Css代码 
  1. height: 10%;  
  2. margin: 5em;  


单位别名列表: 

  • p 表示%
  • e 表示 em
  • x 表示 ex
2.  附加属性 

可能你之前已经了解了一些缩写,比如 @f,可以生成: 

Css代码 
  1. @font-face {  
  2.   font-family:;  
  3.   src:url();  
  4. }  

一些其他的属性,比如background-image、border-radius、font、@font-face,text-outline、text-shadow等额外的选项,可以通过“+”符号来生成,比如输入@f+,将生成: 

Css代码 
  1. @font-face {  
  2.   font-family: 'FontName';  
  3.   src: url('FileName.eot');  
  4.   src: url('FileName.eot?#iefix') format('embedded-opentype'),  
  5.      url('FileName.woff') format('woff'),  
  6.      url('FileName.ttf') format('truetype'),  
  7.      url('FileName.svg#FontName') format('svg');  
  8.   font-style: normal;  
  9.   font-weight: normal;  
  10. }  



3.  模糊匹配 

如果有些缩写你拿不准,Emmet会根据你的输入内容匹配最接近的语法,比如输入ov:h、ov-h、ovh和oh,生成的代码是相同的: 

Css代码 
  1. overflow: hidden;  



4.  供应商前缀 

如果输入非W3C标准的CSS属性,Emmet会自动加上供应商前缀,比如输入trs,则会生成: 

Css代码 
  1. -webkit-transform: ;  
  2. -moz-transform: ;  
  3. -ms-transform: ;  
  4. -o-transform: ;  
  5. transform: ;  



你也可以在任意属性前加上“-”符号,也可以为该属性加上前缀。比如输入-super-foo: 

Css代码 
  1. -webkit-super-foo: ;  
  2. -moz-super-foo: ;  
  3. -ms-super-foo: ;  
  4. -o-super-foo: ;  
  5. super-foo: ;  

如果不希望加上所有前缀,可以使用缩写来指定,比如-wm-trf表示只加上-webkit和-moz前缀: 

Css代码 
  1. -webkit-transform: ;  
  2. -moz-transform: ;  
  3. transform: ;  

前缀缩写如下: 

  • w 表示 -webkit-
  • m 表示 -moz-
  • s 表示 -ms-
  • o 表示 -o-
5.  渐变 

输入lg(left, #fff 50%, #000),会生成如下代码: 

Css代码 
  1. background-image: -webkit-gradient(linear, 0 01000, color-stop(0.5, #fff), to(#000));  
  2. background-image: -webkit-linear-gradient(left, #fff 50%, #000);  
  3. background-image: -moz-linear-gradient(left, #fff 50%, #000);  
  4. background-image: -o-linear-gradient(left, #fff 50%, #000);  
  5. background-image: linear-gradient(left, #fff 50%, #000);  



三、附加功能 

生成Lorem ipsum文本 

Lorem ipsum指一篇常用于排版设计领域的拉丁文文章,主要目的是测试文章或文字在不同字型、版型下看起来的效果。通过Emmet,你只需输入lorem 或 lipsum即可生成这些文字。还可以指定文字的个数,比如lorem10,将生成: 

引用
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Libero delectus.



四、定制 

你还可以定制Emmet插件: 

  • 添加新缩写或更新现有缩写,可修改snippets.json文件
  • 更改Emmet过滤器和操作的行为,可修改preferences.json文件
  • 定义如何生成HTML或XML代码,可修改syntaxProfiles.json文件

五、针对不同编辑器的插件 

Emmet支持的编辑器如下(链接为针对该编辑器的Emmet插件): 

  • Sublime Text 2
  • TextMate 1.x
  • Eclipse/Aptana
  • Coda 1.6 and 2.x
  • Espresso
  • Chocolat (通过“Install Mixin”对话框添加)
  • Komodo Edit/IDE (通过Tools → Add-ons菜单添加)
  • Notepad++
  • PSPad
  • <textarea>
  • CodeMirror2/3
  • Brackets
相关文档: http://docs.emmet.io/(其中包含了一个Demo,你可以试验文中所提到的这些缩写) 

http://chatgpt.dhexx.cn/article/pqb4jtjx.shtml

相关文章

Emmet插件使用方法总结

Emmet插件使用方法总结 在前端开发的过程中&#xff0c;一大部分的工作是写 HTML、CSS 代码。特别是手动编写 HTML 代码的时候&#xff0c;效率会特别低下&#xff0c;因为需要敲打很多尖括号&#xff0c;而且很多标签都需要闭合标签等。于是&#xff0c;就有了 Emmet(前身是Ze…

华硕笔记本安装Ubuntu20.04

前言&#xff1a;由于工作原因&#xff0c;需要使用Ubuntu18以上的版本&#xff0c;因此我干脆一步到位&#xff0c;直接安装Ubuntu20.04&#xff0c;以下是我这两天的魔鬼经历&#xff0c;特此记录&#xff0c;给遇到同样问题的同学做个参考。 一、安装前准备 1.1). 更换笔记…

VMware安装Ubuntu 16.04(完整版图文教程)

VMware安装Ubuntu 16.04 准备工作创建虚拟机打开VMware&#xff0c;点击“创建新的虚拟机”选择自定义安装方式&#xff0c;点击下一步选择兼容性选择稍后安装操作系统&#xff0c;点击下一步选择操作系统&#xff0c;点选“Linux”&#xff0c;版本中找到“Ubuntu 64 位”&…

使用U盘安装Ubuntu20.04

背景 今天自己鼓捣小电脑&#xff0c;卖家发过来的时候已经按要求预装了Ubuntu20.04&#xff0c;我想改一下卖家起的用户名(也许是计算机名&#xff0c;分不太清)&#xff0c;结果搞的电脑输入密码却进不了桌面&#xff0c;最终决定重装系统&#xff0c;记录一下以防以后再有需…

在VMware16虚拟机安装Ubuntu详细教程

在VMware16.2.4安装Ubuntu 一、安装VMware 1.打开VMware Workstation Pro官网&#xff0c;点击即可进入。 2.进入后向下滑动找到Workstation 16 Pro for Windows &#xff0c;点击立即下载。 3.下载完成&#xff0c;文件大小615MB&#xff0c;如下图&#xff1a; 4.鼠标右击…

VMware虚拟机快速安装Ubuntu教程

准备工作 VMware Workstation15 官方下载地址&#xff1a; https://www.vmware.com/cn/products/workstation-pro/workstation-pro-evaluation.html Ubuntu18.04LTS镜像 官方下载地址&#xff1a;https://ubuntu.com/download/desktop 注&#xff1a;VMware Workstation15激活…

Windows系统安装Ubuntu虚拟机

我们在学习过程中经常会用到Linux系统&#xff0c;其中Ubuntu系统是最常用的Linux系统之一&#xff0c;通常的使用方法有3种&#xff1a; 1.抛弃Windows系统&#xff0c;转用Linux系统&#xff1a;缺点是对新手小白不友好&#xff0c;我们大部分常用还是Windows。 2.Windows和L…

Windows安装Ubuntu双系统(Win11+最新Ubuntu22.04.1LTS)

目录 前言 一、查看基础环境 二、准备安装文件 1.下载Ubuntu 22.04.01 LTS镜像ISO文件 2.下载官方推荐的U盘启动制作工具 3.制作启动U盘 4.新建硬盘分区用来安装Ubuntu系统 5.BIOS设置 三、安装Ubuntu 1.准备安装 2.接下来按照Ubuntu系统的提示选择&#xff0c;可…

个人笔记本安装ubuntu系统

个人笔记本安装Ubuntu20.04 LTS 前言一、笔记本配置二、步骤1.UltraISO制作系统盘2.安装显卡驱动2.1禁用安全启动2.1禁用nouveau驱动 3.安装CUDA 总结 前言 由于需要跑深度学习代码&#xff0c;发现linux系统更为合适&#xff0c;所以入坑linux&#xff0c;市面上流行的桌面li…

安装Ubuntu虚拟机

一、安装虚拟机 1、下载 Download VMware Workstation Player | VMware 选择Windows版本下载 2、安装 选择合适的路径&#xff0c;进行安装。 二、安装Ubuntu系统 1、下载 Download Ubuntu Desktop | Download | Ubuntu 2、安装 &#xff08;1&#xff09;创建新的虚…

安装Ubuntu系统

一、参考资料 Windows和Ubuntu双系统安装教程 二、步骤 1. U盘启动&#xff0c;开机按ESC进入BIOS选择U盘启动系统 2. 中文&#xff08;简体&#xff09;&#xff0c;安装Ubuntu 选择【中文&#xff08;简体&#xff09;】&#xff0c;选择【安装Ubuntu】 连接WIFI 选择【其他…

安装Ubuntu14.04教程

** 安装Ubuntu14.04 ** 准备工具 1、下载Ubuntu14.04镜像文件 下载地址http://mirrors.aliyun.com/ubuntu-releases/14.04/ 2、将U盘制作为启动盘 下载win32磁盘影响工具或者大白菜U盘 导入文件&#xff0c;选择设备 //仅读取分配区不用选中 安装 一、更改BIOS 1、一般…

树莓派安装Ubuntu系统

参考&#xff1a;树莓派ubuntu18.04ROS-melodicMAVROSlibrealsenseviorealsense_ros 基础知识&#xff1a; 树莓派支持许多操作系统&#xff0c;包括原生的Raspberry Pi OS&#xff08;Raspbian&#xff09;&#xff0c;但是其无法安装ROS&#xff0c;Mavros等安装包&#xf…

虚拟机安装Ubuntu详解

安装Ubuntu Ubuntu简介 以桌面应用为主的Linux操作系统 Ubuntu是LInux的一个发行版本&#xff0c;特点是具有丰富的应用资源以及庞大的社区力量。 Ubuntu版本 根据Ubuntu发行版本的用途来划分&#xff0c;可分为&#xff1a; Ubuntu桌面版(Ubuntu Desktop) Ubuntu服务器版(U…

U盘安装Ubuntu

在做完相应的准备工作之后&#xff0c;就可以正式开始安装了。 1.进入预装系统 先插入刚刚制作好的启动盘&#xff0c;再按开机&#xff0c;进入Boot menu&#xff0c;选择该U盘。 在这里选择Try Ubuntu&#xff0c;语言建议选择英语。 2 进行一系列的选择 进入系统后&…

wsl安装ubuntu

WSL 用管理员打开powershell wsl --install重启 用管理员打开powershell 启用适用于 Linux 的 Windows 子系统 dism.exe /online /enable-feature /featurename:Microsoft-Windows-Subsystem-Linux /all /norestart dism.exe /online /enable-feature /featurename:Virtual…

ubuntu安装详细步骤

文章目录 前言一、ubuntu是什么&#xff1f;二、安装环境三、安装步骤1.将下载好的iso镜像文件装入磁盘2.启动机器&#xff0c;进入安装界面 前言 作为Linux发行版中的后起之秀&#xff0c;Ubuntu 在短短几年时间里便迅速成长为从Linux初学者到实验室用计算机/服务器都适合使用…

python中read() readline()以及readlines()区别 .

.read() 每次读取整个文件&#xff0c;它通常将读取到底文件内容放到一个字符串变量中&#xff0c;也就是说 .read() 生成文件内容是一个字符串类型&#xff0c;如下图&#xff1b; .readline()每只读取文件的一行&#xff0c;通常也是读取到的一行内容放到一个字符串变量中&am…

java 中readline

https://www.cnblogs.com/dongrilaoxiao/p/6688107.html 小结&#xff0c;使用readLine()一定要注意&#xff1a; 读入的数据要注意有/r或/n或/r/n没有数据时会阻塞&#xff0c;在数据流异常或断开时才会返回null使用socket之类的数据流时&#xff0c;要避免使用readLine()&a…

Python中read()、readline()和readlines()的用法简单案例

首先我们先建立一个测试文件&#xff0c;test.txt 1.read() 用法&#xff1a; 从文件当前位置起读取size个字节&#xff0c;若无参数size&#xff0c;则表示读取至文件结束为止&#xff0c;它范围为字符串对象。 # 打开含中文的文本 fileopen("test.txt",encodingu…