提升 Vue 项目开发效率:高阶组件 RenderFunction 的灵活性与实战应用

Vue 3 开发中,我们常常需要创建可复用的组件,但传统的组件封装方式有时会带来限制。比如,一个表格组件可能需要支持不同的数据结构,一个弹窗组件可能需要动态更改内容。面对这种需求,我们通常会通过 slotsScoped Slots 来解决,但它们的灵活性仍然有限。

有没有更好的方法?答案是:直接让组件接受一个渲染函数,让父组件完全控制渲染逻辑,而 RenderFunction 组件仅负责调用这个函数。这样,我们就能实现 更高自由度的组件定制能力,避免重复封装多个类似的 UI 组件。

实现

tsx 复制代码
import type { PropType, VNodeTypes } from "vue";
import { defineComponent } from "vue";

export type RenderFunc = (props: Record<string, unknown>) => VNodeTypes;

export default defineComponent({
  name: "RenderFunction",
  props: {
    renderFunc: {
      type: Function as PropType<RenderFunc>,
      required: true,
    },
  },
  render() {
    return this.renderFunc(this.$attrs);
  },
});

Props

Prop 名称 类型 是否必填 说明
renderFunc (props: Record<string, unknown>) => VNodeTypes 传递自定义渲染函数,返回 Vue 虚拟 DOM 节点
v-bind="$attrs" Record<string, unknown> 组件外部传入的额外属性,作为 renderFunc 的参数

适用场景

场景 说明
动态组件渲染 让父组件决定如何渲染,而不是硬编码 UI 结构
自定义 UI 组件 适用于开发可定制的 UI 库,如动态表单、可变布局组件
高阶组件(HOC RenderFunction 作为通用的渲染容器,实现不同 UI 逻辑
JSX 支持 结合 JSX,使渲染逻辑更简洁

示例

vue 复制代码
<template>
  <RenderFunction :renderFunc="myRenderFunc" :message="'Hello, Vue!'" />
</template>

<script setup lang="ts">
import { h } from "vue";
import RenderFunction from "./RenderFunction.vue";

const myRenderFunc = (props: Record<string, unknown>) => {
  return h("div", { class: "custom-class" }, `Message: ${props.message}`);
};
</script>

说明

  • renderFunc 负责定义组件的渲染方式。
  • props 参数用于传递动态数据。

结合 JSX 语法

如果你喜欢 JSX 语法,可以这样写:

vue 复制代码
<script setup lang="tsx">
import RenderFunction from "./RenderFunction.vue";

const myRenderFunc = (props: Record<string, unknown>) => (
  <div style="color: blue;">{props.message}</div>
);
</script>

<template>
  <RenderFunction :renderFunc="myRenderFunc" :message="'Hello JSX!'" />
</template>

说明

  • JSX 语法使代码更加直观,可读性更高。
  • 适用于 Vue 3<script setup> 语法。

适用于动态 UI

可以使用 RenderFunction 渲染不同结构的 UI,比如表格:

vue 复制代码
<template>
  <RenderFunction :renderFunc="tableRender" :data="items" />
</template>

<script setup lang="ts">
import { h } from "vue";
import RenderFunction from "./RenderFunction.vue";

const items = [
  { id: 1, name: "Vue" },
  { id: 2, name: "React" },
  { id: 3, name: "Svelte" },
];

const tableRender = (props: Record<string, unknown>) => {
  return h("table", { border: 1 }, [
    h("tr", [h("th", "ID"), h("th", "Name")]),
    ...props.data.map((item: any) =>
      h("tr", [h("td", item.id), h("td", item.name)])
    ),
  ]);
};
</script>

说明

  • RenderFunction 组件使表格结构可以动态配置,无需创建新的子组件。

总结

  1. RenderFunction 组件是一种 高阶渲染组件,提供极大的灵活性。
  2. 适用于 动态 UI、JSX、自定义渲染逻辑 的场景。
  3. 避免创建多个类似的 UI 组件,提高代码复用性。

如果你的项目有 动态内容渲染需求 ,这个组件将是一个 高效且优雅的解决方案!

相关推荐
不爱吃饭爱吃菜23 分钟前
uniapp微信小程序一键授权登录
前端·javascript·vue.js·微信小程序·uni-app
90后小陈老师1 小时前
3D个人简历网站 5.天空、鸟、飞机
前端·javascript·3d
不爱吃糖的程序媛5 小时前
浅谈前端架构设计与工程化
前端·前端架构设计
BillKu6 小时前
Vue3 Element Plus 对话框加载实现
javascript·vue.js·elementui
郝YH是人间理想7 小时前
系统架构设计师案例分析题——web篇
前端·软件工程
Evaporator Core7 小时前
深入探索:Core Web Vitals 进阶优化与新兴指标
前端·windows
初遇你时动了情7 小时前
html js 原生实现web组件、web公共组件、template模版插槽
前端·javascript·html
QQ2740287568 小时前
Soundness Gitpod 部署教程
linux·运维·服务器·前端·chrome·web3
前端小崔8 小时前
从零开始学习three.js(18):一文详解three.js中的着色器Shader
前端·javascript·学习·3d·webgl·数据可视化·着色器
哎呦你好8 小时前
HTML 表格与div深度解析区别及常见误区
前端·html