http://www.johnpapa.net/zen-coding-in-visual-studio-2012

Zen Coding is a faster way to write HTML using a CSS style selector syntax, and you can now use Zen Coding in Visual Studio via the Web Essentials 2012 plug in (v1.7).  Zen Coding was introduced by Sergey Chikuyonok in 2009 (according to Smashing Magazine) and has been updated over time to become a great way to write monotonous HTML much more efficiently.
 
Special thanks  to Mads Kristensen and his team at Microsoft for adding Zen Coding to Visual Studio 2012 via Web Essentials 2012 (along with many other great features).

Quick Reference

Here is a quick list of the Zen Coding features that are now supported in Visual Studio 2012 via the Web Essentials 2012 plug in

  • # creates an id attribute
  • . creates a class attribute
  • [ ] creates a custom attribute
  • > creates a child element
  • + creates a sibling element
  • ^ climbs up
  • * is element multiplication. This creates the same thing n number of times
  • $ is replaced with an incremental number
  • $$ is used for numbers with padding
  • { } creates text in an element
What can you do? Here is an example:
  1. <!-- Type this -->
  2. ul[data-bind="foreach:customers"]>li*4>span{Caption $$}+input[type=text data-bind="value:$$"]
  3. <!-- Creates this -->
  4. <uldata-bind="foreach:customers">
  5. <li><span>Caption 01</span><inputtype="text"value=""data-bind="value:01"/></li>
  6. <li><span>Caption 02</span><inputtype="text"value=""data-bind="value:02"/></li>
  7. <li><span>Caption 03</span><inputtype="text"value=""data-bind="value:03"/></li>
  8. <li><span>Caption 04</span><inputtype="text"value=""data-bind="value:04"/></li>
  9. </ul>
Let’s take a closer look at the different symbols used

ID and Class Attributes: # and .

You can create an element and assign it an id or class attribute using CSS style syntax.
  1. <!-- Type this -->
  2. div#contentRegion.address
  3. <!-- Creates this -->
  4. <divid="contentRegion"class="address"></div>

Custom Attributes: [ ]

You can create any attribute the square bracket syntax.
  1. <!-- Type this -->
  2. div[title]
  3. <!-- Creates this -->
  4. <divtitle=""></div>
Or create multiple attributes and fill in values
  1. <!-- Type this -->
  2. input[placeholder="Name" type="text"]
  3. <!-- Creates this -->
  4. <inputtype="text"value=""placeholder="Name"/>

Child Elements: >

Create an element and then a child element inside of it. In this example I create a div with the id=menu that contains a span with a class="item" and a blank title attribute
  1. <!-- Type this -->
  2. div#menu>span.item[title]
  3. <!-- Creates this -->
  4. <divid="menu">
  5. <spanclass="item"title=""></span>
  6. </div>

Sibling Elements: +

You can create a sibling element easily too.
  1. <!-- Type this -->
  2. footer>div>a+input
  3. <!-- Creates this -->
  4. <footer>
  5. <div>
  6. <ahref=""></a>
  7. <inputtypevalue=""/>
  8. </div>
  9. </footer>

Climbing Elements: ^

The > operator descends into element hierarchy while the ^ climbs up the hierarchy. You can also climb multiple levels. For example: use 1 ^ to climb 1 level or use 4 ^ to climb 4 levels.
  1. <!-- Type this -->
  2. footer>div>a+input^^p
  3. <!-- Creates this -->
  4. <footer>
  5. <div>
  6. <ahref=""></a>
  7. <inputtypevalue=""/>
  8. </div>
  9. <p></p>
  10. </footer>

Multiplication: *

Create n number of elements
  1. <!-- Type this -->
  2. ul>li*4>span
  3. <!-- Creates this -->
  4. <ul>
  5. <li><span></span></li>
  6. <li><span></span></li>
  7. <li><span></span></li>
  8. <li><span></span></li>
  9. </ul>

Item Numbering: $

When using the multiplication to create n number of elements, you can add an incremental number to them using the $. Notice that using multiple $ operators (ex: $$) creates pads the numbers with 0′s.
  1. <!-- Type this -->
  2. section>article.item$$*4
  3. <!-- Creates this -->
  4. <section>
  5. <articleclass="item01"></article>
  6. <articleclass="item02"></article>
  7. <articleclass="item03"></article>
  8. <articleclass="item04"></article>
  9. </section>

Text: } {

You can enter text values inside of elements, without changing the parent context.
  1. <!-- Type this -->
  2. ul>li*4>span{Caption $$}
  3. <!-- Creates this -->
  4. <ul>
  5. <li><span>Caption 01</span></li>
  6. <li><span>Caption 02</span></li>
  7. <li><span>Caption 03</span></li>
  8. <li><span>Caption 04</span></li>
  9. </ul>
This does not change the parent context, so when specifying the sibling to follow the text, the sibling element will actually follow the element prior to the text. That’s why the example below creates an anchor tag next to the span tag.
  1. <!-- Type this -->
  2. ul>li*4>span{Caption $$}+a{click me}
  3. <!-- Creates this -->
  4. <ul>
  5. <li><span>Caption 01</span><ahref="">click me</a></li>
  6. <li><span>Caption 02</span><ahref="">click me</a></li>
  7. <li><span>Caption 03</span><ahref="">click me</a></li>
  8. <li><span>Caption 04</span><ahref="">click me</a></li>
  9. </ul>

Combining Them all

You can combine multiple features together which allows you to write some pretty cool HTML much faster. You can even use this to create some Knockout.js bindings for templates, and then just change the property names.
  1. <!-- Type this -->
  2. section[data-bind="foreach:customers"]>div*4>input[type="text" data-bind="text:$$"]
  3. <!-- Creates this -->
  4. <sectiondata-bind="foreach:customers">
  5. <div>
  6. <inputtype="text"value=""data-bind="text:01"/>
  7. </div>
  8. <div>
  9. <inputtype="text"value=""data-bind="text:02"/>
  10. </div>
  11. <div>
  12. <inputtype="text"value=""data-bind="text:03"/>
  13. </div>
  14. <div>
  15. <inputtype="text"value=""data-bind="text:04"/>
  16. </div>
  17. </section>

Grouping: ( )

Grouping is a powerful feature of Zen Coding that allows you to create complex expressions. It is not yet in Web Essentials 2012, but I assume it will come in the near future. If it does arrive, you would be able to create entire sections of a DOM very easily.
  1. <!-- Type this -->
  2. div>(header>div)+section>(ul>li*2>a)+footer>(div>span)
  3. <!-- WOULD create this (not yet supported in Web Essentials 2012)-->
  4. <div>
  5. <header>
  6. <div></div>
  7. </header>
  8. <section>
  9. <ul>
  10. <li><ahref=""></a></li>
  11. <li><ahref=""></a></li>
  12. </ul>
  13. </section>
  14. <footer>
  15. <div>
  16. <span></span>
  17. </div>
  18. </footer>
  19. </div>
As you can see, this would make it quite simple to create large sections of HTML with just a few keystrokes.

Lorem Ipsum Generator

(Added Dec 5, 2012)

You can now generate Lorem Ipsum directly in the HTML editor. Type “lorem” and hit TAB and a 30 word Lorem Ipsum text is inserted. Type “lorem10″ and a 10 word Lorem Ipsum text is inserted.

ul>li*5>lorem3

References

Zen Coding in Visual Studio 2012的更多相关文章

  1. 如何在Visual Studio 2012中发布Web应用程序时自动混淆Javascript

    同Java..NET实现的应用程序类似,Javascript编写的应用程序也面临一个同样的问题:源代码的保护.尽管对大多数Javascript应用公开源代码不算是很严重的问题,但是对于某些开发者来说, ...

  2. 在Visual Studio 2012中使用VMSDK开发领域特定语言(二)

    本文为<在Visual Studio 2012中使用VMSDK开发领域特定语言>专题文章的第二部分,在这部分内容中,将以实际应用为例,介绍开发DSL的主要步骤,包括设计.定制.调试.发布以 ...

  3. 在Visual Studio 2012中使用VMSDK开发领域特定语言(一)

    前言 本专题主要介绍在Visual Studio 2012中使用Visualization & Modeling SDK进行领域特定语言(DSL)的开发,包括两个部分的内容.在第一部分中,将对 ...

  4. Visual Studio 2012 trial version

    Update: vs2012.5.iso http://download.microsoft.com/download/9/F/1/9F1DEA0F-97CC-4CC4-9B4D-0DB45B8261 ...

  5. 在Visual Studio 2012 Blue theme下使用Dark theme的文本编辑器颜色设置

    Visual Studio 2012 默认提供了3种color theme: blue,light,和dark.其中dark的文本编辑器颜色设定很爽,可是整个菜单项加上一些小的窗口如Find Resu ...

  6. 分享10条Visual Studio 2012的开发使用技巧

    使用Visual Studio 2012有一段时间了,并不是追赶潮流,而是被逼迫无可奈何.客户要求的ASP.NET MVC 4的项目,要用.NET 4.5来运行.经过一段时间的摸索,得到一点经验和体会 ...

  7. Visual Studio 2012 Update 4 RC 启动调试失败解决方案

    以下解决办法适用于任何Visual Studio开发环境,及Windows NT 6.1以上系统. 系统:Windows 8.1 Enterprise x64 RTM 开发环境:Visual Stud ...

  8. SQL Server Data Tools – Business Intelligence for Visual Studio 2012安装时提示“The CPU architecture....”的解决方法

    SQL Server Data Tools – Business Intelligence for Visual Studio 2012,一个很强大的工具,下载地址:http://www.micros ...

  9. Visual Studio 2012+jQuery-1.7.1

    今天用Visual Studio 2012开发一个网站项目,在集成jqplot图表控件并进行调试的时候(使用的是MVC4框架),加载网页绘制图表的时候总是报错(提示$.jqplot.barRender ...

随机推荐

  1. Java 模拟队列(一般队列、双端队列、优先级队列)

    队列: 先进先出,处理类似排队的问题,先排的.先处理,后排的等前面的处理完了,再处理 对于插入和移除操作的时间复杂度都为O(1).从后面插入,从前面移除 双端队列: 即在队列两端都能够insert和r ...

  2. hdu2844(多重背包)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2844 题意:一位同学想要买手表,他有n种硬币,每种硬币已知有num[i]个.已知手表的价钱最多m元,问 ...

  3. malloc函数的一种简单的原理性实现

    malloc()是C语言中动态存储管理的一组标准库函数之一.其作用是在内存的动态存储区中分配一个长度为size的连续空间.其参数是一个无符号整形数,返回值是一个指向所分配的连续存储域的起始地址的指针 ...

  4. cocos2d_x_05_Box2D物理引擎

    一.认识Box2D 帮助文档,共69页 二.创建一个物理世界 先导入主头文件 #include <Box2D/Box2D.h> 三.物理世界一览 像素转成米 的比例因子 就是32 三.运动 ...

  5. 抽出SqlHelper

    什么叫SqlHelper,通过简单的翻译,能够获得这是对Sql的帮助,那么它究竟对我们的Sql做出了什么样的帮助呢? 在一款软件的设计编程中,总是会对数据库有连接的.假设你用的是SqlServer的数 ...

  6. 解决vmware“二进制转换和长模式与此平台兼容.....”问题

    问题描述: 启动vmware显现:1.二进制转换和长模式与此平台兼容....字等.: 2.vmware启动一会,系统直接重新启动,这个现象出如今惠普电脑上 问题原因: 出现这种原因一般都是因为系统Vi ...

  7. SE 2014年3月31日

    一. 描述OSPF划分区域的优势. OSPF划分区域的优势主要表现在以下几个方面: 1. 当网络中路由器的数量增大时,划分区域有利于减轻一部分性能较低的设备的处理和维护LSA数据库. 2. 区域的划分 ...

  8. maven仓库总结,maven私服搭建

    配置pom.xml依赖包时在这里找包的描述: http://search.maven.org/#browse 以java为根目录. mvn archtype:generate -DgroupId=zt ...

  9. 【ASP.NET】怎样使用类创建公共函数,在不同ASP.NET页面间反复调用

    为了降低代码冗余,应将公共函数写在类中,供不同ASP.NET页面调用. 1,先新建一个类,并在类中加入函数逻辑 namespace public_function_demo { public clas ...

  10. hdu5618 (三维偏序,cdq分治)

    给定空间中的n个点,问每个点有多少个点小于等于自己. 先来分析简单的二维的情况,那么只要将x坐标排序,那么这样的问题就可以划分为两个子问题,,这样的分治有一个特点,即前一个子问题的解决是独立的,而后一 ...