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>
相关推荐
Cobyte1 分钟前
1.基于依赖追踪和触发的响应式系统的本质
前端·javascript·vue.js
主宰者18 分钟前
C# CommunityToolkit.Mvvm全局事件
java·前端·c#
老神在在00122 分钟前
【Selenium 自动化精讲】浏览器弹窗与登录界面的本质区别 & 实操指南
javascript·学习·selenium·测试工具·自动化
计算机学姐38 分钟前
基于SpringBoot的咖啡店管理系统【个性化推荐+数据可视化统计+配送信息】
java·vue.js·spring boot·后端·mysql·信息可视化·tomcat
前端小咸鱼一条1 小时前
16.迭代器 和 生成器
开发语言·前端·javascript
小江的记录本1 小时前
【注解】常见 Java 注解系统性知识体系总结(附《全方位对比表》+ 思维导图)
java·前端·spring boot·后端·spring·mybatis·web
web守墓人1 小时前
【前端】记一次将ruoyi vue3 element-plus迁移到arco design vue的经历
前端·vue.js·arco design
伊步沁心1 小时前
Webpack & Vite 深度解析
前端
libokaifa1 小时前
OpenSpec + TDD:让 AI 写代码,用测试兜底
前端·ai编程
用户15815963743701 小时前
搭 AI Agent 团队踩了 18 个坑,总结出这 5 个关键步骤
前端