vue3中的return,h,render

一、return 的作用

1. 在 setup 函数中

  • 作用setup 函数的返回值决定了模板中可用的数据和方法。setup 只能返回对象或函数,不能混合返回。
  • 规则:返回的对象中的属性和方法会暴露给模板使用。
import { ref } from 'vue';

export default {
  setup() {
    const count = ref(0);
    const increment = () => count.value++;
    // 返回的对象会暴露给模板
    return {
      count,
      increment
    };
  }
}

关键点‌:

  • 若返回对象,模板可直接使用其属性和方法。
  • 若返回‌函数‌,则该函数会被用作 render 函数(替代模板)。

二、h 函数(createVNode 的别名)

1. 什么是 h

h 是 Vue 3 中 createVNode 的别名(h 是 "hyperscript" 的缩写),用于创建 虚拟节点(VNode)

常用于以下场景:

手写渲染函数

JSX/TSX 编译后的代码

动态生成复杂 UI

它是构建渲染函数的核心函数。

2. h 的参数结构

h(
  tag,        // 标签名(字符串、组件、函数)
  props,      // 属性对象(包含 class、style、事件等)
  children    // 子节点(字符串、数组、其他 VNode)
)

在 JSX 中,<div>...</div> 会自动编译为 h('div', {}, ...)

import { h } from 'vue';

export default {
  setup() {
    return () => h('div', { class: 'container' }, [
      h('h1', 'Hello Vue3'),
      h('button', { onClick: () => alert('Clicked!') }, 'Click Me')
    ]);
  }
}

 ‌3. render 函数

render 函数是 Vue 的核心 API,用于定义组件的渲染逻辑。它返回一个由 h 创建的 VNode,Vue 会将其转换为真实 DOM。
在两种场景中使用:

场景 1:直接定义 render 选项 

export default {
  render() {
    return h('div', 'This is rendered by render()');
  }
}
render(vnode, container) {
  const node = createVNode(Button, { type: 'primary' })
  render(node, document.getElementById('app'))
}

 ‌场景 2:在 setup 中返回渲染函数

import { h } from 'vue';

export default {
  setup() {
    // 返回一个函数时,Vue 会将其视为 render 函数
    return () => h('div', 'Dynamic content from setup()');
  }
}

关键点‌:

  • 若 setup 返回一个函数,该函数会替代 render 选项。
  • 此时模板(<template>)会被忽略。
Vue2是一种被广泛使用的JavaScript框架,它提供了一些方便的功能来简化开发人员的工作。其中,使用render函数自定义组件是Vue2中非常强大的一个功能。render函数是一种能够将虚拟DOM转换为实际DOM的函数。通过使用render函数,您可以自定义组件并控制其整个生命周期。以下是Vue2中使用render自定义组件的步骤: 第一步,导入Vuerender函数。您需要在组件中导入Vue和渲染函数。 ``` import Vue from &#39;vue&#39; import { render } from &#39;vue-server-renderer&#39; ``` 第二步,定义组件。您需要定义一个组件,这个组件可以包含其他组件和HTML元素。在这里,我们将定义一个简单的组件。 ``` const HelloWorld = Vue.component(&#39;hello-world&#39;, { render() { return ( <div> <h1>Hello World</h1> </div> ) } }) ``` 第三步,渲染组件。您需要使用Vue的渲染函数将组件渲染到HTML中。 ``` const app = new Vue({ render(h) { return h(HelloWorld) } }) const html = renderToString(app) console.log(html) ``` 第四步,使用组件。您可以在您的Vue应用程序中使用这个组件,只需要像以下这样导入它。 ``` import HelloWorld from &#39;./HelloWorld.vue&#39; export default { components: { HelloWorld } } ``` 通过这些简单的步骤,您可以使用Vue2中的render函数来创建自定义组件,而无需使用Vue的模板语法。这种技术可以让您更加灵活地控制组件,并且可以让您更好地理解Vue的内部工作原理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值