• Vue3中h方法和createVnode的实现-详细步骤


    h方法是给用户来用的,它具备着多样性。我们先来写createVnode

    在公共包shared里写上ShapeFlags

    image.png

    • 采用二进制来标识某些东西

    在runtime-core模块里创建vnode.ts文件专门处理虚拟节点

    • 虚拟节点有很多,组件的、元素的和文本的
    • 用ShapeFlags来判断是否是字符串,判断儿子children是否是个数组
    • children不是数组类型,则标识为text_children
    • 将不同情况打上ShapeFlag标识
    • 最后把来共同标识这个vode节点的类型

    为了后续的diff算法,我们要给这个虚拟节点上加一些属性和标识

    image.png

    h的用法

    • h(‘div’)
    • h(‘div’,{style:{‘color’:‘red’}},‘hello’)
    • h(‘div’,‘hello’)
    • h(‘div’,h(‘span’))
    • h(‘div’,[h(‘span’),h(‘span’)])
    • h(‘div’,null,‘hello’,‘world’)
    • h(‘div’,null,h(‘span’))
    • h(‘div’,null,[h(‘span’)])

    创建h.ts文件来写h方法

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XHuoBllR-1656055147228)(https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/367a28925a53409ea9493943592bf692~tplv-k3u1fbpfcp-zoom-in-crop-mark:1956:0:0:0.image?)]

    • 先判断参数长度
    • 如果参数长度等于2,那么我们要区分一下第二个参数是个h方法处理过的虚拟节点,还是一个普通的属性对象,或者是一个数组
    • 如果第二个参数是不是一个数组并且也不是一个对象,那么判断第二个参数是否是h方法处理过的虚拟节点,如果是虚拟节点,那么调用createVnode,第二个参数传null,第三个参数包装成数组。如果不是虚拟节点,那肯定就是普通属性
    • 如果第二个参数是数组或者不是对象,第二个参数传null,直接把propsChildren传入第三个参数,传第三个参数后,都可以处理到,包括文本元素
    • 如果参数长度大于3,后续的参数包装成一个数组
    • 如果参数长度等于3,并且children是一个虚拟节点,children包装成一个数组
    • 最后统一调createVnode
    • 总结,其实我们上述的一系列判断的核心是处理传入createVnode的第三个参数,这个参数只可能是文本或者数组
  • 相关阅读:
    异构数据源同步之表结构同步 → 通过 jdbc 实现,没那么简单
    操作系统·进程管理
    docker 容器
    java面试题整理《基础篇》五
    python和pycharm的安装教程--保姆级
    线程池处理异常的方法
    IO多路复用实现TCP客户端与TCP并发服务器
    封装vue基于element的select多选时启用鼠标悬停折叠文字以tooltip显示具体所选值
    Jmeter常用的组件
    KingbaseES参数track_activity_query_size介绍
  • 原文地址:https://blog.csdn.net/web22050702/article/details/125446287