学习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 相关文章推荐
XmlUtils JS操作XML工具类
Oct 01 Javascript
div层的移动及性能优化
Nov 16 Javascript
Javascript设置对象的ReadOnly属性(示例代码)
Dec 25 Javascript
jQuery调取jSon数据并展示的方法
Jan 29 Javascript
jQuery实现的倒计时效果实例小结
Apr 16 Javascript
Javascript中的迭代、归并方法详解
Jun 14 Javascript
jQuery获取与设置iframe高度的方法
Aug 01 Javascript
详解Vue的computed(计算属性)使用实例之TodoList
Aug 07 Javascript
JS动态修改网页body的背景色实例代码
Oct 07 Javascript
Angular4自制一个市县二级联动组件示例
Nov 21 Javascript
关于vue利用postcss-pxtorem进行移动端适配的问题
Nov 20 Javascript
node.js中对Event Loop事件循环的理解与应用实例分析
Feb 14 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 Array交叉表实现代码
2010/08/05 PHP
PHP 安全检测代码片段(分享)
2013/07/05 PHP
PHP实现数据库的增删查改功能及完整代码
2018/04/18 PHP
javascript引用对象的方法
2007/01/11 Javascript
javascript window.confirm确认 取消对话框实现代码小结
2012/10/21 Javascript
JQuery 图片滚动轮播示例代码
2014/03/24 Javascript
Node.js(安装,启动,测试)
2014/06/09 Javascript
jQuery封装的tab选项卡插件分享
2015/06/16 Javascript
node.js读取文件到字符串的方法
2015/06/29 Javascript
JS根据浏览器窗口大小实时动态改变网页文字大小的方法
2016/02/25 Javascript
使用React实现轮播效果组件示例代码
2016/09/05 Javascript
vue学习笔记之指令v-text &amp;&amp; v-html &amp;&amp; v-bind详解
2017/05/12 Javascript
Vue如何实现组件的源码解析
2017/06/08 Javascript
vue页面跳转后返回原页面初始位置方法
2018/02/11 Javascript
实例详解Node.js 函数
2018/06/10 Javascript
详解基于DllPlugin和DllReferencePlugin的webpack构建优化
2018/06/28 Javascript
Vue+webpack+Element 兼容问题总结(小结)
2018/08/16 Javascript
JavaScript继承的特性与实践应用深入详解
2018/12/30 Javascript
Python随机生成数模块random使用实例
2015/04/13 Python
Python双精度浮点数运算并分行显示操作示例
2017/07/21 Python
python回调函数中使用多线程的方法
2017/12/25 Python
Python将多份excel表格整理成一份表格
2018/01/03 Python
Python3列表内置方法大全及示例代码小结
2019/05/10 Python
十分钟搞定pandas(入门教程)
2019/06/21 Python
python批量将excel内容进行翻译写入功能
2019/10/10 Python
在Django中自定义filter并在template中的使用详解
2020/05/19 Python
欧舒丹加拿大官网:L’Occitane加拿大
2017/10/29 全球购物
物业经理求职自我评价
2013/09/22 职场文书
酒店门卫岗位职责
2013/12/29 职场文书
xxx同志考察材料
2014/02/07 职场文书
学校团代会开幕词
2016/03/04 职场文书
详解nodejs内置模块
2021/05/06 NodeJs
Vue鼠标滚轮滚动切换路由效果的实现方法
2021/08/04 Vue.js
Html5获取用户当前位置的几种方式
2022/01/18 HTML / CSS
Python开发五子棋小游戏
2022/05/02 Python
mysql如何查询连续记录
2022/05/11 MySQL