extjs6怎么接收后端传过来的map集合里面有两个list集合的数据

时间: 2024-05-14 10:14:52 浏览: 17
可以使用Ext.Ajax.request()方法,其中options的参数中设置success回调函数,接收后端传过来的数据。在回调函数中,可以使用Ext.decode()方法将后端传来的JSON字符串转化为对象,然后直接访问对象中的map集合和list集合数据。具体代码如下: ``` Ext.Ajax.request({ url: 'yourUrl', method: 'POST', success: function(response, options) { var data = Ext.decode(response.responseText); // 将后端传来的JSON字符串转化为对象 var mapData = data.mapData; // 访问map集合数据 var listData1 = data.listData1; // 访问list集合数据1 var listData2 = data.listData2; // 访问list集合数据2 // do something with mapData, listData1, listData2 }, failure: function(response, options) { // handle error } }); ```
相关问题

extjs6怎么接收后端传过来的map集合里面有两个list集合的数据并格式化到model层

可以使用Ext.data.reader.Json的transform方法将后端传过来的数据进行格式化,然后再通过Ext.data.Model的set方法将格式化后的数据设置到model的属性中。 以下是一个示例代码: 假设后端返回的数据格式如下: { "name": "John", "age": 30, "address": { "city": "New York", "state": "NY" }, "hobbies": ["reading", "swimming"], "friends": [ {"name": "Mike", "age": 28}, {"name": "Kate", "age": 32} ] } 那么在前端可以这样处理: // 定义数据模型 Ext.define('MyModel', { extend: 'Ext.data.Model', fields: [ {name: 'name', type: 'string'}, {name: 'age', type: 'int'}, {name: 'city', type: 'string'}, {name: 'state', type: 'string'}, {name: 'hobbies', type: 'auto'}, {name: 'friends', type: 'auto'} ] }); // 定义数据代理 Ext.define('MyProxy', { extend: 'Ext.data.proxy.Ajax', alias: 'proxy.myproxy', reader: { type: 'json', transform: function(data) { // 将address对象的属性展开到根级别 data.city = data.address.city; data.state = data.address.state; delete data.address; // 将friends数组转换成对象 var friends = {}; Ext.each(data.friends, function(friend) { friends[friend.name] = friend.age; }); data.friends = friends; return data; } } }); // 定义数据源 var store = Ext.create('Ext.data.Store', { model: 'MyModel', proxy: { type: 'myproxy', url: 'data.json' } }); // 加载数据 store.load({ callback: function(records, operation, success) { if (success) { // 遍历数据,输出每个记录的属性 Ext.each(records, function(record) { console.log(record.get('name')); console.log(record.get('age')); console.log(record.get('city')); console.log(record.get('state')); console.log(record.get('hobbies')); console.log(record.get('friends')); }); } } }); 在transform方法中,先将address对象的属性展开到根级别,然后将friends数组转换成对象。最后返回这个格式化后的数据对象。这样在model中定义的fields可以正确地映射到数据中。 在加载数据时,可以通过callback回调函数获取加载的数据,并通过Ext.data.Model的get方法获取每个记录的属性。

extjs6接收展示一个list集合里面的map集合的完整案例

好的,我理解了您的问题。以下是一个简单的 ExtJS 6 的代码示例,用于从一个包含多个 Map 对象的 List 中获取和展示数据: ``` Ext.define('MyApp.model.MyModel', { extend: 'Ext.data.Model', fields: [ { name: 'id', type: 'int' }, { name: 'name', type: 'string' }, { name: 'values', convert: function (value, record) { // 将 Map 对象数组转换成字符串 return JSON.stringify(value); } } ] }); Ext.create('Ext.grid.Panel', { store: { model: 'MyApp.model.MyModel', data: [ { id: 1, name: 'Map Collection 1', values: [ { name: 'Key1', value: 'Value1' }, { name: 'Key2', value: 'Value2' }, { name: 'Key3', value: 'Value3' } ] }, { id: 2, name: 'Map Collection 2', values: [ { name: 'Key4', value: 'Value4' }, { name: 'Key5', value: 'Value5' }, { name: 'Key6', value: 'Value6' } ] } ] }, columns: [ { text: 'ID', dataIndex: 'id' }, { text: 'Name', dataIndex: 'name' }, { text: 'Values', dataIndex: 'values' } ], renderTo: Ext.getBody() }); ``` 该示例中包含定义一个 `MyModel` 模型的代码,该模型包含名为 `values` 的字段。这个字段使用 `convert` 函数将 Map 对象数组转换成字符串。最后,在 `Ext.grid.Panel` 中,数据存储在 `store` 中,该 `store` 包含多个 `MyModel` 记录,并构建了一个包含多个 `Map` 对象的 `values` 数组。最后,使用 `columns` 属性定义表格中的列,并在页面上呈现出来。 请注意,此代码仅供参考,并假定您已经具有一定的 ExtJS 6 开发经验。如果需要更多的帮助或说明,请随时联系我。

相关推荐

最新推荐

recommend-type

ExtJs中处理后台传过来的date对象显示到页面上

在使用ExtJs开发时会遇到这样的问题,后台传来一个java对象,里面有一个date类型的数据,现在要显示到页面上,我们该如何写才能不用将date转换成string的直接在页面上显示。下面解决办法:例如:在员工查询页面上,...
recommend-type

ExtJs整合Echarts的示例代码

例如,我们可以创建一个新的面板,并在其内部包含两个div,一个用于展示Echarts图表,另一个用于显示表格数据。以下是一个简单的实现示例: ```javascript initPanel : function() { if (this.panel) { return }...
recommend-type

extjs和servlet数据交互的例子

在这个例子中,`doGet` 方法返回了一个JSON格式的字符串,包含两个对象,每个对象都有 `name`、`age` 和 `sex` 这三个属性。这是Servlet向ExtJS客户端发送数据的方式。 接下来,我们需要在`web.xml`文件中配置...
recommend-type

CCD式铆合测定机保养说明书.doc

CCD式铆合测定机保养说明书
recommend-type

IOS操作系统开发/调试的案例

IOS操作系统开发/调试的案例 iOS操作系统开发和调试是一个复杂但非常有趣的过程。下面是一个简单的iOS应用开发案例,展示了如何使用Swift和Xcode开发一个基本的iOS应用,并进行调试。
recommend-type

计算机基础知识试题与解答

"计算机基础知识试题及答案-(1).doc" 这篇文档包含了计算机基础知识的多项选择题,涵盖了计算机历史、操作系统、计算机分类、电子器件、计算机系统组成、软件类型、计算机语言、运算速度度量单位、数据存储单位、进制转换以及输入/输出设备等多个方面。 1. 世界上第一台电子数字计算机名为ENIAC(电子数字积分计算器),这是计算机发展史上的一个重要里程碑。 2. 操作系统的作用是控制和管理系统资源的使用,它负责管理计算机硬件和软件资源,提供用户界面,使用户能够高效地使用计算机。 3. 个人计算机(PC)属于微型计算机类别,适合个人使用,具有较高的性价比和灵活性。 4. 当前制造计算机普遍采用的电子器件是超大规模集成电路(VLSI),这使得计算机的处理能力和集成度大大提高。 5. 完整的计算机系统由硬件系统和软件系统两部分组成,硬件包括计算机硬件设备,软件则包括系统软件和应用软件。 6. 计算机软件不仅指计算机程序,还包括相关的文档、数据和程序设计语言。 7. 软件系统通常分为系统软件和应用软件,系统软件如操作系统,应用软件则是用户用于特定任务的软件。 8. 机器语言是计算机可以直接执行的语言,不需要编译,因为它直接对应于硬件指令集。 9. 微机的性能主要由CPU决定,CPU的性能指标包括时钟频率、架构、核心数量等。 10. 运算器是计算机中的一个重要组成部分,主要负责进行算术和逻辑运算。 11. MIPS(Millions of Instructions Per Second)是衡量计算机每秒执行指令数的单位,用于描述计算机的运算速度。 12. 计算机存储数据的最小单位是位(比特,bit),是二进制的基本单位。 13. 一个字节由8个二进制位组成,是计算机中表示基本信息的最小单位。 14. 1MB(兆字节)等于1,048,576字节,这是常见的内存和存储容量单位。 15. 八进制数的范围是0-7,因此317是一个可能的八进制数。 16. 与十进制36.875等值的二进制数是100100.111,其中整数部分36转换为二进制为100100,小数部分0.875转换为二进制为0.111。 17. 逻辑运算中,0+1应该等于1,但选项C错误地给出了0+1=0。 18. 磁盘是一种外存储设备,用于长期存储大量数据,既可读也可写。 这些题目旨在帮助学习者巩固和检验计算机基础知识的理解,涵盖的领域广泛,对于初学者或需要复习基础知识的人来说很有价值。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【进阶】音频处理基础:使用Librosa

![【进阶】音频处理基础:使用Librosa](https://picx.zhimg.com/80/v2-a39e5c9bff1d920097341591ca8a2dfe_1440w.webp?source=1def8aca) # 2.1 Librosa库的安装和导入 Librosa库是一个用于音频处理的Python库。要安装Librosa库,请在命令行中输入以下命令: ``` pip install librosa ``` 安装完成后,可以通过以下方式导入Librosa库: ```python import librosa ``` 导入Librosa库后,就可以使用其提供的各种函数
recommend-type

设置ansible 开机自启

Ansible是一个强大的自动化运维工具,它可以用来配置和管理服务器。如果你想要在服务器启动时自动运行Ansible任务,通常会涉及到配置服务或守护进程。以下是使用Ansible设置开机自启的基本步骤: 1. **在主机上安装必要的软件**: 首先确保目标服务器上已经安装了Ansible和SSH(因为Ansible通常是通过SSH执行操作的)。如果需要,可以通过包管理器如apt、yum或zypper安装它们。 2. **编写Ansible playbook**: 创建一个YAML格式的playbook,其中包含`service`模块来管理服务。例如,你可以创建一个名为`setu
recommend-type

计算机基础知识试题与解析

"计算机基础知识试题及答案(二).doc" 这篇文档包含了计算机基础知识的多项选择题,涵盖了操作系统、硬件、数据表示、存储器、程序、病毒、计算机分类、语言等多个方面的知识。 1. 计算机系统由硬件系统和软件系统两部分组成,选项C正确。硬件包括计算机及其外部设备,而软件包括系统软件和应用软件。 2. 十六进制1000转换为十进制是4096,因此选项A正确。十六进制的1000相当于1*16^3 = 4096。 3. ENTER键是回车换行键,用于确认输入或换行,选项B正确。 4. DRAM(Dynamic Random Access Memory)是动态随机存取存储器,选项B正确,它需要周期性刷新来保持数据。 5. Bit是二进制位的简称,是计算机中数据的最小单位,选项A正确。 6. 汉字国标码GB2312-80规定每个汉字用两个字节表示,选项B正确。 7. 微机系统的开机顺序通常是先打开外部设备(如显示器、打印机等),再开启主机,选项D正确。 8. 使用高级语言编写的程序称为源程序,需要经过编译或解释才能执行,选项A正确。 9. 微机病毒是指人为设计的、具有破坏性的小程序,通常通过网络传播,选项D正确。 10. 运算器、控制器及内存的总称是CPU(Central Processing Unit),选项A正确。 11. U盘作为外存储器,断电后存储的信息不会丢失,选项A正确。 12. 财务管理软件属于应用软件,是为特定应用而开发的,选项D正确。 13. 计算机网络的最大好处是实现资源共享,选项C正确。 14. 个人计算机属于微机,选项D正确。 15. 微机唯一能直接识别和处理的语言是机器语言,它是计算机硬件可以直接执行的指令集,选项D正确。 16. 断电会丢失原存信息的存储器是半导体RAM(Random Access Memory),选项A正确。 17. 硬盘连同驱动器是一种外存储器,用于长期存储大量数据,选项B正确。 18. 在内存中,每个基本单位的唯一序号称为地址,选项B正确。 以上是对文档部分内容的详细解释,这些知识对于理解和操作计算机系统至关重要。