在前端開發(fā)的過程中,最費(fèi)時(shí)間的工作就是寫 HTML、CSS 代碼。一堆的標(biāo)簽、屬性、括號(hào)等,頭疼。這里推薦一個(gè)Emmet語法規(guī)則,讓你寫的時(shí)候爽到飛起,能大大提高代碼書寫,只需要敲一行代碼就能生成你想要的完整HTML結(jié)構(gòu),下面會(huì)介紹如何使用。
Emmet是一款插件,只要能安裝他的編輯器都能使用,大部分編輯器都可以使用該語法規(guī)則,我們平時(shí)開發(fā)的Sublime Text
、Eclipse
、Notepad++
、VS code
、Atom
、Dreamweaver
等等編輯器都可以使用。
安裝方式和平時(shí)安裝插件一樣搜索這個(gè)emmet插件安裝,每個(gè)編輯器安裝方式不同,請(qǐng)各自嘗試
先來個(gè)例子:
這個(gè)普通的HTML結(jié)構(gòu),你需要多久打出來呢?
我只需要幾秒鐘,寫好下面這條語句,按下鍵盤Tab
鍵即可看到上圖中的結(jié)構(gòu)了
div#box>p.title+ul.list>li.child${我是第$個(gè)}*3^div#box2
是不是很爽,很快~~啊 ~ 啊~,僅僅一行代碼就生成了一個(gè)復(fù)雜的HTML結(jié)構(gòu),并且id,class,內(nèi)容都對(duì)應(yīng)的上
開始講解語法吧
1:html初始結(jié)構(gòu)
下圖中的結(jié)構(gòu),偷懶的都會(huì)直接一個(gè)!=> Tab 解決,這樣可以快速生成基礎(chǔ)的結(jié)構(gòu),同時(shí)防止手寫時(shí)忘記某個(gè)代碼塊,輸入錯(cuò)誤的代碼。
2:id(#),class(.)
id指令:# ; class指令:.
div#test
div.test
3:子節(jié)點(diǎn)(>),兄弟節(jié)點(diǎn)(+),上級(jí)節(jié)點(diǎn)(^)
子節(jié)點(diǎn)指令:> ; 兄弟節(jié)點(diǎn)指令:+ ; 上級(jí)節(jié)點(diǎn):^
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
的上一級(jí),與ul
成了兄弟關(guān)系,當(dāng)然兩個(gè)^^就是上上級(jí))
<div>
<ul>
<li></li>
</ul>
<div></div>
</div>
4:重復(fù)(*)
重復(fù)指令:*
div*5(*號(hào)后面添加數(shù)字表示重復(fù)的元素個(gè)數(shù))
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
5:分組(())
分組指令:()
div>(ul>li>a)+div>p
(括號(hào)里面的內(nèi)容為一個(gè)代碼塊,表示與括號(hào)內(nèi)部嵌套和外面的的層級(jí)無關(guān))
<div>
<ul>
<li><a href=""></a></li>
</ul>
<div>
<p></p>
</div>
</div>
解釋:這里如果不加括號(hào)的話,猜想下,a+div
這樣div就是和a是兄弟關(guān)系了,會(huì)包含在li里面。懂了吧哈哈
<div>
<ul>
<li>
<a href=""></a>
<div>
<p></p>
</div>
</li>
</ul
6:屬性([attr])——id,class都有怎么能少了屬性呢
屬性指令:[]
a[href=’###’ name=‘xiaoA’] (中括號(hào)內(nèi)填寫屬性鍵值對(duì)的形式,并且空格隔開)
<a href="###" name="xiaoA"></a>
###6:編號(hào)($)
編號(hào)指令:$
ul>li.test$*3 ($代表一位數(shù),后面更上*數(shù)字就代表從1遞增到填寫的數(shù)字)
<ul>
<li class="test1"></li>
<li class="test2"></li>
<li class="test3"></li>
</ul>
注意:
一個(gè)$ 代表一位數(shù),$$就是兩位數(shù)了,以此類推就可以形成$(1),$$(01),$$$(001)
如果想自定義從幾開始遞增的話就利用:$@+數(shù)字*數(shù)字
例如:ul>li*3.test$@3
<ul>
<li class="test3"></li>
<li class="test4"></li>
<li class="test5"></li>
</ul>
7:文本({})
文本指令:{}
ul>li.test$*3{測試$} ({里面填寫內(nèi)容,可以和$一起組合使用哦})
<ul>
<li class="test1">測試1</li>
<li class="test2">測試2</li>
<li class="test3">測試3</li>
</ul>
8:隱式標(biāo)簽
這個(gè)標(biāo)簽沒有指令,而是部分標(biāo)簽可以不使用輸入標(biāo)簽,直接輸入指令,即可識(shí)別父類標(biāo)簽。
例如:.test
例如: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>
等等…
隱私標(biāo)簽有如下幾個(gè):
- li:用于 ul 和 ol 中
- tr:用于 table、tbody、thead 和 tfoot 中
- td:用于 tr 中
- option:用于 select 和 optgroup 中
最后就是:看沒用,操作幾遍,幾分鐘你就能掌握這些指令,然后飛快的擼碼
到此這篇關(guān)于HTML速寫之Emmet語法規(guī)則的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)HTML Emmet語法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!