学习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_06_理解对象的创建过程
Oct 15 Javascript
深入理解Javascript里的依赖注入
Mar 19 Javascript
在JS中解析HTML字符串示例代码
Apr 16 Javascript
JavaScript 异常处理 详解
Feb 06 Javascript
JS实现DIV容器赋值的方法
Dec 14 Javascript
基于javascript实现九宫格大转盘效果
May 28 Javascript
总结Javascript中的隐式类型转换
Aug 24 Javascript
详解如何运行vue项目
Apr 15 Javascript
Node.js之删除文件夹(含递归删除)代码实例
Sep 09 Javascript
深入浅析JavaScript中的in关键字和for-in循环
Apr 20 Javascript
详细分析Node.js 多进程
Jun 22 Javascript
Vue实现菜单切换功能
Nov 08 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中10个不常见却非常有用的函数
2010/03/21 PHP
PHP登录环节防止sql注入的方法浅析
2014/06/30 PHP
初识Laravel
2014/10/30 PHP
php短信接口代码
2016/05/13 PHP
Netbeans 8.2将支持PHP7 更精彩
2016/06/13 PHP
PHP autoload使用方法及步骤详解
2020/09/05 PHP
firefox下jquery ajax返回object XMLDocument处理方法
2014/01/26 Javascript
jQuery 如何先创建、再修改、后添加DOM元素
2014/05/20 Javascript
jquery让返回的内容显示在特定div里(代码少而精悍)
2014/06/23 Javascript
jquery获取一个元素下面相同子元素的个数代码
2014/07/31 Javascript
深入理解JavaScript编程中的原型概念
2015/06/25 Javascript
jQuery插件jquery-barcode实现条码打印的方法
2015/11/25 Javascript
AngularJS中监视Scope变量以及外部调用Scope方法
2016/01/23 Javascript
第九章之路径分页标签与徽章组件
2016/04/25 Javascript
Jquery中map函数的用法
2016/06/03 Javascript
JS删除数组里的某个元素方法
2018/02/03 Javascript
[44:50]DOTA2上海特级锦标赛B组小组赛#2 VG VS Fnatic第二局
2016/02/26 DOTA
使用Python解析JSON数据的基本方法
2015/10/15 Python
举例讲解Python中的list列表数据结构用法
2016/03/12 Python
windows及linux环境下永久修改pip镜像源的方法
2016/11/28 Python
Python操作MySQL数据库的三种方法总结
2018/01/30 Python
Python 实现王者荣耀中的敏感词过滤示例
2019/01/21 Python
python爬取Ajax动态加载网页过程解析
2019/09/05 Python
HTML5表格_动力节点Java学院整理
2017/07/11 HTML / CSS
美国瑜伽品牌:Gaiam
2017/10/31 全球购物
北美最大的零售退货翻新商:VIP Outlet
2019/11/21 全球购物
校园十佳歌手策划书
2014/01/22 职场文书
元旦晚会邀请函
2014/01/27 职场文书
经管应届生求职信范文
2014/05/18 职场文书
运动会口号8字
2014/06/07 职场文书
企业安全生产月活动总结
2014/07/05 职场文书
2014年党员自我评议(5篇)
2014/09/12 职场文书
实习生矿工检讨书
2014/10/13 职场文书
内乡县衙导游词
2015/02/05 职场文书
js基础语法与maven项目配置教程案例
2021/07/15 Javascript
Pandas搭配lambda组合使用详解
2022/01/22 Python