Discuz教程网

dojo学习第一天 Tab选项卡 实现

[复制链接]
authicon dly 发表于 2011-9-6 21:08:58 | 显示全部楼层 |阅读模式
其实不然,用《精通Dojo》里的话来说就是"Dojo不只是一个程序库,而是一个工具包",它比其他所有的JS库的插件更全面更广阔。它包含大约40个用户界面控件、1个图形框架、cometd支持、1个打包系统,还有其他的一些东西。 从dojo官方网站 上下载最新版1.6,解压下来,它有三个文件夹分别是:


1. dojo: 是Dojo基础,你要做的其它事情都是在它的基础上,类似于jquery.js文件,但比它更丰富了一些其他功能;

2. dijit : Dojo的小部件框架及内建的小控件集.(大约有40个HTML用户小控件);
3 dojox: Dojo的扩展库,包含了从表格小部件到绘图库的所有功能。

了解了这些就足够了,虽然才发布到1.6,没有像jquery那样到6.1,但dojo绝对是强大的,选择它,将是你一生不变的追求。(广告词)
(注:dojo始于2004年,alex发起,然后经过众多DHTML专家开发,所以它现在已经很成熟了。)
接下来,我们要来配置我们的第一个例子,准备好了吗?dojo旅程正式开始,我们要做一个表单注册的例子.

首先我们要引用它的主题样式:
  1. <style>
  2. @import url(../dijit/themes/tundra/tundra.css);
  3. @import url(../dojo/resources/dojo.css);
  4. </style>
复制代码

themes就是主题样式了,里面已经存在了几个,我任选了其中的"tundra",然后还要引用下dojo.css。再就是引用dojo基础文件dojo.js:

<script src='../dojo/dojo.js' djConfig='parseOnLoad:true'></script>
这里要注意的是djConfig,由于我们要用到声明式小部件,所以需要parse,这个使用起来会简单点,如果用编程式写法就不需要了,只需注意下就行了。然后是引用parser.js和ContentPane.js,parser是使用声明式所必需的,ContentPane是内容面板所必需的。在dojo里引用的方式是调用require方法,这个和PHP里的 require_once很相似,就是只引用一次该文件.

  1. <script>
  2. dojo.require("dojo.parser");
  3. dojo.require('dijit.layout.ContentPane');
  4. dojo.require('dijit.layout.TabContainer');
  5. </script>
复制代码

这里的"."写法,可以理解为文件夹下的类,或者命名空间,和AS3里很相似。大家是不是发现多了一个TabContainer,这个是我们要用到的选项卡切换小插件了。如果调用这个插件呢,很简单,只需要在我们要使用的地方用dojoType属性指明就行了。
  1. <div dojoType='dijit.layout.TabContainer' class="myForm">
  2. <div dojoType='dijit.layout.ContentPane' title='个人信息'>
  3. <label for="firstName">First Name:</label><input type='text' id='firstName' /></br>
  4. <label for="lastName">Last Name:</label><input type='text' id='lastName' /></br>
  5. <label for="middleInitial">Middle Initial:</label><input type='text' id='middleInitial' /></br>
  6. </div>
  7. <div dojoType='dijit.layout.ContentPane' title='联系地址'>
  8. <label>Email:</label><input type='text' id='email' /></br>
  9. <label>Address:</label><input type='text' id='address' /></br>
  10. <label>State:</label><input type='text' id='state' /></br>
  11. <label>City:</label><input type='text' id='city' /></br>
  12. <label>Country:</label><input type='text' id='country' /></br>
  13. </div>
  14. <div dojoType='dijit.layout.ContentPane' title='联系电话'>
  15. <label>Work Phone:</label><input type='text' id='workPhone' /></br>
  16. <label>Home Phone:</label><input type='text' id='homePhone' /></br>
  17. <label>Cell Phone:</label><input type='text' id='CellPhone' /></br>
  18. </div>
  19. </div>
复制代码

然后我们来一句句理解, dojoType='dijit.layout.TabContainer'是指让容器拥有tab选项卡功能,dojoType='dijit.layout.ContentPane'这个是指该容器是一个内容块,也就是单个的选项卡.

最后就没了,这个简单的选项卡就完成了。大家是不是觉得很奇怪,我们竟然没写其它的一行代码就完成了这个功能?这就是声明式小插件的好处了,因为你给dojoType声明了,它就会自动去绑定这个功能。
好了,这是我第一天的正式接触dojo,可能有理解错误的地方,大家可以指出来,我们一起学习进步。 如果你喜欢,我会写第二篇甚至更多.

本文的最终示例图:demo演示请查阅:http://www.lovewebgames.com/dojoroot/myStudy/study_001.html


完整代码:

  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  2. <html>
  3. <head>
  4. <title>第一天 </title>
  5. <meta name="Generator" content="EditPlus">
  6. <meta name="Author" content="">
  7. <meta name="Keywords" content="">
  8. <meta name="Description" content="">
  9. <style>
  10. @import url(../dijit/themes/tundra/tundra.css);
  11. @import url(../dojo/resources/dojo.css);
  12. </style>
  13. <script src='../dojo/dojo.js' djConfig='parseOnLoad:true'></script>
  14. <script>
  15. dojo.require("dojo.parser");
  16. dojo.require('dijit.layout.ContentPane');
  17. dojo.require('dijit.layout.TabContainer');
  18. </script>
  19. <style>
  20. .myForm{width:600px;height:300px;line-height:1.6;}
  21. .myForm label{width:150px;float:left;}
  22. </style>
  23. </head>

  24. <body class="tundra">

  25. <div dojoType='dijit.layout.TabContainer' class="myForm">
  26. <div dojoType='dijit.layout.ContentPane' title='个人信息'>
  27. <label for="firstName">First Name:</label><input type='text' id='firstName' /></br>
  28. <label for="lastName">Last Name:</label><input type='text' id='lastName' /></br>
  29. <label for="middleInitial">Middle Initial:</label><input type='text' id='middleInitial' /></br>
  30. </div>
  31. <div dojoType='dijit.layout.ContentPane' title='联系地址'>
  32. <label>Email:</label><input type='text' id='email' /></br>
  33. <label>Address:</label><input type='text' id='address' /></br>
  34. <label>State:</label><input type='text' id='state' /></br>
  35. <label>City:</label><input type='text' id='city' /></br>
  36. <label>Country:</label><input type='text' id='country' /></br>
  37. </div>
  38. <div dojoType='dijit.layout.ContentPane' title='联系电话'>
  39. <label>Work Phone:</label><input type='text' id='workPhone' /></br>
  40. <label>Home Phone:</label><input type='text' id='homePhone' /></br>
  41. <label>Cell Phone:</label><input type='text' id='CellPhone' /></br>
  42. </div>
  43. </div>
  44. </body>
  45. </html>
复制代码

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x



上一篇:IE6、IE7中setAttribute不支持class/for/rowspan/colspan等属性
下一篇:js中设置元素class的三种方法小结
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1314学习网 ( 浙ICP备10214163号 )

GMT+8, 2025-7-9 23:28

Powered by Discuz! X3.4

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表