对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 SHA-1:Secure Hash Algorithm
Dec 20 Javascript
Prototype Array对象 学习
Jul 19 Javascript
jQuery 点击图片跳转上一张或下一张功能的实现代码
Mar 12 Javascript
早该知道的7个JavaScript技巧
Mar 27 Javascript
JS组件Form表单验证神器BootstrapValidator
Jan 26 Javascript
JavaScript中eval函数的问题
Jan 31 Javascript
javascript随机抽取0-100之间不重复的10个数
Feb 25 Javascript
angular中实现控制器之间传递参数的方式
Apr 24 Javascript
详解Angular.js中$http拦截器的介绍及使用
Jul 04 Javascript
js中less常用的方法小结
Aug 09 Javascript
JS实现获取word文档内容并输出显示到html页面示例
Jun 23 Javascript
详解如何快速配置webpack多入口脚手架
Dec 28 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
深入了解php4(2)--重访过去
2006/10/09 PHP
ajax php 实现写入数据库
2009/09/02 PHP
PHP中使用匿名函数操作数据库的例子
2014/11/17 PHP
PHP实现二维数组按某列进行排序的方法
2016/11/18 PHP
Laravel框架模板加载,分配变量及简单路由功能示例
2018/06/11 PHP
javascript 动态参数判空操作
2008/12/22 Javascript
ajax 文件上传应用简单实现
2009/03/03 Javascript
JavaScript实现点击按钮后变灰避免多次重复提交
2013/07/15 Javascript
javascript跟随滚动效果插件代码(javascript Follow Plugin)
2013/08/03 Javascript
jQuery中:eq()选择器用法实例
2014/12/29 Javascript
JavaScript中常见获取元素的方法汇总
2015/03/04 Javascript
AngularJS 使用 UI Router 实现表单向导
2016/01/29 Javascript
JS判断键盘是否按的回车键并触发指定按钮点击操作的方法
2017/02/13 Javascript
vue-router:嵌套路由的使用方法
2017/02/21 Javascript
将Sublime Text 3 添加到右键中的简单方法
2017/12/12 Javascript
AngularJS基于MVC的复杂操作实例讲解
2017/12/31 Javascript
node.js部署之启动后台运行forever的方法
2018/05/23 Javascript
工作中常用到的ES6语法
2018/09/04 Javascript
VUE基于NUXT的SSR 服务端渲染
2018/11/30 Javascript
js实现简易拖拽的示例
2020/10/26 Javascript
[37:02]OG vs INfamous 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
用python实现的去除win下文本文件头部BOM的代码
2013/02/10 Python
Jupyter安装nbextensions,启动提示没有nbextensions库
2020/04/23 Python
Django实现登录随机验证码的示例代码
2018/06/20 Python
python3实现名片管理系统
2020/11/29 Python
基于python爬取链家二手房信息代码示例
2020/10/21 Python
一波HTML5 Canvas基础绘图实例代码集合
2016/02/28 HTML / CSS
德国最大的网上鞋店之一:Schuhe24.de
2017/06/10 全球购物
美国帽子俱乐部商店:Hat Club
2019/07/05 全球购物
意大利和国际奢侈品牌购物网站:Suitnegozi.com
2021/01/15 全球购物
新员工培训个人的自我评价
2013/10/09 职场文书
调研座谈会发言材料
2014/08/23 职场文书
写给医院的感谢信
2015/01/22 职场文书
初三英语教学计划
2015/01/23 职场文书
2015年社会实践个人总结
2015/03/06 职场文书
Win10系统搭建ftp文件服务器详细教程
2022/08/05 Servers