对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 相关文章推荐
基于jquery的页面划词搜索JS
Sep 14 Javascript
读jQuery之三(构建选择器)
Jun 11 Javascript
js函数调用常用方法详解
Dec 03 Javascript
js 剪切板的用法(clipboardData.setData)与js match函数介绍
Nov 19 Javascript
深入浅析JavaScript中的作用域和上下文
Mar 26 Javascript
js事件处理程序跨浏览器解决方案
Mar 27 Javascript
Google 地图获取API Key详细教程
Aug 06 Javascript
AngularJs  Using $location详解及示例代码
Sep 02 Javascript
微信头像地址失效踩坑记附带解决方案
Sep 23 Javascript
Vue基于iview实现登录密码的显示与隐藏功能
Mar 06 Javascript
antd-日历组件,前后禁止选择,只能选中间一部分的实例
Oct 29 Javascript
js前端设计模式优化50%表单校验代码示例
Jun 21 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程序中的常见漏洞进行攻击(上)
2006/10/09 PHP
模仿OSO的论坛(一)
2006/10/09 PHP
php部分常见问题总结
2008/03/27 PHP
thinkphp数据查询和遍历数组实例
2014/11/28 PHP
Laravel配置全局公共函数的方法步骤
2019/05/09 PHP
疯掉了,尽然有js写的操作系统
2007/04/23 Javascript
解决jquery submit()提交表单提示:f[s] is not a function
2013/01/23 Javascript
jQuery实现id模糊查询的小例子
2013/03/19 Javascript
JavaScript设置IFrame高度自适应(兼容各主流浏览器)
2013/06/05 Javascript
javascript获取form里的表单元素的示例代码
2014/02/14 Javascript
JavaScript实现弹出DIV层同时页面背景渐变成半透明效果
2016/03/25 Javascript
有关JavaScript中call()和apply() 的一些理解
2016/05/20 Javascript
Bootstrap基本组件学习笔记之input输入框组(9)
2016/12/07 Javascript
Node.js使用Express.Router的方法
2017/11/14 Javascript
vue引入ueditor及node后台配置详解
2018/01/03 Javascript
nodejs实现的连接MySQL数据库功能示例
2018/01/25 NodeJs
JSON是什么?有哪些优点?JSON和XML的区别?
2019/04/29 Javascript
基于Express框架使用POST传递Form数据
2019/08/10 Javascript
JS回调函数 callback的理解与使用案例分析
2019/09/09 Javascript
jsonp格式前端发送和后台接受写法的代码详解
2019/11/07 Javascript
基于javascript的无缝滚动动画1
2020/08/07 Javascript
python如何统计序列中元素
2020/07/31 Python
Python一行代码实现快速排序的方法
2019/04/30 Python
python读取Kafka实例
2019/12/23 Python
python 两个一样的字符串用==结果为false问题的解决
2020/03/12 Python
Python读写锁实现实现代码解析
2020/11/28 Python
HTML5 device access 设备访问详解
2018/05/24 HTML / CSS
VC++笔试题
2014/10/13 面试题
Linux如何修改文件和文件夹的权限
2012/06/27 面试题
医药专业推荐信
2013/11/15 职场文书
社区母亲节活动方案
2014/03/05 职场文书
体育教师求职信
2014/05/24 职场文书
学习退步检讨书
2014/09/28 职场文书
2015年新农村建设工作总结
2015/05/22 职场文书
ElementUI实现el-form表单重置功能按钮
2021/07/21 Javascript
海弦WR-800F
2022/04/05 无线电