源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Zen Coding 快速编写HTML/CSS代码的实现

  • 时间:2021-05-11 23:45 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Zen Coding 快速编写HTML/CSS代码的实现
在本文中我们将展示一种新的使用仿CSS选择器的语法来快速开发HTML和CSS的方法。它由[url=http://www.smashingmagazine.com/author/sergey-chikuyonok/]Sergey Chikuyonok[/url]开发。 你在写HTML代码(包括所有标签、属性、引用、大括号等)上花费多少时间?如果你的编辑器有代码提示功能,你编写的时候就会容易些,但即便如此你还是要手动敲入很多代码。 在JavaScript方面,当我们想要在一个页面上获取某个特定的元素时,我们就会遇到同样的问题,我们必须写很多代码,这就变得难于维护和重用。JavaScript框架应运而生,它们同时引入了CSS选择器引擎。现在,你可以使用简单的CSS表达式来获取DOM元素,这相当酷。 但是,如果你不仅仅可以用CSS的选择器布局和定位元素,还能[b]生成代码[/b]会怎么样?比如,如果你这样写:
[url=http://www.1sucai.cn/softs/33871.html]Zen Coding for Dreamweaver v.0.7[/url] 测试通过 有些迷惑吧?今天,我将向你介绍Zen Coding,一组用于快速HTML和CSS编码的工具。最初由Vadim Makeev在2009年4月提出(文章为俄语),由鄙人(也就是我)开发了数月并最终达到比较成熟的状态。Zen Coding由两个核心组件组成:一个缩写扩展器(缩写为像CSS一样的选择器)和上下文无关的HTML标签对匹配器。看一下这个演示视频来看一下它们能为你做些什么。 [video]http://player.youku.com/player.php/sid/XMTM4NDQwNzgw/v.swf[/video] [b]注意:[/b]该视频原版位于Vimeo,但是要看的话需要翻[和谐]墙先,地址在这里:[url=http://vimeo.com/7405114]http://vimeo.com/7405114[/url],上面的视频是我费尽周折从Vimeo上下载下来上传到优酷的,上传后质量竟被大打折扣了,囧。youtube上也有一份视频,是基于Aptana的演示,一样很精彩:[url=http://www.youtube.com/watch?v=ug84Ypwqfzk]http://www.youtube.com/watch?v=ug84Ypwqfzk[/url]。PS:貌似youtube要比Vimeo翻[和谐]墙容易些,不过如何翻[和谐]墙不在本站讨论范围。 如果你想跳转到详细介绍和使用指南,请看一下演示页面并立刻下载你适用的插件: [h3]Demo[/h3] [list] [*][url=http://zen-coding.ru/demo/]Demo[/url] (使用 [i]Ctrl + ,[/i] 展开缩写,需要JavaScript支持) [/*][*][url=http://labs.qianduan.net/zencoding/]中文版演示[/url] [/*][/list] [h3]下载(完全支持)[/h3] [list] [*][url=http://code.google.com/p/zen-coding/downloads/detail?name=Zen.Coding-Aptana.v0.5.zip]Aptana[/url] (跨平台); [/*][*]Coda, via [url=http://github.com/sergeche/tea-for-coda/downloads]TEA for Coda[/url] (Mac); [/*][*]Espresso, via [url=http://github.com/sergeche/tea-for-espresso/downloads]TEA for Espresso[/url] (Mac); [/*][/list] [h3]下载(部分支持,只支持“展开缩写”)[/h3] [list] [*][url=http://code.google.com/p/zen-coding/downloads/detail?name=Zen%20Coding%20for%20TextMate%20v0.3.1.zip]TextMate[/url] (只能用于Mac机,Windows可以使用E-text编辑器替代); [/*][*][url=http://code.google.com/p/zen-coding/downloads/detail?name=TopStyle.Zen.Coding.1.0.zip]TopStyle[/url]; [/*][*][url=http://code.google.com/p/zen-coding/downloads/detail?name=Sublime.Zen.Coding.1.1.3.zip]Sublime Text[/url]; [/*][*][url=http://www.kryogenix.org/days/2009/09/21/zen-coding-for-gedit]GEdit[/url]; [/*][*][url=http://zen-coding.googlecode.com/files/Zen.Coding-Dreamweaver.v0.4.zip]Dreamweaver CS4[/url] [/*][*][url=http://zen-coding.ru/demo/]editArea在线编辑器[/url]; [/*][*][url=http://labs.qianduan.net/zencoding/]Zen Coding在线编辑器中文版[/url] [/*][/list] 现在让我们看一下这些工具是如何工作的吧。 [h2]展开缩写[/h2] 展开缩写功能将类似CSS的选择器转换为XHTML代码。术语“缩写”可能会有点儿难以理解。为什么不直接称之为“CSS选择器”呢?嗯,首要原因是语义化:“选择器”意为[i]选择[/i]一些东西,但是在这里我们事实上是[i]生成[/i] 一些东西,[b]是写一个长代码的较短的替代[/b]。其次,它只是使用真实的CSS选择器语法的一个小的子集,并添加了一些新的操作符。 这里是一个支持的属性和操作符的列表: [list] [*]E 元素名称(div, p); [/*][*]E#id 使用id的元素(div#content, p#intro, span#error); [/*][*]E.class 使用类的元素(div.header, p.error.critial). 你也可以联合使用class和idID: div#content.column.width; [/*][*]E>N 子代元素(div>p, div#footer>p>span); [/*][*]E+N 兄弟元素(h1+p, div#header+div#content+div#footer); [/*][*]E*N 元素倍增(ul#nav>li*5>a); [/*][*]E$*N 条目编号 (ul#nav>li.item-$*5); [/*][/list] 正如你能看到的,你已经知道如何使用Zen Coding了:只是些一个简单的仿CSS选择器(呃,“缩写”抱歉),就像这样…
[url=]<li><a href=""></a></li> <li><a href=""></a></li> <li><a href=""></a></li>
最后一个——条目编号用于当你想用索引标记重复的元素的情况。假设你想生成class为item1、item2和item3的3个<div>元素。你可以写成这样的缩写,div.item$*3: 只需在你想要索引出现的任何class或id属性上添加一个美元符号即可,而且想要多少都可以。那么,这样…
[url=http://code.google.com/p/zen-coding/source/browse/branches/serge.che/aptana/zen_settings.js]zen_settings.js[/url][/i]描述了输出元素。这是一个简单的JSON文件,描述每种语言的缩写(是的,你可以为不同的句法定义缩写,比如HTML、XSL、CSS等)。通用的语言缩写定义看起来就像这样:
[url=]... } }
[h3]元素类型[/h3] Zen Coding有两个主要的元素类型:[b]“片段(snippets)” 和 “缩写(abbreviations)”。[/b]片段就是随意的代码碎片,而缩写是标签定义。通过片段,你可以写出你想要的任何代码,它也会照你写的格式输出;但是你必须手动的格式化它(使用\n 和\t实现换行和缩进) 并将${child}变量放到你想要输出子元素的地方,就像这样:cc:ie6>style。如果你不使用${child}变量,子元素将会输出于代码片段的[b]后面[/b]。 有了缩写,您必须编写标记定义,而且语法是非常重要的。通常,你必须写一个简单的带有所有默认的属性的标签,比如: <a href=”"></a>。当Zen Coding被加载后,它会解析一个标签定义到一个描述该标签的名字、属性(包括它们的顺序)以及该标签是否为空的特定的对象中。所以,如果你写<img src=”" alt=”" />,你会告诉Zen Coding这个标签必须是空的,然后“扩展缩写”行为就会在输出之前为它使用特定的规则。 对于片段和缩写,你可以添加一个管道符号,它告诉Zen Coding当缩写被展开的时候光标会被定位到哪里。默认的,Zen Coding 将光标放在空属性的引号中间以及开始和关闭标签的中间。 [h3]例子[/h3] 那么,这里解释一下当你写了一个缩写并召唤“展开缩写”行动时发生的事情。首先,它将一个完整的缩写分开为独立的元素:这样div>a 会被分成div 和a 元素,当然也会维持他们的关系。然后,每个元素,解析器先在代码片段内而后在缩写中寻找定义。如果它找不到,将会使用元素的名字作为新的标签,并为其添加缩写中定义的id和class。比如,如果你写mytag#example,解析器在片段或缩写中找不到mytag定义,它就会输出<mytag id=”example”><mytag>。 我们制作了很多
默认的CSS[/url]和[url=http://code.google.com/p/zen-coding/wiki/ZenHTMLElementsEn]HTML缩写和片段[/url]。你会发现学习使用Zen Coding可以增加你的生产力。 [h2]HTML 标签对匹配器[/h2] 对于HTML编码者的另一个非常常见的任务是寻找一个元素的标签对。例如你想选择整个<div id=”content”>标签并将其移动到其它地方或者删除它。或者有可能你在寻找一个关闭标签并想知道它属于那个开始标签。 不幸的是,很多现代开发工具在该功能方面有所欠缺。那么我就决定写一个我自己的标签对匹配器作为Zen Coding的一部分。不过它依然在beta阶段并尚存一些问题,但它可以工作的很不错并很快。不是浏览整个文档(像通常的那种HTML标签对匹配器的做法),它从光标的当前位置开始寻找相关的标签。这使得它非常快并且[i]上下文无关[/i]:它甚至可以用于这段[b]JavaScript代码片段[/b]:
[url=]<li class="item2"><a href=""><span>Products</span></a></li> <li class="item3"><a href=""><span>News</span></a></li> <li class="item4"><a href=""><span>Blog</span></a></li> <li class="item5"><a href=""><span>Contact Up</span></a></li> </ul> </div>
你可以看到,Zen Coding是一个强大的文本处理工具。 [h2]快捷键[/h2] [list] [*]Ctrl+, 展开缩写 [/*][*]Ctrl+M 匹配对 [/*][*]Ctrl+H 使用缩写包括 [/*][*]Shift+Ctrl+M 合并行 [/*][*]Ctrl+Shift+? 上一个编辑点 [/*][*]Ctrl+Shift+? 下一个编辑点 [/*][*]Ctrl+Shift+? 定位匹配对 [/*][/list] 这些快捷键是可以自定义的。 [h2]在线演示[/h2] 你已经学到很多关于Zen Coding如何工作以及它是如何使你的编码更容易了。现在为什么不自己尝试一下呢?因为Zen Coding是用纯JavaScript开发并迁移到Python,它甚至可以用于浏览器内部,这令它成为引入到CMS的首选。 [list] [*]
Demo[/url] (使用 [i]Ctrl + ,[/i] 展开缩写,需要JavaScript支持) [/*][*][url=http://labs.qianduan.net/zencoding/]中文版演示[/url] [/*][/list] [h2]支持的编辑器[/h2] Zen Coding并不依赖某个特定的编辑器。它是一个只处理文本的出色的组件:它获取文本、做一些处理并放回新的文本(或索引,用于标签匹配)。Zen Coding由JavaScript和Python编写,所以它实际上可以运行于任何平台。在Windows,你可以运行JavaScript版本,而Mac和Linux 分支可以使用Python版。 如果让你的编辑器支持Zen Coding,你需要写一个特定的可以在你的编辑器和Zen Coding之间转换数据的插件。问题是一个编辑器可能不会完整的支持Zen Coding因为它本身的插件系统。比如,[url=http://macromates.com/]TextMate[/url]通过使用脚本输出替换当前行很容的就支持了“展开缩写”功能,但是它不能处理标签对匹配因为没有标准的方法请求TextMate来选择内容。 [h3]完全支持[/h3] [list] [*][url=http://code.google.com/p/zen-coding/downloads/detail?name=Zen.Coding-Aptana.v0.5.zip]Aptana[/url] (跨平台); [/*][*]Coda, via [url=http://github.com/sergeche/tea-for-coda/downloads]TEA for Coda[/url] (Mac); [/*][*]Espresso, via [url=http://github.com/sergeche/tea-for-espresso/downloads]TEA for Espresso[/url] (Mac); [/*][/list] [h3]部分支持(只支持“展开缩写”)[/h3] [list] [*][url=http://code.google.com/p/zen-coding/downloads/detail?name=Zen%20Coding%20for%20TextMate%20v0.3.1.zip]TextMate[/url] (只能用于Mac机,Windows可以使用E-text编辑器替代); [/*][*][url=http://code.google.com/p/zen-coding/downloads/detail?name=TopStyle.Zen.Coding.1.0.zip]TopStyle[/url]; [/*][*][url=http://code.google.com/p/zen-coding/downloads/detail?name=Sublime.Zen.Coding.1.1.3.zip]Sublime Text[/url]; [/*][*][url=http://www.kryogenix.org/days/2009/09/21/zen-coding-for-gedit]GEdit[/url]; [/*][*][url=http://zen-coding.googlecode.com/files/Zen.Coding-Dreamweaver.v0.4.zip]Dreamweaver CS4[/url] [/*][*][url=http://zen-coding.ru/demo/]editArea在线编辑器[/url]; [/*][*][url=http://labs.qianduan.net/zencoding/]Zen Coding在线编辑器中文版[/url] [/*][/list] Aptana是我主要的开发环境,它使用一个JavaScript版本的Zen Coding。它也包含很多其它的我用于日常工作的工具,所以任何一个新的Zen Coding版本都将会首先对Aptana可用,然后部署到Python并兼容其它的编辑器。 Coda和Espresso 插件被杰出的[url=http://onecrayon.com/tea/]Text Editor Actions[/url] (TEA) 平台支持,由[url=http://beckism.com/]Ian Beck[/url]开发。原始的源代码[url=http://github.com/onecrayon]在GitHub上[/url],但我还是制作了[url=http://github.com/sergeche/]我自己的分支[/url]以整合Zen Coding的特性。 [h2]总结[/h2] 很多尝试过Zen Coding的人都说它改变了他们写页面的方式。当然还有很多事情要做,还有很多的编辑器需要被支持以及一些文档要写。请浏览[url=http://code.google.com/p/zen-coding/w/list]现在的文档[/url] 以及[url=http://code.google.com/p/zen-coding/source/browse/#svn/branches/serge.che]源代码[/url]以寻找你的问题的答案。希望你喜欢Zen Coding! [h2]附:Zen coding的具体用法[/h2] 遗憾的是, 本文原作者并没有说明zen coding的具体用法,神飞认为有必要做以下简要的说明。这里就以Aptana/Eclipse和Dreamweaver为例,其它编辑器平台暂不描述,如有疑问可以在评论中与前端观察的网友交流。 [h3]Aptana/Eclipse[/h3] 由于Aptana本身就是基于Eclipse的,所以,Zen Coding也是支持Eclipse的,只是需要一个EclipseMonkey插件的支持,Aptana已经封装了这个插件,所以如果你使用Aptana,下面的第一步可以跳过。 [list=1] [*]通过更新网站安装EclipseMonkey: [url=http://download.eclipse.org/technology/dash/update]http://download.eclipse.org/technology/dash/update[/url](如果你使用Aptana,可跳过这一步) [/*][*]在你的当前工作去创建一个顶级的项目,给它命名,比如,就叫[b]zencoding[/b] [/*][*]在新创建的项目中创建[b]scripts[/b]文件夹 [/*][*]解压缩下载的ZIP插件包到该文件夹。项目结构看起来就像这样: [img]http://files.jb51.net/upload/201101/20110103232738221.png[/img] [/*][*]安装之后,Aptana的菜单栏中的“脚本(Script)”菜单中将会出现Zen coding相关子菜单 [/*][/list] 注意事项: [list] [*]Aptana版的官方插件是基于MAC机的,如果你用的是Windows,需要手动更改快捷键(在每个文件头部的注释片段中更改) [/*][*]官方的文件编码有点儿乱,修改官方js的时候,请注意[b]编码问题[/b],修改不当会造成相关功能的丢失; [/*][/list] [h3]DreamWeaver[/h3] 好消息是,现在已经有了Zen coding for DreamWeaver插件,坏消息是,该插件支持的功能很少,只支持展开缩写功能。而且默认的快捷键是无效的。只能在“命令”菜单中点击操作。另外,没有测试该插件是不是只支持CS4版本。不过比较好的是,作者将本插件的源码也放出了,你可以自定义一个Dreamweaver的插件。 事实上,官方的DW插件在Windows下有点儿bug,就是会出现空白的行,我简单的修正了下,重新编译了个包,在本机测试没问题,感兴趣的童鞋可以下载尝试:[url=http://www.boxcn.net/shared/c71z7x7sfe]http://www.boxcn.net/shared/c71z7x7sfe[/url] PS:官方的DW插件已经更新,[b]推荐[/b][url=http://zen-coding.googlecode.com/files/Zen%20Coding.mxp]到官方去下载[/url]。新的插件添加了更多的功能支持。UPDATE @ 12-23-2009 [b]特别推荐[/b]:豪情同学将缩写给实践了一番,总结出了很多很棒的用例,推荐大家[url=http://www.1sucai.cn/article/25880.htm]前去学习[/url]。 [h2]原作者介绍:[/h2] Sergey Chikuyonok是一位俄罗斯的前端开发工程师和作者,他在优化方面有很大的热情:从图片、JavaScript效果到工作流程和节省时间的编码。访问[url=http://chikuyonok.ru/]他的主页[/url]和[url=http://twitter.com/chikuyonok]他的Twitter[/url]。 原文来自:http://www.qianduan.net/zen-coding-a-new-way-to-write-html-code.html
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部