vue入门:函数式组件

Vue 函数式组件是一种特殊的组件,它没有实例(即没有 this 上下文),并且是无状态的。

函数式组件的主要用途是作为渲染函数的包装器,用于更高效地渲染组件,尤其是在需要大量渲染简单组件的场景中。

一、函数式组件的特点

(一)无状态

函数式组件不包含任何状态(data),也不支持生命周期钩子。它们的输出完全依赖于它们的输入(props)。

(二)无实例

函数式组件没有实例,因此不支持 this 上下文。这意味着你不能在函数式组件内部访问 this,也不能使用 this 来访问 datamethods 等。

(三)高效渲染

由于函数式组件没有实例和状态,它们的渲染过程更加高效。Vue 在内部对函数式组件进行了优化,减少了不必要的开销。

二、函数式组件的定义和使用

(一)定义函数式组件

在 Vue 2.x 中,可以通过设置组件选项的 functional: true 来定义函数式组件。在 Vue 3.x 中,函数式组件通常使用 setup 函数来定义。

1. Vue 2.x 示例
javascript 复制代码
// MyFunctionalComponent.vue
<template>
  <div>
    <h1>{{ title }}</h1>
    <p>{{ content }}</p>
  </div>
</template>

<script>
export default {
  functional: true,
  props: {
    title: String,
    content: String
  },
  // h: CreateElement
  render(h, { props }) {
    return h('div', [
      h('h1', props.title),
      h('p', props.content)
    ]);
  }
};
</script>
2. Vue 3.x 示例

在 Vue 3.x 中,函数式组件通常使用 setup 函数来定义,但也可以直接使用 h 函数来定义。

javascript 复制代码
// MyFunctionalComponent.vue
<template>
  <div>
    <h1>{{ title }}</h1>
    <p>{{ content }}</p>
  </div>
</template>

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

export default {
  props: {
    title: String,
    content: String
  },
  setup(props) {
    return () => h('div', [
      h('h1', props.title),
      h('p', props.content)
    ]);
  }
};
</script>

(二)使用函数式组件

函数式组件的使用方式与其他组件相同,通过 props 传递数据。

html 复制代码
<MyFunctionalComponent :title="'Hello'" :content="'This is a functional component'" />

(三)场景:模版中定义、使用临时变量

将属性返回给调用方

js 复制代码
// TempVar.js
export default {
  functional: true,
  render: (E, ctx) => {
    return ctx.scopedSlots.default && ctx.scopedSlots.default(ctx.props || {});
  }
};
xml 复制代码
// Functional.vue
<template functional>
  <div>
    {{ props }}
  </div>
</template>

使用

js 复制代码
<template>
  <div>
    <a-tabs>
      <a-tab-pane key="Functional" tab="函数式组件">
      
        <Functional :name="name"/>
        
        // 定义临时变量: var1、var2
        // TempVar 将属性返回给调用方
        <TempVar
            :var1="`hello ${name}`"
            :var2="destroyClock ? 'hello vue' : 'hello world'"
        >
        // 接受变量并使用临时变量,可以写复杂的逻辑
          <template v-slot="{ var1, var2 }">
            {{ var1 }}
            {{ var2 }}
          </template>
          
        </TempVar>
        
      </a-tab-pane>
    </a-tabs>
  </div>
</template>
<script>

import Functional from "./Functional";
import TempVar from "./TempVar";

export default {
  components: {
    Functional,
    TempVar
  },
  data() {
    return {
      destroyClock: false,
      name: "vue"
    };
  }
};
</script>
相关推荐
光影少年4 分钟前
rn如何和原生进行通信,是单线程还是多线程,通信方式都有哪些
前端·react native·react.js·taro
好大哥呀24 分钟前
Java Web的学习路径
java·前端·学习
计算机毕设VX:Fegn089527 分钟前
计算机毕业设计|基于springboot + vue动物园管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
HashTang32 分钟前
【AI 编程实战】第 7 篇:登录流程设计 - 多场景、多步骤的优雅实现
前端·uni-app·ai编程
北辰alk34 分钟前
深入理解Vue数据流:单向与双向的哲学博弈
vue.js
cos1 小时前
Fork 主题如何更新?基于 Ink 构建主题更新 CLI 工具
前端·javascript·git
小满zs1 小时前
Next.js第二十一章(环境变量)
前端·next.js
C***11501 小时前
Spring aop 五种通知类型
java·前端·spring
北辰alk1 小时前
解决Vue打包后静态资源图片失效的终极指南
vue.js