题解 | #虚拟DOM#

虚拟DOM

http://www.nowcoder.com/practice/a283d2c284ed49468c3b0f6ec0312b0f

考察递归,解构,节点与文本节点,属性设置
const _createElm = vnode => {
                // 补全代码
                //解构
                let {tag,props,children,text}=vnode
                function setArr(el,attrs){
                    for (var key in attrs){
                        el.setAttribute(key,attrs[key])
                    }
                }
                if(typeof tag == 'string'){
                    vnode.el=document.createElement(tag)
                    setArr(vnode.el,props)
                    vnode.el.appendChild(document.createTextNode(text))
                    children.forEach((child)=>{
                        vnode.el.appendChild(_createElm(child))
                    })
                }else{
                    vnode.el=document.createTextNode(text)
                }
                return vnode.el
            }
全部评论

相关推荐

06-08 22:25
门头沟学院 Java
从零开始的转码生活:这hr不会打开手机不分青红皂白给所有人群发这句话,过一会再给所有人再发一遍,这肯定会有重复的,不管,再过一会再发一遍
点赞 评论 收藏
分享
头顶尖尖的程序员:我是26届的不太懂,25届不应该是找的正式工作吗?为什么还在找实习?大四还实习的话是为了能转正的的岗位吗
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务