有趣数据结构转化,如何实现?
原始数据
javascript
var obj = { 'a': 1, 'b': 2, 'c': ['x','y','z','j'], 'd': ['a','c','u'], 'e': ['e', 'd'] };
转化为目标数据
javascript
[ {'a': 1, 'b': 2, 'c': 'x', 'd': 'a', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'y', 'd': 'a', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'z', 'd': 'a', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'j', 'd': 'a', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'x', 'd': 'c', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'y', 'd': 'c', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'z', 'd': 'c', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'j', 'd': 'c', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'x', 'd': 'u', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'y', 'd': 'u', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'z', 'd': 'u', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'j', 'd': 'u', 'e': 'e'}, {'a': 1, 'b': 2, 'c': 'x', 'd': 'a', 'e': 'd'}, {'a': 1, 'b': 2, 'c': 'y', 'd': 'a', 'e': 'd'}, {'a': 1, 'b': 2, 'c': 'z', 'd': 'a', 'e': 'd'}, {'a': 1, 'b': 2, 'c': 'j', 'd': 'a', 'e': 'd'}, {'a': 1, 'b': 2, 'c': 'x', 'd': 'c', 'e': 'd'}, {'a': 1, 'b': 2, 'c': 'y', 'd': 'c', 'e': 'd'}, {'a': 1, 'b': 2, 'c': 'z', 'd': 'c', 'e': 'd'}, {'a': 1, 'b': 2, 'c': 'j', 'd': 'c', 'e': 'd'}, {'a': 1, 'b': 2, 'c': 'x', 'd': 'u', 'e': 'd'}, {'a': 1, 'b': 2, 'c': 'y', 'd': 'u', 'e': 'd'}, {'a': 1, 'b': 2, 'c': 'z', 'd': 'u', 'e': 'd'}, {'a': 1, 'b': 2, 'c': 'j', 'd': 'u', 'e': 'd'}, ]
参数是不定的,
var obj1 = {
'a': 1,
'b': 2,
'c': ['x','y','z','j'],
'd': ['a','c','u'],
'e': ['e', 'd']
}
var obj2 = {
'a': 1,
'b': 2,
'c': ['x','y','z','j'],
'd': ['a','c','u']
}
var obj3 = {
'c': ['x','y','z','j'],
'd': ['a','c','u']
}
var obj4 = {
'a': 1,
'b': 2
}
等等,对象个数没有限制,属性值没有限制(当然,只翻译属性值为数组类型的)
javascript对象 递归 数据结构 JavaScript javascript数组
酱酱酱酱。
10 years, 3 months ago
Answers
javascript
function transform(obj, keys, index, result) { var key = keys[index]; var value = obj[key]; if (Array.isArray(value)) { var newObj = {}; var newObj2 = {}; keys.forEach(function (k) { newObj[k] = k === key ? value[0] : obj[k]; newObj2[k] = k === key ? value.slice(1) : obj[k]; }); if (newObj[key] !== undefined) { transform(newObj, keys, index, result); } if (newObj2[key].length > 0) { transform(newObj2, keys, index, result); } } else { if (index === keys.length - 1) { var ret = {}; keys.forEach(function (k) { ret[k] = obj[k]; }); result.push(ret); } else { transform(obj, keys, index + 1, result); } } } var obj = { 'a': 1, 'b': 2, 'c': ['x','y','z','j'], 'd': ['a','c','u'], 'e': ['e', 'd'] }; var result = []; transform(obj, Object.keys(obj), 0, result); result.forEach(function (o) { console.log('%j', o); });
奔跑的萝卜
answered 10 years, 3 months ago
js
var oTransformer = function ( obj ) { this.data = obj; this.dataArr = []; this.resultArr = []; this.result = []; }; oTransformer.prototype.parseSrc = function () { var objMapping = [], isArray = function(obj) { return Object.prototype.toString.call(obj) === '[object Array]'; }; for (var key in this.data) { var value = this.data[key], arr = []; if (!isArray(value)) { value = [ value ]; } for (var i = 0; i < value.length; i++) { arr.push(key + ':' + value[i]); } this.dataArr.push(arr); } console.log(this.dataArr); }; oTransformer.prototype.transform = function () { var point = {}, pIndex = null, tempCount = 0, temp = [], list = this.dataArr; for (var index in list) { if (typeof list[index] == 'object') { point[index] = { 'parent': pIndex, 'count': 0 }; pIndex = index; } } if (pIndex == null) { this.resultArr = list; return; } while(true) { for (var index in list) { tempCount = point[index]['count']; temp.push(list[index][tempCount]); } this.resultArr.push(temp); temp = []; while(true) { if (point[index]['count'] + 1 >= list[index].length) { point[index]['count'] = 0; pIndex = point[index]['parent']; if (pIndex == null) { return; } index = pIndex; } else { point[index]['count']++; break; } } } }; oTransformer.prototype.toObjArr = function () { for (var i = 0; i < this.resultArr.length; i++) { var line = this.resultArr[i], obj = {}; for (var j = 0; j < line.length; j++) { var cur = line[j], key = cur.split(':')[0], value = cur.split(':')[1]; obj[key] = value; } this.result.push(obj); } }; oTransformer.prototype.process = function () { this.parseSrc(); this.transform(); this.toObjArr(); }; var obj = { 'a': 1, 'b': 2, 'c': ['x','y','z','j'], 'd': ['a','c','u'], 'e': ['e', 'd'] }; var t = new oTransformer(obj); t.process(); console.log(t.result);
畢竟東流去
answered 10 years, 3 months ago