在 Vue 3.0 中,渲染函数 API 是 Composition API 的一部分,它允许你使用 JavaScript 编写模板而不是字符串,并提供更灵活、强大的编程能力。通过渲染函数,你可以更直观地表达组件的渲染逻辑。

以下是一个使用渲染函数 API 的简单示例:
<template>
  <div>
    <p>{{ message }}</p>
    <button @click="updateMessage">Update Message</button>
  </div>
</template>

<script>
import { ref } from 'vue';

export default {
  setup() {
    const message = ref('Hello from Render Function API');

    const updateMessage = () => {
      message.value = 'Updated Message';
    };

    return {
      message,
      updateMessage
    };

    // 渲染函数 API 的替代写法
    // return () => {
    //   return (
    //     <div>
    //       <p>{message.value}</p>
    //       <button onClick={updateMessage}>Update Message</button>
    //     </div>
    //   );
    // };
  }
};
</script>

在上述示例中,setup 函数返回了组件的状态和方法,并且你可以使用 JSX 的方式(被注释的部分)定义渲染函数。

在 setup 函数中返回一个对象,对象中的属性将会暴露给模板,函数中的逻辑将会在组件初始化时执行。这种方式让你可以更灵活地组织代码,尤其是在处理逻辑较为复杂的组件时。

需要注意的是,在 Vue 3.0 中,模板中的 this 指向的是组件实例,但在 setup 函数中,this 指向的是上下文对象,并不是组件实例。因此,如果你需要访问组件实例,可以通过 getCurrentInstance 函数获取。


转载请注明出处:http://www.pingtaimeng.com/article/detail/554/Vue 3.0