转自:http://www.jianshu.com/p/67fa1e2114c5

背景

HTML和CSS的写法相对固定,而且重复的工作特别多,特别是尖括号实在是很烦。使用Emmet至少能帮你节省一半的前期开发工作量,所以花点时间学习Emmet是很值得的。Emmet不是编程语言,而只是编辑器的插件,也可以自定义规则。

安装

Emmet支持多种编辑器,参见列表。由于我使用vim,这里只介绍vim的插件。

教程里已经介绍的很清楚,我主要罗列常用写法。

用法

快捷键

注:<c-y>, 指先按ctrl+y,再按,,后面不再说明

快捷键 介绍
<c-y>, emmet触发键,tips:输完命令后最好在后面多写一个空格,如:html:5_
v <c-y>, 先进入可视模式,选择目标文本,按快捷键,状态栏弹出Tags:,输入命令即可
<c-y>n 跳转到下一个编辑点
<c-y>N 跳转到上一个编辑点
<c-y>i 移动到img标签,按快捷键,自动为图片添加大小
<c-y>m 合并多行为一行
<c-y>k 删除当前tag
<c-y>/ 切换添加、去除注释
<c-y>a 自动将网址转换为链接标签
  • 简写注意事项
简写 编译
.wrap>.content div.wrap>div.content
em>.info em>span.info
ul>.item*3 ul>li.item*3
table>#row$*4>[colspan=2] table>tr#row$*4>td[colspan=2]

基本html用法

  • ! (生成基本html结构,效果同html:5)
    示例: !
    效果:

      <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title></title>
    </head>
    <body> </body>
    </html>
  • html:5 (效果同!,另外还有html:xt, html:4s)

  • # (生成id)
    示例: div#main 或者直接写 #main
    效果:

      <div id="main">
    </div>
  • . (生成class)
    示例: div.list
    效果:

      <div class="list">
    </div>
  • > (生成后代元素)
    示例: div.list>ul>li
    效果:

      <div class="list">
    <ul>
    <li></li>
    </ul>
    </div>
  • + (生成兄弟元素)
    示例: h1+h2+p
    效果:

      <h1></h1>
    <h2></h2>
    <p></p>
  • {} (文本)
    示例: a{Click me}+ul>li{item$}*3
    效果:

      <a href="">Click me</a>
    <ul>
    <li>item1</li>
    <li>item2</li>
    <li>item3</li>
    </ul>

    示例2:p>{Click }+a{here}+{ to continue}
    效果:

      <p>Click <a href="">here</a>to continue</p>
  • ^ (生成上级元素)
    示例: div.list>ul>li^span
    效果:

      <div class="list">
    <ul>
    <li></li>
    </ul>
    <span></span>
    </div>
  • * (重复生成元素)
    示例: ul>li*5
    效果:

      <ul>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    </ul>
  • () (生成分组)
    示例: div.list>ul>li
    效果:

      <div id="main">
    <div id="header">
    <ul>
    <li></li>
    <li></li>
    </ul>
    </div>
    <div id="footer"></div>
    </div>

    示例2:(div>dl>(dt+dd)*3)+footer>p
    效果:

     <div>
    <dl>
    <dt></dt>
    <dd></dd>
    <dt></dt>
    <dd></dd>
    <dt></dt>
    <dd></dd>
    </dl>
    </div>
    <footer>
    <p></p>
    </footer>
  • $[N] (生成编号,单个编号默认从1开始,也支持多位编号,需要几位就写几个,默认从0开始,N为起始编号)
    示例: div>(ul>li.item$*2)+(ul>li.item$$@5*2)
    效果:

      <div>
    <ul>
    <li class="item1"></li>
    <li class="item2"></li>
    </ul>
    <ul>
    <li class="item05"></li>
    <li class="item06"></li>
    </ul>
    </div>
  • $@[-][N] (编号排序-为倒序,N为起始编号)
    示例: ul>li.item$$@-*2
    效果:

      <ul>
    <li class="item02"></li>
    <li class="item01"></li>
    </ul>

    示例: ul>li.item$$@5*3
    效果:

      <ul>
    <li class="item05"></li>
    <li class="item06"></li>
    </ul>
  • lorem[N] (生成随机内容,N为单词数量)
    示例: lorem
    效果:

      Elit neque iste aspernatur repellat ducimus alias incidunt nam nemo ducimus, id consequatur illo blanditiis! Necessitatibus minima repellat dignissimos eaque quo obcaecati quasi. Voluptatum nostrum harum corporis optio molestias nihil.

    示例: h2*3>lorem5 或者 (h2>lorem5)*3
    效果:

      <h2>
    Consectetur esse recusandae sapiente magnam.
    </h2>
    <h2>
    Lorem odio unde magni molestias!
    </h2>
    <h2>
    Amet perferendis praesentium facilis maxime.
    </h2>

实用html组合

    • 生成一个基本网站框架
      示例: #main_page>(div.header>div.logo+div.menu)+div.context+div.footer
      效果:

        <div id="main_page">
      <div class="header">
      <div class="logo"></div>
      <div class="menu"></div>
      </div>
      <div class="context"></div>
      <div class="footer"></div>
      </div>
    • 生成内容
      示例:.context>((span.title>lorem2)+(span.text>lorem10))*3
      效果:

         <div class="context">
      <span class="title">Elit quod?</span>
      <span class="text">Amet cumque perferendis a quasi dolor voluptatem repellat nihil lorem.</span>
      <span class="title">Adipisicing atque.</span>
      <span class="text">Consectetur deleniti quasi ea iste atque dolores rem nihil. Dolor.</span>
      <span class="title">Adipisicing laborum?</span>
      <span class="text">Sit nam sapiente eius dolorem accusamus, beatae impedit molestias expedita?</span>
      </div>
    • 生成菜单
      示例: div.menu>ul#navigation>li*5>a{Item $}
      效果:

        <div class="menu">
      <ul id="navigation">
      <li><a href="">Item 1</a></li>
      <li><a href="">Item 2</a></li>
      <li><a href="">Item 3</a></li>
      <li><a href="">Item 4</a></li>
      <li><a href="">Item 5</a></li>
      </ul>
      </div>
    • 可视化模式下生成菜单
      示例文本:

      首页
      新闻
      方案
      关于

      v进入可视模式,选中文本,再按<c-y>,,输入:
      nav>ul.nav>li.page$*>a
      效果:

      <nav>
      <ul class="nav">
      <li class="page1"><a href="">首页</a></li>
      <li class="page2"><a href="">新闻</a></li>
      <li class="page3"><a href="">方案</a></li>
      <li class="page4"><a href="">关于</a></li>
      </ul>
      </nav>

      再进一步,取消上面的操作:输入:
      ul.nav>li.page$*>img[alt=$#]+a[href='#']
      效果

      <ul class="nav">
      <li class="page1">
      <img src="" alt="首页">
      <a href="#">首页</a>
      </li>
      <li class="page2">
      <img src="" alt="新闻">
      <a href="#">新闻</a>
      </li>
      <li class="page3">
      <img src="" alt="方案">
      <a href="#">方案</a>
      </li>
      <li class="page4">
      <img src="" alt="关于">
      <a href="#">关于 </a>
      </li>
      </ul>
    • 自动添加图片尺寸
      <img src="test.jpg" alt="首页">
      光标移动到img标签内,按<c-y>i再按Enter即可
      效果:
      <img src="test.jpg" alt="首页" width="500" height="375">

Gvim+Emmet.vim 那些事。的更多相关文章

  1. Gvim 和vim 有什么区别

    Gvim 和vim 有什么区别 Gvim是windows的 vim是linux的黑色的命令符 Gvim是单独的窗口下的vim,像notepad一样. vim就是在黑乎乎的cmd窗口下的编辑器.wind ...

  2. Emmet.vim 教程

    Emmet.vim 教程 May 5, 2012 目录 1 下载 Emmet.vim 2 安装 Emmet.vim 3 使用 Emmet.vim 4 余话 Emmet 项目原先叫 Zen Coding ...

  3. 代码编辑器[0] -> Vim/gVim[1] -> Vim 的快捷键操作

    快捷键 / Shortcut Keys 1 基本操作 / Basic Operation Vim的基本操作主要可以参考以下几张图,参考链接, 命令行模式 i             从光标所在字符前插 ...

  4. 代码编辑器[0] -> Vim/gVim[2] -> Vim 的相关知识

    相关知识 / Relevant Knowledge 1 _vimrc编程 / _vimrc Program 1. 注释符", 用于注释 2. 关键词set, 用于设置功能等 3. 关键词im ...

  5. GVIM、VIM

    全世界最好的编辑器VIM之Windows配置篇 Highlight all search pattern matches Top 10 things Vi user need to know abou ...

  6. windows下的gvim和emmet 下载和安装 + "omnifunc is not set" solution?

    注意几个地方: 引导键是ctrl-y, 其他就是实际的操作键了, 如: n下一个插入点, N是上一个插入点(不是p), ctrl-y + i是自动为图片添加宽度和高度尺寸, 要点是要把光标移动到 im ...

  7. vim 中 也可以 直接安装 emmet 直接使用zen coding 生成 l指定个数的 lorem ipsum文字.

    超链接的写法: 当作为链接的文字, 比较长时, 整个作为链接 就显得不是 很适合. 可以取其中的某一个单词 作为 超链接的 关键字:如: click here to continue emmet中如何 ...

  8. 在vim中使用zencoding/Emmet

    zencoding在vim上的插件已经改名为Emmet.vim 1. 安装,推荐使用vundle插件管理器安装,在~/.vimrc中,添加:Bundle 'Emmet.vim',输入命令vim +Bu ...

  9. Vim:gvim安装配置(windows)

    Vim:gvim安装配置(windows) 一.gvim的特点: vim要求全部键盘操作,而gvim可以使用鼠标进行可视化操作,即gvim是vim的图形化界面: 二.gvim安装: 下载地址:http ...

随机推荐

  1. 继续Kanzi

    转眼间,Kanzi已经发展到3.3版本了,之前研究过的东西,今天有空下了个版本跟进更新看看有没有什么变化.新的引擎跟以前2.x版本有很大的差别.新引擎增加了很多新功能(包括局部刷新技术),也跟随大潮加 ...

  2. 《BI项目笔记》创建计算成员

    也可以利用脚本来生成计算成员

  3. Linux下文件重命名、创建、删除、修改及保存文件

    一.重命名(更名) linux 给文件改名的命令是mv命令 mv命令来为文件或目录改名或将文件由一个目录移入另一个目录中.该命令等同于DOS系统下的ren和move命令的组合.它的使用权限是所有用户. ...

  4. Ubuntu14.04安装redis和简单配置

    1.前言 Redis是常用基于内存的Key-Value数据库,比Memcache更先进,支持多种数据结构,高效,快速.用Redis可以很轻松解决高并发的数据访问问题:做为时时监控信号处理也非常不错. ...

  5. STM32学习笔记(九) 外部中断,待机模式和事件唤醒

    学会知识只需要不段的积累和提高,但是如何将知识系统的讲解出来就需要深入的认知和系统的了解.外部中断和事件学习难度并不高,不过涉及到STM32的电源控制部分,还是值得认真了解的,在本文中我将以实际代码为 ...

  6. 【转载】CSS 伪类-:before和:after

    :before和:after的作用就是在指定的元素内容(而不是元素本身)之前或者之后插入一个包含content属性指定内容的行内元素,最基本的用法如下: #example:before { conte ...

  7. Head First 设计模式 --9 迭代器模式 组合模式

    迭代器模式:提供一种方法书序访问一个聚合对象中的各个元素,而又不暴露其内部的表示. 用到的设计原则:1.封装变化2.多用组合,少用继承|3.针对接口编程,不针对实现编程4.松耦合5.对扩展开放,对修改 ...

  8. zabbix3.0.4 部署之三 (LNMP > Mysql 安装)

    MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具. 因此,我们首先要在系统中源码编译安装cmake工具. 接下来的安装过程中会遇到错误,我们 ...

  9. AWS EC2的VPN-PPTP搭建教程(on aws redhat6.5 X64 centOS 6.5)

    前些日子收到amazon的邮件通知,一年前申请的ec2到期了,一年免费的free tier没有了,放在上面的2个站已经欠费了十几美元了,不过我也不打算用了,准备重新注册账号(请不要鄙视我..) 1.注 ...

  10. SPSS数据分析—重复测量差分析

    多因素方差分析中,每个被试者仅接受一种实验处理,通过随机分配的方式抵消个体间差异所带来的误差,但是这种误差并没有被排除.而重复测量设计则是让每个被试接受所有的实验处理,这样我们就可以分离出个体差异所带 ...