感觉递归还是很好理解的:先合并赋值,接着,判断目前深度是否是最后一层,是的话,直接返回,不是就删除当前这层,继续遍历
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 }