对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 相关文章推荐
js 数组实现一个类似ruby的迭代器
Oct 27 Javascript
用javascript为页面添加天气显示实现思路及代码
Dec 02 Javascript
js判断变量初始化的三种形式及推荐用的形式
Jul 22 Javascript
jquery中ready()函数执行的时机和window的load事件比较
Jun 22 Javascript
jQuery控制frames及frame页面JS的方法
Mar 08 Javascript
JavaScript通过HTML的class来获取HTML元素的方法总结
May 24 Javascript
Js操作DOM元素及获取浏览器高宽的简单方法
Sep 08 Javascript
js正则表达式最长匹配(贪婪匹配)和最短匹配(懒惰匹配)用法分析
Dec 27 Javascript
jQuery实现的电子时钟效果完整示例
Apr 28 jQuery
JavaScript检查数据中是否存在相同的元素(两种方法)
Oct 07 Javascript
LayUI switch 开关监听 获取属性值、更改状态的方法
Sep 21 Javascript
js滚轮事件 js自定义滚动条的实现
Jan 18 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 危险函数解释 分析
2009/04/22 PHP
ajax 的post方法实例(带循环)
2011/07/04 PHP
PHP对象转换为数组函数(递归方法)
2012/02/04 PHP
ThinkPHP3.1新特性之动态设置自动完成及自动验证示例代码
2014/06/23 PHP
PHP中echo和print的区别
2014/08/28 PHP
PHP获得数组交集与差集的方法
2015/06/10 PHP
PHP中call_user_func_array回调函数的用法示例
2016/11/26 PHP
PHP使用DOM对XML解析处理操作示例
2019/07/04 PHP
采用CSS和JS,刚好我最近有个站点要用到下拉菜单!
2006/06/26 Javascript
JavaScript 对任意元素,自定义右键菜单的实现方法
2013/05/08 Javascript
Jquery遍历checkbox获取选中项value值的方法
2014/02/13 Javascript
jquery模拟进度条实现方法
2015/08/03 Javascript
探讨JavaScript标签位置的存放与功能有无关系
2016/01/15 Javascript
jQuery插件imgPreviewQs实现上传图片预览
2016/01/15 Javascript
jQuery中text() val()和html()的区别实例详解
2016/06/28 Javascript
jQuery生成假加载动画效果
2016/12/01 Javascript
Vue分页组件实例代码
2017/04/17 Javascript
jQuery封装animate.css的实例
2018/01/04 jQuery
vue-router命名路由和编程式路由传参讲解
2019/01/19 Javascript
vue实现输入框自动跳转功能
2020/05/20 Javascript
python的pdb调试命令的命令整理及实例
2017/07/12 Python
python jieba分词并统计词频后输出结果到Excel和txt文档方法
2018/02/11 Python
Python实现的多进程和多线程功能示例
2018/05/29 Python
python ---lambda匿名函数介绍
2019/03/13 Python
基于selenium及python实现下拉选项定位select
2020/07/22 Python
python写文件时覆盖原来的实例方法
2020/07/22 Python
简单整理HTML5的基本特性和语法
2016/02/18 HTML / CSS
缓解脚、腿和背部疼痛:Z-CoiL鞋
2019/03/12 全球购物
Araks官网:纽约内衣品牌
2020/10/15 全球购物
防灾减灾标语
2014/10/07 职场文书
教师政风行风自查自纠报告
2014/10/21 职场文书
应届生求职自荐信范文
2015/03/04 职场文书
酒店财务总监岗位职责
2015/04/03 职场文书
幼儿园安全教育月活动总结
2015/05/08 职场文书
2015年基建工作总结范文
2015/05/23 职场文书
Pytest之测试命名规则的使用
2021/04/16 Python