对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跑马灯代码(自写)
Apr 17 Javascript
JavaScript中的parse()方法使用简介
Jun 12 Javascript
JS实现带提示的星级评分效果完整实例
Oct 30 Javascript
js对象浅拷贝和深拷贝详解
Sep 05 Javascript
在网页中插入百度地图的步骤详解
Dec 02 Javascript
BootStrap的两种模态框方式
May 10 Javascript
jquery获取链接地址和跳转详解(推荐)
Aug 15 jQuery
在angular 6中使用 less 的实例代码
May 13 Javascript
js与jQuery实现获取table中的数据并拼成json字符串操作示例
Jul 12 jQuery
Vue filter格式化时间戳时间成标准日期格式的方法
Sep 16 Javascript
vue实现文字加密功能
Sep 27 Javascript
Vue路由的模块自动化与统一加载实现
Jun 05 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
缅甸的咖啡简史
2021/03/04 咖啡文化
使用php4加速网络传输
2006/10/09 PHP
一些PHP Coding Tips(php小技巧)[2011/04/02最后更新]
2011/05/02 PHP
php入门学习知识点三 PHP上传
2011/07/14 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(十)
2014/06/24 PHP
php使用memcoder将视频转成mp4格式的方法
2015/03/12 PHP
Yii2 中实现单点登录的方法
2018/03/09 PHP
Laravel 自定命令以及生成文件的例子
2019/10/23 PHP
PHP7创建COOKIE和销毁COOKIE的实例方法
2020/02/03 PHP
用JS判别浏览器种类以及IE版本的几种方法小结
2011/08/02 Javascript
Jquery选择子控件"大于号"和" "区别介绍及使用示例
2013/06/25 Javascript
javascript拖拽上传类库DropzoneJS使用方法
2013/12/05 Javascript
完美兼容IE,chrome,ff的设为首页、加入收藏及保存到桌面js代码
2014/12/17 Javascript
jQuery Mobile框架中的表单组件基础使用教程
2016/05/17 Javascript
javascript 广告移动特效的实现代码
2016/06/25 Javascript
AngularJS中的作用域实例分析
2018/05/16 Javascript
详解在HTTPS 项目中使用百度地图 API
2019/04/26 Javascript
jquery 回调操作实例分析【回调成功与回调失败的情况】
2019/09/27 jQuery
JS前端模块化原理与实现方法详解
2020/03/17 Javascript
Python中关于Sequence切片的下标问题详解
2017/06/15 Python
用Pycharm实现鼠标滚轮控制字体大小的方法
2019/01/15 Python
python通过paramiko复制远程文件及文件目录到本地
2019/04/30 Python
windows中安装Python3.8.0的实现方法
2019/11/19 Python
浅析Python 责任链设计模式
2020/09/11 Python
Pandas中DataFrame交换列顺序的方法实现
2020/12/14 Python
html5构建触屏网站之touch事件介绍
2013/01/07 HTML / CSS
世界上最大的高分辨率在线图片库:Alamy
2018/07/07 全球购物
师范学院毕业生求职信范文
2013/12/26 职场文书
大学英语演讲稿(中英文对照)
2014/01/14 职场文书
学生会干部自荐信
2014/02/04 职场文书
大学生素质拓展活动方案
2014/02/11 职场文书
财政局党的群众路线教育实践活动整改方案
2014/09/21 职场文书
信访工作汇报材料
2014/10/27 职场文书
2014年教育工作总结
2014/11/26 职场文书
向雷锋同志学习倡议书
2015/04/27 职场文书
党员读书活动心得体会
2016/01/14 职场文书