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

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
}