百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

前端开发快速编写HTML结构标签之Emmet表达式

myzbx 2025-01-26 23:27 32 浏览

来源:升学就业帮讲师——肖云锐

1. 概述

缩写是Emmet工具箱的核心:这些特殊表达式在运行时进行解析,并转换为结构化代码块,例如HTML。该缩写的语法看起来像CSS选择器,带有一些特定于代码生成的扩展名。因此,每个Web开发人员都已经知道如何使用它。

这是一个例子:这个缩写

可以转化为:

只需一个按键。在许多编辑器(例如Eclipse,Sublime Text 2,Espresso等)中,插件还会生成适当的标签结束标记,因此您可以使用Tab键快速在生成的代码的重要位置之间移动。

缩写针对(但不限于)HTML和XML生成进行了优化,并使编写繁琐的标记代码变得轻而易举。

2. 语法

2.1 缩写语法

Emmet使用类似于CSS选择器的语法来描述元素在生成的树中的位置和元素的属性。

2.2 元素

您可以使用元素的名字,如div或p以生成 HTML标签。Emmet没有一组预定义的可用标签名称,您可以编写任何单词并将其转换为标签:div→

,foo→ 等。

2.3 嵌套运算符

嵌套运算符用于将缩写元素放置在生成的树内:是将其放置在上下文元素内部或者附近。

子元素: >

你可以使用 > 运算符来实现在每一个元素中嵌套内置元素

输出:

兄弟紧邻: +

使用 + 运算符来将元素放置在同一个级别的其他元素的紧邻位置

输出:

父元素: ^

输出:

使用^运算符,您可以向上爬树并更改上下文,其中应显示以下元素:

输出:

您可以使用任意数量的^运算符,每个运算符将上移一个级别:

输出:

乘法: *

使用*运算符,您可以定义元素应输出多少次:

输出:

分组: ()

Emmets的高级用户使用括号将复杂缩写的字数分组:

输出:

如果使用浏览器的DOM,则可以将组视为文档片段:每个组均包含缩写子树,并且以下所有与第一个元素相同的元素都插入到该组中。

您可以将组彼此嵌套,并使用乘法*运算符将它们组合:

输出:

使用组,您可以使用一个缩写字面意义写完整的页面标记,但是请不要这样 做。

2.4 属性运算符

属性运算符用于修改输出元素的属性。例如,在HTML和XML中,您可以快速将class属性添加到生成的元素。

2.4.1 ID和CLASS

在CSS中,您可以使用elem#id和elem.class表示法来访问具有指定id或class属性的元素。在Emmet中,可以使用完全相同的语法将这些属性添加到指定的元素:

输出:

2.4.2 自定义属性

您可以使用[attr]符号(如CSS中一样)向元素添加自定义属性:

输出:

注意:

1. 您可以在方括号内放置任意数量的属性。

2. 您不必指定属性值:td[colspan title]或在每个空属性内使用制表符产生(如果您的编辑器支持它们)。

3. 您可以使用单引号或双引号来引用属性值。

4. 如果值不包含空格,则无需引用它们:td[title=hello colspan=3]可以。

2.4.3 项目编号: $

随着乘法*运算符可以重复的元素,但是$你可以编号它们。将$运算符放在元素名称,属性名称或属性值内,以输出当前重复元素的数量:

输出:

您可以$连续使用多个以零填充数字:

输出:

2.4.4 更改编号基础和方向

使用@修饰符,您可以更改编号方向(升序或降序)和基数(例如起始值)。

例如,要更改方向,请在$之后添加@-:

输出:

要更改计数器的基本值,请在$之后添加@N修饰符:

输出:

您可以将这些修饰符一起使用:

输出:

2.4.5 文本: {}

您可以使用花括号将文本添加到元素:

输出:

请注意:{text}被当做一个独立的元素(例如div,p等等)来解析和使用,但是当写在元素的右边的时候有一个特殊的含义,举个例子:a{click}和a>{click}将产生同样的输出结果,但是a{click}+b{here}和a>{click}+b{here}将会产生不同的结果,如下所示:

在后面第二个例子中,标签放置在元素的里面,这就是两种情况的不同之处:当{text}写在元素的右边是不会更改父级上下文,这里有一个更复杂的例子来显示为什么这点很重要:

输出:

在这个例子中,要编写Click here to continue 到

元素的内部,我们必须使用>运算符将文本移动到树形结构p标签的里面,但是对于a元素来说,我们不能这么做,因为我们只需要带有here文本的元素,而不修改父级上下文。

为了进行比较,这是不带子运算符>的相同emmet缩写:

输出:

2.5 缩写格式注意事项

当您熟悉Emmet的缩写语法时,您可能希望使用某种格式来使您的缩写更具可读性。例如,在元素和运算符之间使用空格,如下所示:

但这是行不通的,因为空格是Emmet停止缩写解析的停止符号

许多用户错误地认为,每个缩写都应该用新行写成,但是他们是错误的:您可以在文本的任何位置键入和扩展缩写:

使用心得:

1.emmet缩写不是模板语言,它们不一定需要具备“可读”性,更重要的是具备“可快速扩展和删除”的功能。

2.您实际上不需要编写复杂的缩写。不要再去想着手写一些HTML结构是Web开发中最慢的过程。您会很快发现,构造一个单独的复杂的缩写比构造和键入一些简短的缩写要慢得多并且容易出错。

3. 隐式标签名称

即使使用功能强大的缩写引擎(可以从短缩写扩展大型HTML结构),编写标签名称也可能非常繁琐。

在许多情况下,您可以跳过键入标签名称的操作,而Emmet会根据上下文选择对应的标签来代替。例如,div.content您可以简单地将.content其编写并扩展为

执行原理:扩展缩写词时,Emmet会尝试在其内部扩展缩写词的地方获取父级上下文,例如HTML元素。如果成功捕获了上下文,Emmet将使用其名称来解析隐式名称,解析规则如下:

1. 如果父级是块级元素,则默认隐式标签是div

2. 如果父级是行内元素,则默认隐式标签是span

3. 如果父级是特殊层级元素,则默认隐式标签是对应父级的子元素,例如:

li为ul和ol

tr为table,tbody,thead和tfoot

td 对于 tr

option为select和optgroup

看一下带有隐式和显式标记名的一些缩写等效项:

4."Lorem Ipsum"生成器

许多Web开发人员都使用“ Lorem ipsum”伪文本来测试其HTML模板与真实数据的外观。开发人员通常会使用第三方服务来生成“ Lorem ipsum”文本,但是现在您可以在编辑器中直接进行操作。只需展开lorem或lipsum缩写即可获得以下代码段:

lorem不仅仅是一个正常的代码片段,它实际上是一个generator。每次扩展它时,它都会生成一个30个单词的虚拟文本,并分成几个句子。

您可以在缩写中指定应生成多少个单词。例如,lorem100将生成一个100字的伪文本。

重复"Lorem ipsum"

您可以lorem在重复元素中使用生成器来创建完全随机句子填充的标签。例如,p*4>lorem缩写将生成如下内容:

此外,当元素是自重复元素时,lorem生成器会使用隐式标签名称解析器,lorem因此您可以缩短缩写:

输出:

相关推荐

零基础入门AI智能体:详细了解什么是变量类型、JSON结构、Markdown格式

当品牌跳出固有框架,以跨界联动、场景创新叩击年轻群体的兴趣点,一场关于如何在迭代中保持鲜活的探索正在展开,既藏着破圈的巧思,也映照着与新一代对话的密码。在创建AI智能体时,我们会调用插件或大模型,而在...

C# 13模式匹配:递归模式与属性模式在真实代码中的性能影响分析

C#13对模式匹配的增强让复杂数据处理代码更简洁,但递归模式与属性模式的性能差异一直是开发者关注的焦点。在实际项目中,选择合适的模式不仅影响代码可读性,还可能导致执行效率的显著差异。本文结合真实测试...

零基础快速入门 VBA 系列 6 —— 常用对象(工作簿、工作表和区域)

上一节,我介绍了VBA内置函数以及如何自动打字和自动保存文件。这一节,我们来了解一下Excel常用对象。Excel常用对象Excel有很多对象,其中最常用也最重要的包括以下3个:1.Workbo...

不同生命数字的生肖龙!准到雷普!

属龙的人总在自信爆棚和自讨苦吃之间反复横跳?看完这届龙宝宝的日常我悟了。属龙的人好像天生自带矛盾体:领导力超强可人缘时好时坏,工作雷厉风行却总在爱情里翻车。关键年份的龙性格差异更大——76年龙靠谱但不...

仓颉编程语言基础-面向对象编程-属性(Properties)

属性是仓颉颉中一种强大的机制,它允许你封装对类(或接口interface、结构体struct、枚举enum、扩展extend)内部状态的访问。它看起来像一个普通的成员变量(字段),但在其背后,它通过...

Python中class对象/属性/方法/继承/多态/魔法方法详解

一、基础入门:认识类和对象1.类和对象的概念在Python中,类(class)是一种抽象的概念,用于定义对象的属性和行为,而对象(也称为实例)则是类的具体表现。比如,“汽车”可以是一个类,它有...

VBA基础入门:搞清楚对象、属性和方法就成功了一半

如果你刚接触VBA(VisualBasicforApplications),可能会被“对象”“属性”“方法”这些术语搞得一头雾水。但事实上,这三个概念是VBA编程的基石。只要理解它们之间的关系,...

P.O类型文推荐|年度编推合集(一百九十五篇)

点击左上方关注获取更多精彩推文目录2019年度编推35篇(1V1)《悖论》作者:流苏.txt(1V1)《桂花蒸》作者:大姑娘浪.txt(1V1)《豪门浪女》作者:奚行.txt...

Python参数传递内存大揭秘:可变对象 vs 不可变对象

90%的Python程序员不知道,函数参数传递中可变对象的修改竟会导致意想不到的副作用!一、参数传递的本质:对象引用传递在Python中,所有参数传递都是对象引用的传递。这意味着函数调用时传递的不是对...

JS 开发者必看!TC39 2025 最新动向,这些新语法要火?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力。TC39第...

2025 年值得尝试的 5 个被低估的 JavaScript 库

这些JavaScript库可能不会在社交媒体或HackerNews上流行起来,但它们会显著提高您的工作效率和代码质量。JavaScript不再只是框架。虽然React、Vue和Sv...

Python自动化办公应用学习笔记30—函数的参数

一、函数的参数1.形参:o定义:在函数定义时,声明在函数名后面括号中的变量。o作用:它们是函数内部的占位符变量,用于接收函数被调用时传入的实际值。o生命周期:在函数被调用时创建,在函数执...

16种MBTI人格全解析|测完我沉默了三秒:原来我是这样的人?

MBTI性格测试火了这么久,你还不知道自己是哪一型?有人拿它当社交话题,有人拿它分析老板性格,还有人干脆当成择偶参考表。不废话,今天我一次性给你整理全部16种MBTI人格类型!看完你不仅能知道自己是谁...

JS基础与高级应用: 性能优化

在现代Web开发中,性能优化已成为前端工程师必须掌握的核心技能之一。本文从URL输入到页面加载完成的全过程出发,深入分析了HTTP协议的演进、域名解析、代码层面性能优化以及编译与渲染的最佳实践。通过节...

爱思创CSP-J/S初赛模拟赛线上开赛!助力冲入2024年CSP-J/S复赛!

CSP-J/S组初赛模拟赛爱思创,专注信奥教育19年,2022年CSP-J/S组赛事指定考点,特邀NOIP教练,开启全真实CSP-J/S组线上初赛模拟大赛!一、比赛对象:2024年备考CSP-J/S初...