学习YUI.Ext 第七天--关于View&JSONView


Posted in Javascript onMarch 10, 2007

展现一条一条的二维关系的数据,我们可以使用GIRD组件。 但有些场合,如产品展示,画册,我们可以使用View组件,来展示“矩阵”式的数据。 View的数据源来自DataModel对象,即包含XMLDataModel和JSONDataModel。尽管View支持JSON,但如果不是用于DataModel,View的子类JSONView更适用,因为它提供更多的事件和方法。一般来说,View用于XML数据源;JSONView用于JSON数据源。

View如何工作?

记得以前如何输出一个记录吗?以网上商店为例子;以前是这样输出一个商品的:

<%
		.....
		//下列服务端代码为ASP using JScript(依然是JS,I'm a big JS Fan^^)
		var str ="";
		str+="<td><div id='title'>";
		str+=rs("title")+"<\/div>";
		str+="<img src="+rs("thumb_image")+">";
		str+="<\/td>"
		Resposne.Write(str);
		.....
%>

很明显,我们最终目的还是要输出HTML,为浏览器渲染(Render)服务。View工作原理也一样,只不过把以前Sever做的事情搬到Cilent来,依靠View来处理(实质上是Domhelper的模版),让浏览器最终渲染输出。

需要你的帮忙:Domhelper

如上述,View的工作离不开DomHelpr。DomHelpr在这里提供"模版Template",并将其编译。见下面代码:

//新建一个Template对象
var tpl = new YAHOO.ext.Template(
 '<div class="entry">' + 
  '<a class="entry-title" href="{link}">{title}</a>' +
  '<h4>{date} by {author} | {comments} Comments</h4>{description}' +
 '</div><hr />'
);
tpl.compile(); //compile()的方法,可带来DOM性能的增益
var moreView = new YAHOO.ext.JsonView('entry-list', tpl, {
 jsonRoot: 'posts'
});
//又或者隐式创建Template对象
var view = new YAHOO.ext.View('my-element', 
   '<div id="{0}">{2} - {1}</div>', // auto create template
   dataModel, { 
    singleSelect: true, 
    selectedClass: 'ydataview-selected'
   });

 

加载数据

VIEW加载数据的方式与JSONView的有所不同:VIEW采用DataModel的load(),JSONView采用UpateManager的load()。下面重点说说JSONView的load()方法:

view.load({ url: 'your-url.php',
 params: {param1: 'foo', param2: 'bar'}, // 可以是URL encoded字符
 callback: yourFunction,
 scope: yourObject, //(optional scope) 
 discardUrl: false, 
 nocache: false,
 text: 'Loading...',//loading之提示文字
 timeout: 30,//超时
 scripts: false
 });

只有url参数是不可缺省的,其它如 nocache, text and scripts都是可选的。 text和scripts是与UpdateManger实例关联的参数

  • params : String/Object
    (optional) The parameters to pass as either a url encoded string "param1=1¶m2=2" or an object {param1: 1, param2: 2}
  • callback : Function
    (optional) Callback when transaction is complete - called with signature (oElement, bSuccess)
  • discardUrl : Boolean
    (optional) By default when you execute an update the defaultUrl is changed to the last used url. If true, it will not store the url.

JSONView使用点滴

a.有一个gird和JSONView,两者如何同时调用一个数据源?
1.改变jsonData属性; 2.Call refresh(); 见http://www.yui-ext.com/forum/viewtopic.php?t=1968

b.分页
分页视乎还没有什么好的方案,JACK只提供下面的思路:
JsonView extends View. View supports using a JSONDataModel. It won't render a paging toolbar for you, but it will loadPage() and standard DataModel functionality. The view will automatically update when you load new data. If you want named template parameters (like JsonView), you will need to remap the indexes (DataModel style) to named parameters. See the YAHOO.ext.View docs for more info on that.
http://www.yui-ext.com/forum/viewtopic.php?t=2340

c.如何JSONView的获取整个DataModel而不是字段?我每次用alert(mainView.jsonData); 结果是“undefined”
如果是获取DataModel,那应该用View对象。出现undefined的原因是load()是异步的,你必须先等待数据load完。如:

mainView.el.getUpdateManager().on('update', function(){ 
  alert(mainView.jsonData); 
});

详见http://www.yui-ext.com/forum/viewtopic.php?t=1209

 

d.学习例子。范例Image Chooser本身就是一个好的学习例子

JSON Format

您可能认为服务输出这样的JSON:

{"user": {"username": "Bob", "birthday": "1976-11-08", "join_date": "2006-08-01", "last_login": "2006-12-03"}}

是正确无误的。但不对,它是不能被处理的。正确的格式应该是:

{"user": [{"username": "Bob", "birthday": "1976-11-08", "join_date": "2006-08-01", "last_login": "2006-12-03"}]}

注意方括号内声明的是数组类型,View渲染方式实际是与DataModel一致的

最后,提供一幅Veiw的UML图

学习YUI.Ext 第七天--关于View&amp;JSONView
Javascript 相关文章推荐
JavaScript 学习笔记 Black.Caffeine 09.11.28
Nov 30 Javascript
JS的document.all函数使用示例
Dec 30 Javascript
探讨JavaScript中的Rest参数和参数默认值
Jul 29 Javascript
基于jquery实现动态竖向柱状条特效
Feb 12 Javascript
javascript轻量级库createjs使用Easel实现拖拽效果
Feb 19 Javascript
jQuery中each()、find()和filter()等节点操作方法详解(推荐)
May 25 Javascript
AngularJS Controller作用域
Jan 09 Javascript
理解 javascript 中的函数表达式与函数声明
Jul 07 Javascript
微信小程序template模版的使用方法
Apr 13 Javascript
在微信小程序中使用图表的方法示例
Apr 25 Javascript
基于JS实现table导出Excel并保留样式
May 19 Javascript
微信小程序实现锚点跳转
Nov 23 Javascript
学习YUI.Ext 第六天--关于树TreePanel(Part 1)
Mar 10 #Javascript
学习YUI.Ext第五日--做拖放Darg&amp;Drop
Mar 10 #Javascript
学习YUI.Ext 第四天--对话框Dialog的使用
Mar 10 #Javascript
学习YUI.Ext 第三天
Mar 10 #Javascript
学习YUI.Ext 第二天
Mar 10 #Javascript
学习YUI.Ext基础第一天
Mar 10 #Javascript
JavaScript触发器详解
Mar 10 #Javascript
You might like
用php和MySql来与ODBC数据连接
2006/10/09 PHP
php递归遍历删除文件的方法
2015/04/17 PHP
[JS源码]超长文章自动分页(客户端版)
2007/01/09 Javascript
JavaScript中的Screen屏幕对象
2008/01/16 Javascript
JS鼠标事件大全 推荐收藏
2011/11/01 Javascript
基于JQuery 选择器使用说明介绍
2013/04/18 Javascript
Firefox中通过JavaScript复制数据到剪贴板(Copy to Clipboard 跨浏览器版)
2013/11/22 Javascript
javascript中callee与caller的区别分析
2015/04/20 Javascript
JS实现新浪微博效果带遮罩层的弹出框代码
2015/10/12 Javascript
JavaScript中省略元素对数组长度的影响
2016/10/26 Javascript
JavaScript实现图片瀑布流和底部刷新
2017/01/02 Javascript
前端页面文件拖拽上传模块js代码示例
2017/05/19 Javascript
nodejs集成sqlite使用示例
2017/06/05 NodeJs
vuex 使用文档小结篇
2018/01/11 Javascript
微信小程序公用参数与公用方法用法示例
2019/01/09 Javascript
npm的lock机制解析
2019/06/20 Javascript
JavaScript仿京东秒杀倒计时
2020/03/17 Javascript
Vue Render函数原理及代码实例解析
2020/07/30 Javascript
Windows下的Jupyter Notebook 安装与自定义启动(图文详解)
2018/02/21 Python
详解关于Django中ORM数据库迁移的配置
2018/10/08 Python
Python 普通最小二乘法(OLS)进行多项式拟合的方法
2018/12/29 Python
Python面向对象程序设计多继承和多态用法示例
2019/04/08 Python
Python如何处理大数据?3个技巧效率提升攻略(推荐)
2019/04/15 Python
python脚本调用iftop 统计业务应用流量的思路详解
2019/10/11 Python
用python画一只可爱的皮卡丘实例
2019/11/21 Python
Python解析json代码实例解析
2019/11/25 Python
详解python环境安装selenium和手动下载安装selenium的方法
2020/03/17 Python
深入研究HTML5实现图片压缩上传功能
2016/03/25 HTML / CSS
美国电视购物HSN官网:HSN
2016/09/07 全球购物
英国时尚饰品和发饰购物网站:Claire’s
2017/07/04 全球购物
艺龙旅行网酒店预订:国内、港澳台酒店
2018/06/26 全球购物
Footshop乌克兰:运动鞋的最大选择
2019/12/01 全球购物
什么是Oracle的后台进程background processes?都有哪些后台进程?
2012/04/26 面试题
RIP版本1跟版本2的区别
2013/12/30 面试题
诚信承诺书模板
2014/05/26 职场文书
研究生学习计划书应该怎么写?
2019/09/10 职场文书