• Vue虚拟节点和渲染函数


    1.虚拟节点

    虚拟节点(dom)本质上就是一个普通的JS对象,用于描述视图的界面结构

    2.渲染函数render():接收一个 createElement()函数创建的VNode

    1. Vue.component("board", {
    2. render: function(createElement) {
    3. return createElement("div", [
    4. createElement("h1", "这是一个h1标签")]);
    5. }
    6. });

    可以使用render()对页面进行编程式的修改。字符串模板的代替方案,允许你发挥 JavaScript 最大的编程能力。

    render()渲染函数接收一个 createElement 方法作为第一个参数用来创建 VNode。如果组件是一个函数组件,渲染函数还会接收一个额外的 context 参数。

    createElement()参数:

    • 第一个参数:标签名称或对象或async 函数
    • 第二个:数据对象,可选
    • 第三个参数:子级虚拟节点,由 `createElement()` 构建而成,也可以是使用字符串来生成“文本虚拟节点”
    1. createElement(
    2. // {String | Object | Function}
    3. // 一个 HTML 标签名、组件选项对象,或者
    4. // resolve 了上述任何一种的一个 async 函数。必填项。
    5. 'div',
    6. // {Object}
    7. // 一个与模板中 attribute 对应的数据对象。可选。
    8. {
    9. // (详情见下一节)
    10. },
    11. // {String | Array}
    12. // 子级虚拟节点 (VNodes),由 `createElement()` 构建而成,
    13. // 也可以使用字符串来生成“文本虚拟节点”。可选。
    14. [
    15. '先写一些文字',
    16. createElement('h1', '一则头条'),
    17. createElement(MyComponent, {
    18. props: {
    19. someProp: 'foobar'
    20. }
    21. })
    22. ]
    23. )

     3.数据对象

    数据对象可以是一下内容:class,style,普通的 HTML attribute(id等),props组件,DOM property,事件(on),nativeOn(监听原生事件),directives指令,slot,scopedSlots(作用域插槽:{ name: props => VNode | Array }),ref,key,refInFor(为true时,如果有多个ref会变成一个数组)

    1. {
    2. // 与 `v-bind:class` 的 API 相同,
    3. // 接受一个字符串、对象或字符串和对象组成的数组
    4. 'class': {
    5. foo: true,
    6. bar: false
    7. },
    8. // 与 `v-bind:style` 的 API 相同,
    9. // 接受一个字符串、对象,或对象组成的数组
    10. style: {
    11. color: 'red',
    12. fontSize: '14px'
    13. },
    14. // 普通的 HTML attribute
    15. attrs: {
    16. id: 'foo'
    17. },
    18. // 组件 prop
    19. props: {
    20. myProp: 'bar'
    21. },
    22. // DOM property
    23. domProps: {
    24. innerHTML: 'baz'
    25. },
    26. // 事件监听器在 `on` 内,
    27. // 但不再支持如 `v-on:keyup.enter` 这样的修饰器。
    28. // 需要在处理函数中手动检查 keyCode。
    29. on: {
    30. click: this.clickHandler
    31. },
    32. // 仅用于组件,用于监听原生事件,而不是组件内部使用
    33. // `vm.$emit` 触发的事件。
    34. nativeOn: {
    35. click: this.nativeClickHandler
    36. },
    37. // 自定义指令。注意,你无法对 `binding` 中的 `oldValue`
    38. // 赋值,因为 Vue 已经自动为你进行了同步。
    39. directives: [
    40. {
    41. name: 'my-custom-directive',
    42. value: '2',
    43. expression: '1 + 1',
    44. arg: 'foo',
    45. modifiers: {
    46. bar: true
    47. }
    48. }
    49. ],
    50. // 作用域插槽的格式为
    51. // { name: props => VNode | Array }
    52. scopedSlots: {
    53. default: props => createElement('span', props.text)
    54. },
    55. // 如果组件是其它组件的子组件,需为插槽指定名称
    56. slot: 'name-of-slot',
    57. // 其它特殊顶层 property
    58. key: 'myKey',
    59. ref: 'myRef',
    60. // 如果你在渲染函数中给多个元素都应用了相同的 ref 名,
    61. // 那么 `$refs.myRef` 会变成一个数组。
    62. refInFor: true
    63. }

    4.实例

    1. <board>board>
    2. <board2>board2>
    3. ....
    4. <script>
    5. // 两个全局注入的组件
    6. Vue.component("board", {
    7. render: function(createElement) {
    8. // 组件有一个div元素,div下一个h1标签
    9. return createElement("div", [
    10. createElement("h1", "这是一个h1标签")]);
    11. }
    12. });
    13. Vue.component("board2", {
    14. render: function(createElement) {
    15. // 组件下一个div元素,里面是一个文本节点,通过对象数据config设置了class属性和click事件
    16. return createElement("div", config ,"字符串的文本节点");
    17. }
    18. });
    19. const config = {
    20. 'class': {
    21. foo: true,
    22. bar: false
    23. },
    24. on: {
    25. click: function(){
    26. console.log("文本节点点击事件测试");
    27. }
    28. }
    29. }
    30. script>

  • 相关阅读:
    nginx发布vue项目
    第3章 docker容器管理
    医学影像图像去噪:滤波器方法、频域方法、小波变换、非局部均值去噪、深度学习与稀疏表示和字典学习
    实际业务中使用策略模式对代码进行重构
    回归预测 | MATLAB实现GRU(门控循环单元)多输入单输出
    mysql添加外键
    单页面应用(SPA)与多页面应用(MPA)的区别及优缺点
    红色荧光素标记硫酸软骨素;Rhodamine-Chondroitin-Sulfate;Chondroitin-Sulfate-TRITC
    MySQL必知必会
    【数据结构】链表其实并不难 —— 手把手带你实现双向链表
  • 原文地址:https://blog.csdn.net/qq_34569497/article/details/133971285