Emmet插件使用方法总结

article/2025/9/22 10:40:56

Emmet插件使用方法总结

      在前端开发的过程中,一大部分的工作是写 HTML、CSS 代码。特别是手动编写 HTML 代码的时候,效率会特别低下,因为需要敲打很多尖括号,而且很多标签都需要闭合标签等。于是,就有了 Emmet(前身是Zen Coding),它可以极大的提高代码编写的效率,它提供了一种非常简练的语法规则,然后立刻生成对应的 HTML 结构或者 CSS 代码,同时还有多种实用的功能帮助进行前端开发。

一、安装emmet:packages安装

下面方法适用于 sublime text 3。

1、安装 Package ctrl: 使用 ctrl + ~ 打开控制台,输入以下代码:

import urllib.request,os; pf = 'Package Control.sublime-package'; ipp = sublime.installed_packages_path(); urllib.request.install_opener(urllib.request.build_opener( urllib.request.ProxyHandler()) ); open(os.path.join(ipp, pf), 'wb').write(urllib.request.urlopen('http://sublime.wbond.net/' + pf.replace(' ','%20')).read())

2、在 Package ctrl 中选择 Install package;

3、搜索 emmet 并安装。

二、快速编写HTML代码 

先来看一下这个插件的效果,

新建一个HTML文档,输入“!”或“html:5”,然后按Tab键

基本语法:

1、生成后代元素:>      大于号表示后面要生成的内容是当前标签的后代

命令:nav>ul>li 

每个命令输完后按下Tab键即可快速得到代码

<nav><ul><li></li></ul>
</nav>

2、生成兄弟元素:+     加号表示后面的元素和前面的元素是兄弟元素

命令:div+p+bq   得到代码如下:

<div></div>
<p></p>
<blockquote></blockquote>

3、生成上级元素:^   表示^后面的元素与^前面的元素的父元素是平级,即兄弟元素。一个^表示提升一个层级,两个提升两级

命令:div+div>p>span+em^bq  得到代码如下:

<div></div>
<div><p><span></span><em></em></p><blockquote></blockquote>
</div>

命令:div+div>p>span+em^^bq  得到代码如下:

<div></div>
<div><p><span></span><em></em></p>
</div>
<blockquote></blockquote>

4、生成类名: .    Emmet 默认的标签为 div ,如果我们不给出标签名称的话,默认就生成 div 标签。Emmet会根据父标签进行判定。比如在<ul>中输入.item,就会生成<li class="item"></li>。 

命令:.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 me</a>

命令:p>{Click }+a{here}+{ to continue}  得到代码如下:

<p>Click <a href="">here</a>to continue</p>

到此为止基本语法内容也就这么多,剩下的就是加强理解与练习了。

注意:在写命令的时候,你可能为了代码的可读性,使用一些空格什么的排版一下,这将会导致代码无法使用。但是{}[]中可存在空格

ul>li.item${item$}*3

    <ul><li class="item1">item1</li><li class="item2">item2</li><li class="item3">item3</li></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>name</span></a></li><li><a href="" style="block"><span>name</span></a></li><li><a href="" style="block"><span>name</span></a></li><li><a href="" style="block"><span>name</span></a></li><li><a href="" style="block"><span>name</span></a></li><li><a href="" style="block"><span>name</span></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>article1</h1></div><div class="article"><h1>article2</h1></div><div class="article"><h1>article3</h1></div></div></body><div class="footer">copyright</div></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="" />

命令:inp

<input type="text" name="" id="" />

命令:input:p

<input type="password" name="" id="">

命令:btn         结果:<button></button>

命令:btn:s        结果:<button type="submit"></button>

命令:btn:r        结果:<button type="reset"></button>

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文件

这里都是英文文档,没有英语基础的同学可就有点抓瞎了。

好了今天就到这里吧!一下子说太多怕接受不了。

 

转载于:https://www.cnblogs.com/jesse131/p/4978966.html


http://chatgpt.dhexx.cn/article/6aHYQmau.shtml

相关文章

华硕笔记本安装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…

readline库的简单使用

readline库的简单使用 这周要实现一个简单的 shell, 平时使用bash, zsh这些shell的时候, 如果文件名或命令太长&#xff0c;又或者要频繁执行几条命令的话&#xff0c;最常用的应该就是tab键补全和上下键切换历史命令了。 想要在自己的shell里面实现这两个功能很困难&#xf…