js運算元組中資料排列組合
需求: 將
var priceOption = {
age:[18,20],
sex:[‘男’,’女’],
hc:[‘2-6人’,’7-8人’]
}
上述物件中age與sex及hc自由組合:得到如下形式:
{age: 18, sex: “男”, hc: “2-6人”}
{age: 18, sex: “男”, hc: “7-8人”}
{age: 18, sex: “女”, hc: “2-6人”}
{age: 18, sex: “女”, hc: “7-8人”}
{age: 20, sex: “男”, hc: “2-6人”}
{age: 20, sex: “男”, hc: “7-8人”}
{age: 20, sex: “女”, hc: “2-6人”}
{age: 20, sex: “女”, hc: “7-8人”}
程式碼如下
// 需要引入lodash.
var priceFactor=['age','sex','hc']
var priceOption = {
age:[18,20],
sex:['男','女'],
hc:['2-6人','7-8人']
}
function plzhFirst(datas){
var array = [];
var propObj = getFirstProp(datas);
var propName= propObj.name;
var propValue=propObj.value;
if(_.isArray(propValue)){
for(var i = 0 ;i<propValue.length;i++){
var newObj = {};
newObj[propName]=propValue[i];
array.push(newObj);
}
}else{
var newObj ={};
newObj[propName]=propValue;
array.push(newObj)
}
for(var i=1;i<priceFactor.length;i++){
array = plzh(array,priceOption[priceFactor[i]],priceFactor[i])
}
return array
}
function getFirstProp(obj){
var propObj = {}
for(var i in obj){
propObj.name=i;
propObj.value=obj[i];
return propObj;
}
}
function plzh(arr1,arr2,nextAttr){
var array = [];
for(var i=0;i<arr1.length;i++)
{
var obj = arr1[i];
for(var j=0;j<arr2.length;j++)
{
var newObj= _.cloneDeep(obj);
var v2 = arr2[j];
newObj[nextAttr]=v2;
array.push(newObj);
};
};
return array;
}
var endData =console.log(plzhFirst(priceOption));
/*根據表格資料合併成var priceOption = {
age:[18,20],
sex:['男','女'],
hc:['2-6人','7-8人']
}形式*/
function getSZ(){
var defaultObj={}
for(var i = 0 ;i<endData.length;i++){
var defaultObj = combineObjectToOne(defaultObj,endData[i])
}
console.log(defaultObj);
}
getSZ();
function combineObjectToOne(object1,object2){
var nextObj =_.cloneDeep(object1);
for(var i in object2){
var oldValue = nextObj[i];
var nextValue = object2[i];
/*是陣列*/
if(_.isArray(oldValue) && oldValue.indexOf(nextValue)==-1){
oldValue.push(nextValue)
}else if ((_.isString(oldValue)||_.isNumber(oldValue))&&oldValue!==nextValue){
nextObj[i]=new Array(oldValue,nextValue)
}else if(oldValue==null||oldValue==undefined){
nextObj[i]=object2[i]
}
}
return nextObj;
}
相關文章
- js 方法(運算元組為主JS
- JS中運算元組的方法JS
- 排列組合
- 【數學】組合數學 - 排列組合
- 【POJ 2249】 Binomial Showdown 組合數學 排列組合計算
- java反射——運算元組Java反射
- 組合數學筆記-排列與組合筆記
- JavaScript 資料處理 - 運算元組JavaScript
- 字串排列組合問題字串
- PHP運算元據庫得到資料進行JSON組裝PHPJSON
- vue的資料劫持以及運算元組的坑Vue
- 模仿Java Stream API 運算元組/切片JavaAPI
- 無重複字串的排列組合字串
- Relax! It's just a game(排列組合,簡單)GAM
- 常見規格排列組合問題
- 【原創】開源.NET排列組合元件KwCombinatorics使用(一)—組合生成元件
- acm-排列組合學習筆記(更新中)ACM筆記
- 遞迴演算法實踐---實現排列組合遞迴演算法
- 程式設計師必備演算法——排列組合程式設計師演算法
- Python3組合資料型別(元組、列表、集合、字典)語法Python資料型別
- 計算組合數 (sdut oj)
- 回溯問題Python框架總結——排列組合問題Python框架
- Python使用combinations實現排列組合Python
- CF1796C C. Maximum Set 題解 排列組合
- js設計模式–組合模式JS設計模式
- js設計模式--組合模式JS設計模式
- js 組合繼承詳解JS繼承
- 元組
- 組合
- python:用pyinstaller做個排列組合的小工具Python
- 增補部落格 第十六篇 python 排列組合序列Python
- 遞迴示例-指定數字以內的所有排列組合(Reduce)遞迴
- 組合資料型別資料型別
- 陣列和廣義表的基本運算實現(三元組)陣列
- js的curry和函式組合JS函式
- IT組合和專案組合管理(轉)
- js 合併單元格的方法(使用直接呼叫資料時排列好的)JS
- 在C#中對列舉進行位運算--列舉組合C#