YUI3学习(一)---入门

转载 2012年03月26日 12:59:48

原文地址:http://houfeng0923.iteye.com/blog/1113593


 学习YUI3有一段时间,并且应用在了一些小项目的前端开发中,感觉还是蛮不错的,所以决定开始记录下YUI3的学习历程和个人经验。
     YUI3在前身YUI2基础上进行了大量的重新设计,并不只是简单的版本升级。YUI3强调代码重用,将功能做了级别划分和颗粒化的设计。在概念上抽象出 核心、工具、和组件类,分别放在不同的目录结构中,需要的时候自行去引用。为动态加载的框架设计做铺垫。

YUI 3重点是代码的组织和结构。以下是结构图。


YUI3在结构上分为四大类:

种子: 该模块是YUI3的单一核心,页面都必须包含该模块,该模块提供加载功能,所以可以堪称是YUI的一个种子。在YUI3中扮演引导层的作用,通过在页面引入种子相关文件,调用YUI().use()方法可以安全快速的加载YUI3核心类和组件类。

包含YUI Base、Get和Loader模块。

核心: 核心模块为YUI3下游组件提供通用依赖。该模块包括OOP模块(提供对象继承机制,DOM等绝大多数模块直接或间接依赖OOP)、Dom模块(提供基础的DOM操作与选择类)、Node模块(基于Dom模块,提供文档节点的创建、选择和操作等方法,相比YUI2有了很大的精简)、Event模块(提供屏蔽浏览器差异的事件注册和响应机制,同时提供高级自定义事件的功能)

组件框架:组件框架基于YUI核心框架。从下到上依次基于Attribute、Base、Widget模块组成;同时提供Plugin模块实现灵活扩展。组件框架是建立和扩展组件的基础。

组件: YUI3提供的高度模块化可复用的组件,根据程序按需引入相关模块即可。YUI3目前提供了Animation、Drag and Drop、IO、Cookies、JSON 等基础组件模块。


 

接下来总结一下YUI3的部分特点:

1,动态按需加载

YUI3种子中的Get、Loader模块是动态按需加载的基础,YUI3框架通过良好的结构组织,可以根据程序引入的所需模块名称自动计算依赖模块,实现按需加载;YUI3动态加载的优势:

1)将js文件写入script标签,每一个标签都会占用一个http请求(即使是304.),而动态加载的文件缓存后则不必发起真实的http请求。提高了框架的性能。

    2) 动态加载可以避免开发人员额外关注js文件之间的依赖和排序及重复问题。  引入的时候只需要引入需要模块的名称即可,依赖关系不需要花费精力处理。

       3) 动态加载利于页面代码语义化,只需要关心 ‘需要什么’。

 

2,细粒度化设计

YUI3对每个模块都进行了更细粒度的划分。比如,dom模块,划分为了 base,screen,style,selector-css2,selector-css3,selector-native等几个小模块,对于我们控制页面的载入的数据量有很大帮助。

下图是YUI3各个细粒度模块的列表和大小。


3,安全沙箱

 页面的每一个YUI实例能够被自包含、保护和限制(YUI().use())。这种和其他YUI实例的分离,能够配合你的特殊函数需求,并且能让不同的YUI 版本更好的运行在一起。在很大程度上方便了不同开发者对同一页面的并行开发。

这里YUI().use(”,function(Y){…})就是一个安全沙箱,可以确保这里面的Y是纯天然无污染的,Y实例里有什么功能完全取决于use里传进的模块名称,function(Y){}里面的程序跟外界是隔离的,在里面创建的变量(除了全局变量)以及对YUI的添加修改都不会影响到同个页面上其他人写的程序。

 

 

 

 

YUI3学习路线

目前关于YUI3的中文资料并不多,也未发现一本介绍YUI3的书籍。所以目前最全的文档就只有yahoo 的官方YUI3介绍、API和examples(http://developer.yahoo.com/yui/3/)。根据网友的学习经验,学习路线最好是依据官方说明的顺序学习(YUI3核心(YUI Global Object\Node\Event)->组件框架->组件);循序渐进,逐步了解YUI组织结构及使用方法。

 

 

hello YUI3 demo

 

首先下载YUI3开发包(在http://developer.yahoo.com/yui/3/ 选择Download  full developer kit,包含YUI3代码、api和例子)。解压后拷贝build文件夹里的yui3文件夹到自己的工程中。然后在页面引入yui3-min.js。

<script type="text/javascript" src="../../yui/build/yui/yui-min.js"></script>
<script type="text/javascript">
YUI().use('*',function(Y){  
    alert('hello YUI3');       
}); 
</script>


YUI介绍以及快速入门 Yahoo的JS框架

1、YUI介绍: YUI库是一系列使用Javascript和CSS创建的的工具和控件集,用来创建富客户端Web应用。使用到了DOM scripting,DHTML和AJAX。 2、在页面中...

本地jekyll突然不能正常工作,遇到的问题全可以在这个文章中找到答案。

搞不清怎么回事,前两天Jekyll本地环境还是好的,可是,今天打开,发现不正常了,报各种错误。 奇怪,难道jekyll,python,ruby 这几个软件自动更新了,很是不解。 然后就先根据错误找...
  • jearmy
  • jearmy
  • 2015年01月15日 23:13
  • 2310

清华梦的粉碎——写给清华大学的退学申请

清华梦的诞生 小时候,妈妈给我一个梦。她指着一个大哥哥的照片对我说,这是爸爸的学生,他考上了清华大学,他是我们中学的骄傲。长大后,你也要进入清华大学读书,为我们家争光。我不知道清华是什么样子,但是我...

YUI3学习(一)---入门

原文地址 http://houfeng0923.iteye.com/blog/1113593 学习YUI3有一段时间,并且应用在了一些小项目的前端开发中,感觉还是蛮不错的,所以决定开始记录下YUI3...

yui3学习(-)简单介绍

YUI3强调代码重用,将功能做了级别划分和颗粒化的设计。在概念上抽象出核心、工具、和组件类,分别放在不同的目录结构中,需要的时候自行去引用。为动态加载的框架设计做铺垫。 YUI3在结构上分为四大类...

3、YUI部分中文文档2

6.4.     AutoComplete 用户在文本输入框中输入文字时,该组件通过输入的内容查找符合输入条件的内容,并显示出所有符合条件的内容,供用户能够很快的完成正确的输入。   ...

YUI3的css栅格系统解析

一、YUI3的css栅格系统与浮动布局的比较 css的布局方案不胜枚举,主流的有以下几种:浮动布局、负外边距布局、绝对/相对定位布局法、表格布局法,而浮动布局是目前应用最广的,但总所周知,浮动布局固...

YUI 3 Cookbook

  • 2012年09月13日 19:13
  • 4.22MB
  • 下载

YUI3 dialog组件

  • 2010年07月05日 11:43
  • 16KB
  • 下载

YUI 3:Node

YUI的Node功能为获取、创建、操作DOM节点提供很易懂的方式。每个Node实例代表一个DOM节点,每个NodeList代表一系列DOM节点。我们可以管理Node的className(myNode....
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:YUI3学习(一)---入门
举报原因:
原因补充:

(最多只允许输入30个字)