vue中的功能组件是一个采用渲染上下文并返回渲染html的组件,它没有实例。创建功能组件必须要使用functional: true属性以及渲染功能来创建对象
功能组件可允许以简洁的方式来通过传递上下文创建简单的组件,使它们变得非常简单而大受欢迎,接下来将要在文章中分享的是Vue.js中的功能组件,具有一定的参考价值,希望对大家有所帮助。

【推荐课程:Vue.js教程】
什么是功能组件
立即学习“前端免费学习笔记(深入)”;
功能组件可以看作是与组件相关的功能,也就是说它是一个采用渲染上下文并返回渲染HTML的组件。它没有实例,因此也就没有this。
创建功能组件
要创建一个功能组件,必须要使用functional: true属性以及渲染功能来创建对象。在下面的例子中将创建一个FunctionalButton组件的示例:
export default {
functional: true,
render(createElement, context) {
return createElement('button', 'Click me');
}};渲染上下文
context在render函数上看到的参数称为渲染上下文。它是一个包含以下属性的对象:
props:提供props 的对象
本系统经过多次升级改造,系统内核经过多次优化组合,已经具备相对比较方便快捷的个性化定制的特性,用户部署完毕以后,按照自己的运营要求,可实现快速定制会费管理,支持在线缴费和退费功能财富中心,管理会员的诚信度数据单客户多用户登录管理全部信息支持审批和排名不同的会员级别有不同的信息发布权限企业站单独生成,企业自主决定更新企业站信息留言、询价、报价统一管理,分系统查看分类信息参数化管理,支持多样分类信息,
0
children :VNode 子节点的数组
slots:函数返回slot对象
parent:对父组件的引用
listeners:一个包含了组件上所注册的 v-on 侦听器的对象。这只是一个指向 data.on 的别名。
injections:如果使用了 inject 选项, 则该对象包含了应当被注入的属性。
data: 包含所有先前属性的对象
触发事件
由于功能组件没有实例,事件侦听器来自context.listeners属性上的父级,所以可用以下代码来实现click事件
例:假设有一个App.vue组件,可以在其中导入FunctionalButton.js以在其模板中使用它
<template>
<FunctionalButton>
Click me
</FunctionalButton></template>export default {
functional: true,
render(createElement, { props, listeners, children }) {
return createElement(
'button',
{
attrs: props,
on: {
click: listeners.click
}
},
children
);
}};总结:以上就是本篇文章的全部内容了,希望对大家有所帮助。
以上就是Vue.js中的功能组件的理解的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号