服务器之家:专注于服务器技术及软件下载分享
分类导航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服务器之家 - 编程语言 - JavaScript - json - 使Ext的Template可以解析二层的json数据的方法

使Ext的Template可以解析二层的json数据的方法

2022-01-03 21:39json教程网 json

使Ext的Template可以解析二层的json数据的方法

Ext的Template支持通过传入json数据的方式进行模板替换。
API中有这样一段示例:

复制代码 代码如下:


var t = new Ext.Template( 
    '<div name="{id}">', 
        '<span class="{cls}">{name:trim} {value:ellipsis(10)}</span>', 
    '</div>' 
); 
t.append('some-element', {id: 'myid', cls: 'myclass', name: 'foo', value: 'bar'}); 




稍作修改做个测试:

复制代码 代码如下:


var t = new Ext.Template( 
    '<div name="{id}">', 
        '<span class="{cls}">{name} {value}</span>', 
    '</div>' 
); 
var dt=t.apply({id: 'myid', cls: 'myclass', name: 'foo', value: 'bar'}); 
alert(dt); 



运行上面的代码会弹出<div name="myid"><span class="myclass">foo bar</span></div>说明替换成功。

但如果又这样一个模板数据:

复制代码 代码如下:


{id: 'myid', cls:{o:'myclass'}, name: 'foo', value: 'bar'} 




我们想在替换时将模板中原cls部分替换为cls.o的值,也就是myclass,该怎么做呢?是不是想直接用{cls.o},你可以试下,绝对无效,没有替换。因为template匹配替换是直接对{}中冒号前的字符串与JSON变量进行匹配的。当然找不到cls.o这个串所以也就不能匹配。
好在Template支持对数据的解析处理。
我们可以自己定义一个解析函数即可。其实很简单:
 

复制代码 代码如下:


var t = new Ext.Template( 
    '<div name="{id}">', 
        '<span class="{cls:this.parseJSON}">{name} {value}</span>', 
    '</div>' 
); 
t.parseJSON=function(data){return data.o}; 
var dt=t.apply({id: 'myid', cls: {o:'myclass'}, name: 'foo', value: 'bar'}); 
alert(dt) 




我们定义了一个叫parseJSON的解析方法,在模板中访问顶层的cls然后对cls(是一个object)的值进行处理(直接访问它的o属性)即可。

延伸 · 阅读

精彩推荐
  • json使Ext的Template可以解析二层的json数据的方法

    使Ext的Template可以解析二层的json数据的方法

    使Ext的Template可以解析二层的json数据的方法...

    json教程网4822022-01-03
  • json告诉大家什么是JSON

    告诉大家什么是JSON

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。...

    json教程网6382022-01-03
  • json看了就知道什么是JSON

    看了就知道什么是JSON

    JSON(Javascript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于Javascript Programming Language, Standard ECMA-262 ...

    JSON教程网5852022-01-03
  • json厉害了,ECMAScript 新提案:JSON模块

    厉害了,ECMAScript 新提案:JSON模块

    第三阶段的一个名为JSON模块的新提议,提出了一种将JSON导入到ES模块的方法。现在,我们来看看JSON模块是如何工作的。...

    大迁世界11212021-12-27
  • jsonXML的代替者----JSON

    XML的代替者----JSON

    我个人觉得PHP与Javascript各有长处,如果能完美的结合起来,那将创造出许许多多的奇迹!我是初次写此类文章,Bug难免,请各位指正~ 现在AJAX应用非常流行...

    JSON教程网6982022-01-03
  • json用 JSON 处理缓存

    用 JSON 处理缓存

    使用 JSON(即 JavaScript Object Notation),将以一种特定的字符串形式来表示 JavaScript 对象。如果将具有这样一种形式的字符串赋给任意一个 JavaScript 变量,该...

    JSON教程网8592022-01-03