Emmet 語法

Emmet 是高效、快速編寫 HTML 和 CSS 代碼的一種插件,若是還不瞭解,請戳[Emmet — the essential toolkit for web-developers](http://docs.emmet.io/),再根據你使用的編輯器(sublime 或 vim 等)下載對應的 Emmet 插件,讓你的代碼快步如飛吧。下面我記錄下經常使用的 Emmet 語法和快捷鍵。代碼區裏的均指在編輯器裏輸入的字符,而後按 「Tab」 鍵便會生成代碼。css

例如 輸入`!` 而後按 「tab」 會獲得以下所示的HTML文檔初始機構,不再用一個字母一個字母敲了,是否是很簡單呢?html

## HTML 編寫git

1. 生成HTML文檔初始機構github

- `html:5` 或者 `!` 生成 HTML5 結構web

1
2
3
4
5
6
7
8
9
    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
    </head>
    <body>
    </body>
    </html>

- `html:xt` 生成 HTML4 過渡型json

1
2
3
4
5
6
7
8
9
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh-cmn-Hans">
    <head>
        <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
        <title>Document</title>
    </head>
    <body>
    </body>
    </html>

- `html:4s` 生成 HTML4 嚴格型bootstrap

1
2
3
4
5
6
7
8
9
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
    <html>
    <head>
        <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
        <title>Document</title>
    </head>
    <body>
    </body>
    </html>

2. 任意一個 html 標籤輸入都會生成完整的閉合標籤。vim

  例如輸入 `p` 按 `tab` 則 生成:`<p></p>`c#

3. 生成帶有 id 、class 的 HTML 標籤: `#`爲 id,`.` 爲 class。sublime-text

  例如輸入 `div#header.section` 則生成 `<div id="header"></div>`

4. 生成後代:`>`

  例如輸入`p>span` 則生成 `<p><span></span></p>`

5. 生成兄弟標籤:`+`

  例如輸入`p+div` 則生成 `<p></p><div></div>`

6. 生成上級標籤: `^`

  例如輸入`ul>li>a^div` 則生成

1
2
3
4
  <ul>
    <li><a href=""></a></li>
    <div></div>
  </ul>

  也可使用多個 `^`,  

  例如輸入`ul>li>a^^div` 則生成

1
2
3
4
  <ul>
      <li><a href=""></a></li>
  </ul>
  <div></div>

7. 重複生成多個標籤 `*`

  例如輸入`ul>li*5` 則生成

1
2
3
4
5
6
7
    <ul>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
    </ul>

8. 生成分組的標籤: `()`

  例如輸入`ul>(li>a)*5` 則生成

1
2
3
4
5
6
7
    <ul>
        <li><a href=""></a></li>
        <li><a href=""></a></li>
        <li><a href=""></a></li>
        <li><a href=""></a></li>
        <li><a href=""></a></li>
    </ul>

    注意和`ul>li>a*5` 生成是不同的

1
2
3
4
5
6
7
8
9
    <ul>
        <li>
            <a href=""></a>
            <a href=""></a>
            <a href=""></a>
            <a href=""></a>
            <a href=""></a>
        </li>
    </ul>

9. 生成自定義屬性:`[]`

  例如輸入`img[https://octodex.github.com/images/codercat.jpg][alt=octcat]` 則生成

1
    <img src="https://octodex.github.com/images/codercat.jpg" alt="octcat" />

10. 生成遞增的屬性標籤等: `$`

  例如輸入`ul>li.item$*5` 則生成

1
2
3
4
5
6
7
    <ul>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
    </ul>

11. 生成多位遞增的呢:`$$$`

  例如輸入`ul>li.item$$$*5` 則生成

1
2
3
4
5
6
7
    <ul>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
    </ul>

 想生成幾位輸入幾個`$`

11. 要生成遞減的呢:`@-`

  例如輸入`ul>li.item$@-*5` 則生成

1
2
3
4
5
6
7
    <ul>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
    </ul>

12. 想要從某個特定的順序開始呢:`@N`

  例如輸入`ul>li.item$@10*5` 則生成

1
2
3
4
5
6
7
   <ul>
       <li></li>
       <li></li>
       <li></li>
       <li></li>
       <li></li>
   </ul>

13. 逆序生成到某個數:`@-`

  例如輸入`ul>li.item$@-10*5` 則生成

1
2
3
4
5
6
7
    <ul>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
    </ul>

14. 生成文本內容:`{}`

  例如輸入`p{我是paddingme}` 則生成

1
    <p>我是paddingme</p>

15. 缺省元素:

 - 聲明一個帶class的div 能夠不用輸入div;

   `.header+.footer` 則生成:

1
2
   <div></div>
   <div></div>

 - Emmet 還會根據父標籤進行斷定

   例如輸入`ul>.item*3` 則生成:

1
2
3
4
5
   <ul>
       <li></li>
       <li></li>
       <li></li>
   </ul>

   下面是全部的隱式標籤名稱:

    - li:用於 ul 和 ol 中

    - tr:用於 table、tbody、thead 和 tfoot 中

    - td:用於 tr 中

    - option:用於 select 和 optgroup 中


 

 

 

首先,Sublime Text3 已經提供了比較強大的 CSS 樣式所寫方法來提升 CSS 編寫效率。例如編寫 `position: absolute`; 這一個屬性,咱們只須要輸入 posa 這四個字母便可。能夠在平時書寫過程當中,留意一下 ST3 提供了哪些屬性的縮寫方法,這樣就能夠提升必定的效率了。可是 Emmet 提供了更多的功能,請往下看。

 

1. 簡寫屬性和屬性值

 好比要定義元素的寬度,只需輸入w100,便可生成:

 ```

  width: 100px;

 ```

 Emmet 的默認設置 w 是 width 的縮寫,後面緊跟的數字就是屬性值。默認的屬性值單位是 px ,你能夠在值的後面緊跟字符生成單位,能夠是任意字符。例如,`w100foo` 會生成:

 ```

 width:100foo;

 ```

 一樣也能夠簡寫屬性單位,若是你緊跟屬性值後面的字符是`p`,那麼將會生成:

 ```

 width:100%;

 ```

 下面是單位別名列表:

 - p 表示%

 - e 表示 em

 - x 表示 ex

 

 像 margin 這樣的屬性,可能並非一個屬性值,生成多個屬性值須要用橫槓(-)鏈接兩個屬性值,由於 Emmet 的指令中是不容許空格的。例如使用 `m10-20` 能夠生成:

 ```

 margin: 10px 20px;

 ```

 若是你想生成負值,多加一條橫槓便可。例如:`m10--20` 能夠生成:

 ```

 margin: 10px -20px;

 ```

 須要注意的是,若是你對每一個屬性都指定了單位,那麼不須要使用橫槓分割。例如使用  m10e20e 能夠生成:

 ```

 margin: 10em 20em;

 ```

 若是使用了橫槓分割,那麼屬性值就變成負值了。例如使用 `m10e-20e` 就生成:

 ```

 margin: 10em -20em;

 ```

 若是你想一次生成多條語句,可使用 「+」 鏈接兩條語句,例如使用 h10p+m5e  能夠生成:

 ```

 height: 10%;
 margin: 5em;

 ```

 

 顏色值也是能夠快速生成的,例如 `c#3` 生成`color: #333`;,更復雜一點的,使用  `bd5#0s` 能夠生成 `border: 5px #000 solid`;。

 下面是顏色值生成規則:

 - ‘#1’ → #111111

 - ‘#e0’ → #e0e0e0

 - ‘#fc0’ → #ffcc00

 生成 `!important` 這條語句也固然很簡單,只須要一個 「!」 就能夠了。

 

2. 附加屬性

 使用 `@f` 便可生成 CSS3 中的 font-face 的代碼結構:

 ```

 @font-face {
     font-family:;
     src:url();
 }

 ```

 可是這個結構太簡單,不包含一些其餘的 font-face 的屬性,諸如 background-image、border-radius、font、@font-face、 text-outline、 text-shadow 等屬性,咱們能夠在生成的時候輸入 「+」 生成加強的結構,例如咱們能夠輸入 `@f+`  命令,便可輸出選項加強版的 font-face 結構:

 ```

 @font-face {
     font-family: 'FontName';
     src: url('FileName.eot');
     src: url('FileName.eot?#iefix') format('embedded-opentype'),
          url('FileName.woff') format('woff'),
          url('FileName.ttf') format('truetype'),
          url('FileName.svg#FontName') format('svg');
     font-style: normal;
     font-weight: normal;
 }

 ```

 

3. 模糊匹配

 若是有些縮寫你拿不許,Emmet 會根據你的輸入內容匹配最接近的語法,好比輸入 `ov:h`、`ov-h`、`ovh` 和 `oh`,生成的代碼是相同的:

 

 ```
  overflow: hidden;

 ```

 

4. 供應商前綴

 CSS3 等如今尚未出正式的 W3C 規範,可是不少瀏覽器已經實現了對應的功能,僅做爲測試只用,因此在屬性前面加上本身獨特的供應商前綴,不一樣的瀏覽器只會識別帶有本身規定前綴的樣式。然而爲了實現兼容性,咱們不得不編寫大量的冗餘代碼,並且要加上對應的前綴。使用 Emmet 能夠快速生成帶有前綴的 CSS3 屬性。

 在任意字符前面加上一條橫槓(-),便可生成該屬性的帶前綴代碼,例如輸入 `-foo-`css,會生成:

 

 ```

 -webkit-foo-css: ;
 -moz-foo-css: ;
 -ms-foo-css: ;
 -o-foo-css: ;
 foo-css: ;

 ```

 

 雖然 foo-css 並非什麼屬性,可是照樣能夠生成。此外,你還能夠詳細的控制具體生成哪幾個瀏覽器前綴或者前後順序,使用 `-wm-trf` 便可生成:

 

 ```

 -webkit-transform: ;
 -moz-transform: ;
 transform: ;

 ```

 可想而知,w 就是 webkit 前綴的縮寫,m 是 moz 前綴縮寫,s 是 ms 前綴縮寫,o  就是 opera 瀏覽器前綴的縮寫。若是使用 `-osmw-abc` 便可生成:

 

 ```

 -o-abc: ;
 -ms-abc: ;
 -moz-abc: ;
 -webkit-abc: ;
 abc: ;

 ```

5. 漸變背景

 CSS3 中新增長了一條屬性 `linear-gradient` 使用這個屬性能夠直接製做出漸變的效果。可是這個屬性的參數比較複雜,並且須要添加實驗性前綴,無疑須要生成大量代碼。而 在 Emmet 中使用 `lg()`指令便可快速生成,例如:使用 `lg(left,#fff,50%,#000)`能夠直接生成:

 

 ```

 background-image: -webkit-gradient(linear, 0 0, 100% 0, color-stop(0.5, #fff),  to(#000));
 background-image: -webkit-linear-gradient(left, #fff 50%, #000);
 background-image: -moz-linear-gradient(left, #fff 50%, #000);
 background-image: -o-linear-gradient(left, #fff 50%, #000);
 background-image: linear-gradient(left, #fff 50%, #000);

 ```

 

6. 附加功能

 生成Lorem ipsum文本

 Lorem ipsum 指一篇經常使用於排版設計領域的拉丁文文章,主要目的是測試文章或文字在不一樣字型、版型下看起來的效果。經過 Emmet,你只需輸入 lorem 或 lipsum 便可生成這些文字。還能夠指定文字的個數,好比 `lorem10`,將生成:

 

 ```

 Lorem ipsum dolor sit amet, consectetur adipisicing elit. Explicabo, esse,  provident, nihil laudantium vitae quam natus a earum assumenda ex vel  consectetur fugiat eveniet minima veritatis blanditiis molestiae harum est!

 ```

 

## 定製

你還能夠定製Emmet插件:

- 添加新縮寫或更新現有縮寫,可修改 snippets.json 文件

- 更改Emmet過濾器和操做的行爲,可修改 preferences.json 文件

- 定義如何生成HTML或XML代碼,可修改 syntaxProfiles.json 文件

如何自定義 Emmet 語法可參考:<http://qianduanblog.com/post/sublime-text-3-custom-emmet-output-bootstrap-widget.html>;github 上 一絲的 [Emment-plus](https://github.com/yisibl/emmet-plus) 也推薦

 

## 快捷鍵

- Ctrl+,: 展開縮寫

- Ctrl+M: 匹配對

- Ctrl+H: 使用縮寫包括

- Shift+Ctrl+M: 合併行

- Ctrl+Shift+?: 上一個編輯點

- Ctrl+Shift+?: 下一個編輯點

- Ctrl+Shift+?: 定位匹配對

 

Emmet 的官方 API 列表在[這裏](http://docs.emmet.io/cheat-sheet/),有一個圖片版本能夠[點此下載](http://bubkoo.qiniudn.com/emmet-api.jpg)

 

 

CSS 部分轉自[HTML/CSS 速寫神器:Emmet](http://bubkoo.com/2014/01/04/emmet-a-toolkit-for-improving-html-css-workflow/),由於寫着寫着發現 bubkoo 差很少給我要寫的寫完了。因此就摘抄下(不要打我),

 

其他參考:[Emmet官方文檔](http://docs.emmet.io/cheat-sheet/)。

相關文章
相關標籤/搜索