Sublime Text、webstorm等編譯器快速編寫HTML/CSS代碼的技巧

Sublime Text、webstorm等編譯器,若是你從事Web前端開發的話,對這幾款軟件必定不會陌生。它使用仿CSS選擇器的語法來生成代碼,大大提升了HTML/CSS代碼編寫的速度,好比下面的演示:html

1、快速編寫HTML代碼

1.  初始化

HTML文檔須要包含一些固定的標籤,好比<html>、<head>、<body>等,如今你只須要1秒鐘就能夠輸入這些標籤。好比輸入「!」或「html:5」,而後按Tab鍵: 
前端

  • html:5 或!:用於HTML5文檔類型
  • html:xt:用於XHTML過渡文檔類型
  • html:4s:用於HTML4嚴格文檔類型

2.  輕鬆添加類、id、文本和屬性

連續輸入元素名稱和ID,編譯器會自動爲你補全,好比輸入p#foo:web

連續輸入類和id,好比p.bar#foo,會自動生成:webstorm

    <p class="bar" id="foo"></p>  

下面來看看如何定義HTML元素的內容和屬性。你能夠經過輸入h1{foo}和a[href=#],就能夠自動生成以下代碼:svg

<h1>foo</h1>  
<a href="#"></a>  

3.  嵌套

如今你只須要1行代碼就能夠實現標籤的嵌套。
url

  • >:子元素符號,表示嵌套的元素
  • +:同級標籤符號
  • ^:可使該符號前的標籤提高一行

效果以下圖所示: spa

4.  分組

你能夠經過嵌套和括號來快速生成一些代碼塊,好比輸入(.foo>h1)+(.bar>h2),會自動生成以下代碼: code

<div class="foo">  
    <h1></h1>  
</div>  
<div class="bar">  
     <h2></h2>  
</div>  

5.  隱式標籤

聲明一個帶類的標籤,只需輸入div.item,就會生成<div class="item"></div>。

在過去版本中,能夠省略掉div,即輸入.item便可生成<div class="item"></div>。如今若是隻輸入.item,編譯器會根據父標籤進行斷定。好比在<ul>中輸入.item,就會生成<li class="item"></li>。 orm

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

    • li:用於ul和ol中
    • tr:用於table、tbody、thead和tfoot中
    • td:用於tr中
    • option:用於select和optgroup中

 

6.  定義多個元素

要定義多個元素,可使用*符號。好比,ul>li*3能夠生成以下代碼:

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

7.  定義多個帶屬性的元素

若是輸入 ul>li.item$*3,將會生成以下代碼: 

<ul>  
      <li class="item1"></li>  
      <li class="item2"></li>  
      <li class="item3"></li>  
</ul>  

2、CSS縮寫

1.  值

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

width: 100px;  

除了px,也能夠生成其餘單位,好比輸入h10p+m5e,結果以下:

height: 10%;  
 margin: 5em;  

單位別名列表:

    • p 表示%
    • e 表示 em
    • x 表示 ex

2.  附加屬性

可能你以前已經瞭解了一些縮寫,好比 @f,能夠生成:

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

一些其餘的屬性,好比background-image、border-radius、font、@font-face,text-outline、text-shadow等額外的選項,能夠經過「+」符號來生成,好比輸入@f+,將生成:

    @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.  模糊匹配

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

overflow: hidden;  

4.  供應商前綴

若是輸入非W3C標準的CSS屬性,Emmet會自動加上供應商前綴,好比輸入trs,則會生成:

    -webkit-transform: ;  
    -moz-transform: ;  
    -ms-transform: ;  
    -o-transform: ;  
    transform: ;  

你也能夠在任意屬性前加上「-」符號,也能夠爲該屬性加上前綴。好比輸入-super-foo:

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

若是不但願加上全部前綴,可使用縮寫來指定,好比-wm-trf表示只加上-webkit和-moz前綴:

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

前綴縮寫以下:

    • w 表示 -webkit-
    • m 表示 -moz-
    • s 表示 -ms-
    • o 表示 -o-

5.  漸變

輸入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);

相關文章
相關標籤/搜索