对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 相关文章推荐
javascript 面向对象编程基础:继承
Aug 21 Javascript
javascript contains和compareDocumentPosition 方法来确定是否HTML节点间的关系
Feb 04 Javascript
屏蔽F1~F12的快捷键的js函数
May 06 Javascript
javascript作用域链(Scope Chain)用法实例解析
Nov 30 Javascript
微信小程序开发教程-手势解锁实例
Jan 06 Javascript
浅谈node中的cluster集群
Jun 02 Javascript
Vue页面跳转动画效果的实现方法
Sep 23 Javascript
解决angular双向绑定无效果,ng-model不能正常显示的问题
Oct 02 Javascript
vue里如何主动销毁keep-alive缓存的组件
Mar 21 Javascript
Vue使用screenfull实现全屏效果
Sep 17 Javascript
JavaScript 声明私有变量的两种方式
Feb 05 Javascript
html5中sharedWorker实现多页面通信的示例代码
May 07 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
用PHP实现ODBC数据分页显示一例
2006/10/09 PHP
php下封装较好的数字分页方法
2010/11/23 PHP
PHP中simplexml_load_string函数使用说明
2011/01/01 PHP
PHP echo,print,printf,sprintf函数之间的区别与用法详解
2013/11/27 PHP
php去掉URL网址中带有PHPSESSID的配置方法
2014/07/08 PHP
PHP获取文件扩展名的方法实例总结
2017/06/10 PHP
XP折叠菜单&仿QQ2006菜单
2006/12/16 Javascript
对JavaScript的eval()中使用函数的进一步讨论
2008/07/26 Javascript
JavaScript 变量命名规则
2009/09/23 Javascript
chrome原生方法之数组
2011/11/30 Javascript
一个封装js代码-----展开收起效果示例
2013/07/03 Javascript
Javascript获取HTML静态页面参数传递值示例
2013/08/18 Javascript
JavaScript中的类与实例实现方法
2015/01/23 Javascript
超赞的动手创建JavaScript框架的详细教程
2015/06/30 Javascript
AngularJS表格详解及示例代码
2016/08/17 Javascript
JavaScript排序算法动画演示效果的实现方法
2016/10/18 Javascript
AngularJS学习笔记(三)数据双向绑定的简单实例
2016/11/08 Javascript
vue源码入口文件分析(推荐)
2018/01/30 Javascript
探秘vue-rx 2.0(推荐)
2018/09/21 Javascript
layui框架与SSM前后台交互的方法
2019/09/12 Javascript
JS回调函数深入理解
2019/10/16 Javascript
[05:04]DOTA2上海特级锦标赛主赛事第二日TOP10
2016/03/04 DOTA
Python多进程通信Queue、Pipe、Value、Array实例
2014/11/21 Python
Python json模块使用实例
2015/04/11 Python
python读取Excel实例详解
2018/08/17 Python
django迁移文件migrations的实现
2020/03/31 Python
学python需要去培训机构吗
2020/07/01 Python
Python 必须了解的5种高级特征
2020/09/10 Python
澳大利亚小众服装品牌:Maurie & Eve
2018/03/27 全球购物
优秀教导主任事迹材料
2014/05/09 职场文书
文员求职信
2014/07/15 职场文书
停车位租赁协议书
2014/09/24 职场文书
2015重阳节座谈会主持词
2015/07/30 职场文书
三好学生主要事迹怎么写
2015/11/03 职场文书
2019财务管理制度最新范本!
2019/07/09 职场文书
Django利用AJAX技术实现博文实时搜索
2021/05/06 Python