当前位置: 首页 > news >正文

vue入门:函数式组件

Vue 函数式组件是一种特殊的组件,它没有实例(即没有 this 上下文),并且是无状态的。
函数式组件的主要用途是作为渲染函数的包装器,用于更高效地渲染组件,尤其是在需要大量渲染简单组件的场景中。

一、函数式组件的特点

(一)无状态

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

(二)无实例

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

(三)高效渲染

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

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

(一)定义函数式组件

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

1. Vue 2.x 示例
// 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 函数来定义。

// 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 传递数据。

<MyFunctionalComponent :title="'Hello'" :content="'This is a functional component'" />

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

将属性返回给调用方

// TempVar.js
export default {
  functional: true,
  render: (E, ctx) => {
    return ctx.scopedSlots.default && ctx.scopedSlots.default(ctx.props || {});
  }
};

// Functional.vue
<template functional>
  <div>
    {{ props }}
  </div>
</template>

使用

<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>

相关文章:

  • 实现一个动态验证码生成器:Canvas与JavaScript的完美结合
  • 《C语言中的形参与实参:理解函数调用的核心概念》
  • NVIDIA AI Aerial
  • docker 安装 jenkins
  • SpringBoot实战2
  • 【强化学习-蘑菇书-3】马尔可夫性质,马尔可夫链,马尔可夫过程,马尔可夫奖励过程,如何计算马尔可夫奖励过程里面的价值
  • 奇怪的电梯——DFS算法
  • linux多线(进)程编程——(4)进程间的传音术(命名管道)
  • Android envsetup与Python venv使用指南
  • CST1017.基于Spring Boot+Vue共享单车管理系统
  • 【软考系统架构设计师】软件工程知识点
  • AI agents系列之全面介绍
  • 密码加密方式
  • 【基础算法】递推算法 - java
  • go之为什么学go?
  • 常用AI辅助编程工具及平台介绍
  • 数据集 handpose_x_plus 3D RGB 三维手势 - 手工绘画 场景 draw picture
  • 【无标题】四色拓扑模型与黑洞信息存储的统一性论证(猜想)——基于规范场论与全息原理的跨学科研究
  • 机器学习(5)——支持向量机
  • 基于ssm网络游戏推荐系统(源码+lw+部署文档+讲解),源码可白嫖!
  • 纽约市长称墨西哥海军帆船撞桥事故已致2人死亡
  • 中国旅马大熊猫“福娃”和“凤仪”启程回国
  • 嫩黑线货物列车脱轨致1名路外人员死亡,3人被采取刑事强制措施
  • 俄媒:俄乌代表团抵达谈判会场
  • 侵害孩子者,必严惩不贷!3名性侵害未成年人罪犯今日执行死刑
  • 国防部:赖清德歪曲二战历史,背叛民族令人不齿