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

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

在公共包shared里写上ShapeFlags

Vue3中h方法和createVnode的实现-详细步骤_第1张图片

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

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

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

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

Vue3中h方法和createVnode的实现-详细步骤_第2张图片

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的第三个参数,这个参数只可能是文本或者数组

你可能感兴趣的:(前端,vue.js,javascript)