js之对象处理
数据拼接一:
原始数据为对象
{
0grade: ""
0home: "萍钢四切(边部钩痕)"
0price: "3200"
0productName: "普板"
0remark: ""
1grade: ""
1home: "萍钢四切(边部钩痕)"
1price: "3201"
1productName: "普板"
1remark: ""
3grade: ""
3home: "萍钢四切(边部钩痕)"
3price: "3201"
3productName: "普板"
3remark: ""
}
要求数据为数组
[
{
grade: "",
home:"萍钢四切(边部钩痕)",
price: "3021",
productName: "普板",
remark: "",
},{
grade: "",
home:"萍钢四切(边部钩痕)",
price: "3021",
productName: "普板",
remark: "",
},
{
grade: "",
home:"萍钢四切(边部钩痕)",
price: "3021",
productName: "普板",
remark: "",
}
]
解决方案一:
getTableArry (data) {
let arry = [];
let obj = {};
for(let key in data) {
let curKey = parseInt(key.replace(/[^0-9]+/g, '')); // 获取key里的数字标记
let keyName =key.replace(/[^a-zA-Z]+/g, ''); // 获取 key里的字段名称
if(!isNaN(curKey)){// 过滤掉不包含数字标记的
obj = {
'productName':data[`${curKey}productName`],
'spec':data[`${curKey}spec`],
'grade':data[`${curKey}grade`],
'home':data[`${curKey}home`],
'weight':data[`${curKey}weight`],
'warehouse':data[`${curKey}warehouse`],
'price':data[`${curKey}price`],
'remark':data[`${curKey}remark`],
}
if(`${curKey}` in arry) {// 过滤掉已经追加到arry的obj }else {
arry.push(obj)
}
} }
return arry;
}
解决方案二:
ps: obj 对象拷贝,需放在里面,每次重新初始化
getTableArry (data, o) {
let arry = []; for(let key in data) {
let curKey = parseInt(key.replace(/[^0-9]+/g, '')); // 获取key里的数字标记
let keyName =key.replace(/[^a-zA-Z]+/g, ''); // 获取 key里的字段名称
if(!isNaN(curKey)){// 过滤掉不包含数字标记的
if(`${curKey}` in arry) {// 过滤掉已经追加到arry的obj }else {
let obj = {};
for (let i in o){
obj[i] = data[`${curKey}${i}`]
}
arry.push(obj)
}
} }
return arry;
}
js之对象处理的更多相关文章
- js定义对象的几种容易犯的错误
//js定义对象的几种容易犯的错误function Person() { getName = function (){ console.info(1); }; return this;}//Perso ...
- 模仿console自写函数打印js的对象
本以为写个递归函数就可以将js的对象打印出来. 当然第一个想到的估计是JSON.stringify() 这个函数.但这个函数打印到浏览器 显示效果不友好.最友好的显示肯定是 控制台打印咯. 结果尝试打 ...
- js自定义对象
一,概述 在Java语言中,我们可以定义自己的类,并根据这些类创建对象来使用,在Javascript中,我们也可以定义自己的类,例如定义User类.Hashtable类等等. 目前在Javascrip ...
- Atitit 跨平台异常处理(2)--------异常转换 -----java c# js异常对象结构比较and转换
Atitit 跨平台异常处理(2)--------异常转换 -----java c# js异常对象结构比较and转换 { "@type":"java.lang.Runti ...
- js中对象使用
简单记录javascript中对象的使用 一.创建对象 //创建一个空对象 var o={}; //创建一个含有两个属性的对象,x.y var o2={x:12,y:'12',name:'JS'}; ...
- JavaScript学习06 JS事件对象
JavaScript学习06 JS事件对象 事件对象:当事件发生时,浏览器自动建立该对象,并包含该事件的类型.鼠标坐标等. 事件对象的属性:格式:event.属性. 一些说明: event代表事件的状 ...
- [转]JS中对象与字符串的互相转换
原文地址:http://www.cnblogs.com/luminji/p/3617160.html 在使用 JSON2.JS 文件的 JSON.parse(data) 方法时候,碰到了问题: thr ...
- JS中对象与字符串的互相转换
在使用 JSON2.JS 文件的 JSON.parse(data) 方法时候,碰到了问题: throw new SyntaxError('JSON.parse'); 查询资料,大概意思如下: JSON ...
- JS面相对象
一.理解对象: //第一种:基于Object对象 var person = new Object(); person.name = 'My Name'; person.age = ; person.g ...
- 关于js一般对象与标配对象
当一个js函数对象被创建时,Function 构造器产生的函数对象会运行类似这样的一些代码 this.prototype={constructor:this} 新函数被赋予了一个prototype属性 ...
随机推荐
- 【转载】 VCS编译的基本参数,//code细节,注释
https://www.bilibili.com/read/cv18255106?spm_id_from=333.999.0.0
- 第十三天笔记Cookie
第十三天笔记Cookie 计算机重要的四个内容 数据结构 数据存储的结构及逻辑的体现,以及相关数据结构之间的操作(算法) 操作系统 windows(dos命令).linux(指令操作) 计网 网络通信 ...
- linux环境通过nginx转发allure报告
前言: 自动化测试生成的allure报告一般通过jenkins生成,生成后通过jenkins的view账号进行查看,但这样就必须登录jenkins才能看到,如何不通过登录jenkins从而看到al ...
- webpack4从0开始构建前端单页项目(15)用clean-webpack-plugin清理构建前的目录(dist)
clean-webpack-plugin 这个插件用来清空打包后的 dist 目录下的文件.可以避免每次打包前手动删除构建目录(dist)下的文件. 安装 clean-webpack-plugin c ...
- 【Java学习Day09】Java知识点及面试题微讲
Java知识点及面试题 整数拓展 进制 二进制0b 八进制0 十进制 十六进制0x public class Demo03 { public static void main(String[] arg ...
- SpringBoot_Thymeleaf项目开发
用Springboot集成Thymeleaf,开发一个前后端不分离的Web项目,记录下每个步骤:(IDEA版) 一.项目初始化: 1.打开idea,以次点击 File -- New -- Projec ...
- CToolsDetachBehaviors
CTools dispatches the event "CToolsDetachBehaviors" when the modal gets closed. Careful th ...
- ES bool查询
一.bool查询包含四种操作 1.must 2.must not 3.filter 4.should 二.功能 1.must 对应mysql的 and a= 2.must not 对应mysql的 a ...
- leetcode 剑指offer小结
栈与队列 剑指 Offer 09. 用两个栈实现队列 使用两个堆栈,一个输出栈,另一个输入栈.队列入队:直接将元素压入输入栈,队列出队:如果输出栈为空,将输入栈元素压入输出栈,再将输出栈元素出栈. 查 ...
- 制作docker php5.6的镜像
docker pull centos Docker run -it --name="centos-test" centos yum install wget # 报错在后面有处理 ...