感觉递归还是很好理解的:先合并赋值,接着,判断目前深度是否是最后一层,是的话,直接返回,不是就删除当前这层,继续遍历
function namespace(oNamespace, sPackage) {
const args = sPackage.split(".")
return fn(oNamespace, args)
}
function fn(oNamespace, args){
oNamespace[args[0]] = Object.assign({}, oNamespace[args[0]])
if(args.length !== 0){
fn(oNamespace[args[0]] ,args.splice(1))
}
return oNamespace
}



京公网安备 11010502036488号