首页 > 其他分享 >前端项目实战52-debugger测试

前端项目实战52-debugger测试

时间:2023-02-12 21:36:22浏览次数:46  
标签:实战 console debugger splitKey 52 result key operation log


const parseFilters = (filter: any, defaultListOp: any) => {
const result: any = {}
console.log(filter,"filter")
console.log(defaultListOp,"defaultListOp")
Object.keys(filter).forEach(function (key) {
debugger
// key: the name of the object key
//属性按照@分割
const splitKey = key.split('@');
console.log(splitKey,"splitKey")
//如果长度为2 取出数组的属性值
const operation = splitKey.length == 2 ? splitKey[1] : defaultListOp;
console.log(operation,"operation")
let values;
//如果包含like这个属性 拉取到当前的值 拿取到对应的属性值
if (operation.includes('like')) {
values = filter[key].trim().split(' ');
} else {
values = [filter[key]];
}
console.log(values,"values")
values.forEach((value: any) => {
//进行拼接
// if operator is intentionally blank, rpc syntax
let op = operation.includes('like') ? `${operation}.*${value}*` : operation.length == 0 ? `${value}` : `${operation}.${value}`;
console.log(op,"oplist")
console.log(result,"result")
console.log(splitKey,"splitKey")
if (result[splitKey[0]] === undefined) {
// first operator for the key, we add it to the dict
result[splitKey[0]] = op;
}
else {

if (!Array.isArray(result[splitKey[0]])) {
// second operator, we transform to an array
result[splitKey[0]] = [result[splitKey[0]], op]
} else {
// third and subsequent, we add to array
result[splitKey[0]].push(op);
}
}
});

});
return result;
}

标签:实战,console,debugger,splitKey,52,result,key,operation,log
From: https://blog.51cto.com/u_15460007/6052186

相关文章