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. like-minded 都有什么意思_百度知道

    like-minded 都有什么意思_百度知道 like-minded 都有什么意思

  2. sys_refcursor的使用方法实例

    --创建过程,參数为sys_refcursor,为out型 create or replace procedure aabbsys_refcursor(o out sys_refcursor) is ...

  3. Java中定时器的使用

    import java.text.SimpleDateFormat; import java.util.Date; import java.util.Timer; import java.util.T ...

  4. 项目中那些事|ListView中嵌套ListView问题

    要在一个ListView中放入另一个ListView,也即在一个ListView的每个 item 中放入另外一个ListView.但刚开始的时候,会发现放入的子ListView会显示不完全(我这里只显 ...

  5. HDU 4643 GSM 暑期多校联合训练第五场 1001

    点击打开链接 我就不说官方题解有多坑了 V图那么高端的玩意儿 被精度坑粗翔了 AC前 AC后 简直不敢相信 只能怪自己没注意题目For the distance d1 and d2, if fabs( ...

  6. asp.net Form 认证【转】

    第一部分 如何运用 Form 表单认证 一.        新建一个测试项目 为了更好说明,有必要新建一个测试项目(暂且为“FormTest”吧),包含三张页面足矣(Default.aspx.Logi ...

  7. phpmailer【PHP邮件】的用法

    第一,需要下载PHPMailer文件包phpmailer. http://phpmailer.sourceforge.net/ 第二,确认你的服务器系统已经支持socket ,通过phpinfo(); ...

  8. 在html中禁用自己主动完毕

    输入框输入内容时总是显示历史输入历史记录,现禁用的方法是加入一个属性: <input type="text name="txt_xm" autocomplete=& ...

  9. 实现Android ListView 自动加载更多内容

    研究了几个小时终于实现了Android ListView 自动加载的效果. 说说我是怎样实现的.分享给大家. 1.给ListView增加一个FooterView,调用addFooterView(foo ...

  10. u-boot TFTP: &#39;Access violation&#39; (2)

    今天做tftp下载时间会遇到以下问题. --->8--- Load address: 0x20000000 Loading: * TFTP error: 'Access violation' ( ...