对YUI扩展的Gird组件 Part-2


Posted in Javascript onMarch 10, 2007

原文在这里 文章日期:2006-9-2

代码在这里


Sidney SheldonMaster of the GameWarner BooksBookSidney SheldonAre You Afraid of the Dark?Warner BooksBookSidney SheldonIf Tomorrow ComesWarner BooksBookSidney SheldonTell Me Your DreamsWarner VisionBookSidney SheldonBloodlineWarner BooksBookSidney SheldonThe Other Side of MeWarner BooksBookSidney SheldonA Stranger in the MirrorWarner BooksBookSidney SheldonThe Sky Is FallingWilliam Morrow & CompanyBookSidney SheldonNothing Lasts ForeverWarner BooksBookSidney SheldonThe Naked FaceWarner BooksBook
Author
Title
Manufacturer
Product Group
 Loading...

DataModel包含的类如下:

AbstractDataModel
提供事件event infrastructure等义接口interface
    '-DefaultDataModel
        定义了操控数据的API
        '-LoadableDataModel
            AJAX服务的基类
            '-XMLDataModel
                    包含以上的功能和提供XML的数据调用

看上去,这分得很详细,详细到好像过于复杂。但是在我看来,对于提升代码的可再用和扩展性,建立一个结实的DataModel是尤其重要的部分。正是基于这种方法,DataModel便能为其它的组件可再用,而不需要太多的组件--尽管它是庞大的。

如果你打开Js文件观察的话,将会发现只需几行代码便可设置XMLDataModel:

var schema = {
  tagName: 'Item',
  id: 'ASIN',
  fields: ['Author', 'Title', 'Manufacturer', 'ProductGroup']
};
this.dataModel = new YAHOO.ext.grid.XMLDataModel(schema);

实际加载的数据:

// 参数可以是url encoed或对象类型
var params = {'author': author};
//回调函数清除loading
this.dataModel.load('/blog/examples/amazon.php', params, this.clearIndicator);

表头能够对gird排序。现在进行新一番的搜索,例如输入John,数据加载后仍然按照你指定的方式排序。这是新的功能。

在一个实际项目中,我们需要一个能提供回调参数的,方便的异常处理机制。LoadableDataModel就就包含这种事件(onLoadException) 。

总的来说,一切进展顺利。有些Part1的反馈告诉,Gird在Safari和其它浏览器上能够工作^^。说真的,有些反馈真的不错! thanks!

Javascript 相关文章推荐
CSS(js)限制页面显示的文本字符长度
Dec 27 Javascript
js获取本机的外网/广域网ip地址完整源码
Aug 12 Javascript
jquery easyui滚动条部分设置介绍
Sep 12 Javascript
js中function()使用方法
Dec 24 Javascript
详解AngularJS中自定义指令的使用
Jun 17 Javascript
详谈js对url进行编码和解码(三种方式的区别)
Aug 16 Javascript
Node.js使用cookie保持登录的方法
May 11 Javascript
vue 国际化 vue-i18n 双语言 语言包
Jun 07 Javascript
深入理解 JS 垃圾回收
Jun 03 Javascript
微信小程序事件流原理解析
Nov 27 Javascript
Vue结合路由配置递归实现菜单栏功能
Jun 16 Javascript
Vue获取微博授权URL代码实例
Nov 04 Javascript
对YUI扩展的Gird组件 Part-1
Mar 10 #Javascript
学习YUI.Ext第七日-View&JSONView Part Two-一个画室网站的案例
Mar 10 #Javascript
学习YUI.Ext 第六天--关于树TreePanel(Part 2异步获取节点)
Mar 10 #Javascript
学习YUI.Ext 第七天--关于View&JSONView
Mar 10 #Javascript
学习YUI.Ext 第六天--关于树TreePanel(Part 1)
Mar 10 #Javascript
学习YUI.Ext第五日--做拖放Darg&Drop
Mar 10 #Javascript
学习YUI.Ext 第四天--对话框Dialog的使用
Mar 10 #Javascript
You might like
zend framework多模块多布局配置
2011/02/26 PHP
如何使用php判断所处服务器操作系统的类型
2013/06/20 PHP
jQuery+PHP实现的掷色子抽奖游戏实例
2015/01/04 PHP
php通过各种函数判断0和空
2020/07/04 PHP
document对象execCommand的command参数介绍
2006/08/01 Javascript
XHTML下,JS浮动代码失效的问题
2009/11/12 Javascript
jquery异步循环获取功能实现代码
2010/09/19 Javascript
jQuery处理json数据返回数组和输出的方法
2015/03/11 Javascript
jQuery()方法的第二个参数详解
2015/04/29 Javascript
纯javascript实现分页(两种方法)
2015/08/26 Javascript
JavaScript组件开发完整示例
2015/12/15 Javascript
JavaScript中自带的 reduce()方法使用示例详解
2016/08/10 Javascript
Node.js如何实现注册邮箱激活功能 (常见)
2017/07/23 Javascript
Vue中的Props(不可变状态)
2018/09/29 Javascript
Node.js Windows Binary二进制文件安装方法
2019/05/16 Javascript
详解vuejs中执行npm run dev出现页面cannot GET/问题
2020/04/26 Javascript
[43:41]OG vs Newbee 2019国际邀请赛淘汰赛 胜者组 BO3 第一场 8.21.mp4
2020/07/19 DOTA
Python实现Youku视频批量下载功能
2017/03/14 Python
python简单实现操作Mysql数据库
2018/01/29 Python
tensorflow实现KNN识别MNIST
2018/03/12 Python
python中的decorator的作用详解
2018/07/26 Python
python中的句柄操作的方法示例
2019/06/20 Python
python如何实现代码检查
2019/06/28 Python
Myprotein蛋白粉美国官网:欧洲畅销运动营养品牌
2016/11/15 全球购物
Missguided美国官网:英国时尚品牌
2018/01/18 全球购物
New Balance加拿大官方网站:运动鞋和健身服装
2018/11/19 全球购物
德国二手设计师时装和复古时装跳蚤市场:Mädchenflohmarkt
2020/11/09 全球购物
Java如何读取CLOB字段
2013/10/10 面试题
报社实习生自荐信
2014/01/24 职场文书
市场营销大学生职业规划书
2014/02/25 职场文书
感恩教师节主题班会
2015/08/12 职场文书
文明和谐家庭事迹材料(2016精选版)
2016/02/29 职场文书
Python序列化与反序列化相关知识总结
2021/06/08 Python
Java并发编程之详解CyclicBarrier线程同步
2021/06/23 Java/Android
redis 存储对象的方法对比分析
2021/08/02 Redis
nginx sticky实现基于cookie负载均衡示例详解
2022/12/24 Servers