学习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 相关文章推荐
用js实现trim()的解决办法
Apr 16 Javascript
js取消单选按钮选中示例代码
Nov 14 Javascript
js实现图片拖动改变顺序附图
May 13 Javascript
Easyui ueditor 整合解决不能编辑的问题(推荐)
Jun 25 Javascript
详解webpack 如何集成第三方js库
Jun 29 Javascript
详解在React.js中使用PureComponent的重要性和使用方式
Jul 10 Javascript
vue实现的微信机器人聊天功能案例【附源码下载】
Feb 18 Javascript
通过JS运行机制的角度说说作用域
Mar 12 Javascript
vue实现抖音时间转盘
Sep 08 Javascript
IDEA安装vue插件图文详解
Sep 26 Javascript
JavaScript 声明私有变量的两种方式
Feb 05 Javascript
JS数组方法some、every和find的使用详情
Oct 05 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
最小化数据传输――在客户端存储数据
2006/10/09 PHP
修改Zend引擎实现PHP源码加密的原理及实践
2008/04/14 PHP
PHP 开发环境配置(测试开发环境)
2010/04/28 PHP
ThinkPHP中Common/common.php文件常用函数功能分析
2016/05/20 PHP
thinkphp制作404跳转页的简单实现方法
2016/09/22 PHP
用js怎么把&amp;字符换成&quot;&amp;amp:&quot;
2006/10/19 Javascript
基于jquery的复制网页内容到WORD的实现代码
2011/02/16 Javascript
jQuery中的.bind()、.live()和.delegate()之间区别分析
2011/06/08 Javascript
jquery实现漂浮在网页右侧的qq在线客服插件示例
2013/05/13 Javascript
鼠标事件的screenY,pageY,clientY,layerY,offsetY属性详解
2015/03/12 Javascript
jquery实现可横向和竖向展开的动态下滑菜单效果
2015/08/24 Javascript
Highcharts使用简例及异步动态读取数据
2015/12/30 Javascript
Node.js使用Express.Router的方法
2017/11/14 Javascript
Mac下通过brew安装指定版本的nodejs教程
2018/05/17 NodeJs
对angularJs中2种自定义服务的实例讲解
2018/09/30 Javascript
使用mixins实现elementUI表单全局验证的解决方法
2019/04/02 Javascript
Vue使用localStorage存储数据的方法
2019/05/27 Javascript
js+canvas实现两张图片合并成一张图片的方法
2019/11/01 Javascript
vue2.0 解决抽取公用js的问题
2020/07/31 Javascript
解决vue 退出动画无效的问题
2020/08/09 Javascript
[01:58]最残酷竞争 2016国际邀请赛中国区预选赛积分循环赛回顾
2016/06/28 DOTA
[02:49]2018DOTA2亚洲邀请赛主赛事决赛日战况回顾 Mineski鏖战5局夺得辉耀
2018/04/10 DOTA
python使用wmi模块获取windows下的系统信息 监控系统
2015/10/27 Python
用pandas中的DataFrame时选取行或列的方法
2018/07/11 Python
python查询文件夹下excel的sheet名代码实例
2019/04/02 Python
python对XML文件的操作实现代码
2020/03/27 Python
PyTorch 导数应用的使用教程
2020/08/31 Python
深入理解Python变量的数据类型和存储
2021/02/01 Python
html5使用window.postMessage进行跨域实现数据交互的一次实战
2021/02/24 HTML / CSS
公积金转移接收函
2014/01/11 职场文书
员工拓展培训方案
2014/02/15 职场文书
外语专业毕业生自荐信
2014/04/14 职场文书
教师廉洁自律个人总结
2015/02/10 职场文书
七年级思品教学反思
2016/02/20 职场文书
golang 实现对Map进行键值自定义排序
2021/04/28 Golang
Redis特殊数据类型HyperLogLog基数统计算法讲解
2022/06/01 Redis