vue render 渲染函数
2024-08-24 17:22:27
vue render 渲染函数
经常看到使用render
渲染函数的示例,而且在一些特殊情况下,确实更好使用,可以更加有效地细分组件,因而借助vue-element-admin
来学习一波
render函数分析
- 函数式组件
- 基础的使用方式
针对 Link.vue进行改造
Link.vue
// https://github.com/vuejs/eslint-plugin-vue/issues/462
<template>
<!-- eslint-disable vue/require-component-is -->
<component v-bind="linkProps(to)">
<slot />
</component>
</template>
<script>
import { isExternal } from '@/utils/validate'
export default {
props: {
to: {
type: String,
required: true
}
},
methods: {
linkProps(url) {
if (isExternal(url)) {
return {
is: 'a',
href: url,
target: '_blank',
rel: 'noopener'
}
}
return {
is: 'router-link',
to: url
}
}
}
}
</script>
上述方式打开了一个新的使用方式,这样的好处,不需要使用if/else
进行处理,还可以减少一个多余的标签【root element】。但是会有一些语法提示错误,虽然添加了eslint-disable
来禁止,但还是不行,而且有些不似vue
的用法
改造开始
- 版本一 非函数式组件 【Link.vue】
<script>
import { isExternal } from '@/utils/validate'
export default {
name: 'Link',
props: {
to: {
type: String,
required: true
}
},
render(h) {
if (isExternal(this.to)) {
return h(
'a',
{
attrs: {
target: '_blank',
rel: 'noopener',
href: this.to
}
},
this.$slots.default
)
} else {
return h('router-link',
{
props: {
to: this.to
}
},
this.$slots.default
)
}
}
}
</script>
主要是slot
如何处置比较好,其他都好处理,而且使用slot
有两种方式 插槽
方式一
this.$slots.default
方式二
this.$scopedSlots.default()
- 版本二 函数式组件 【Link.vue】
<script>
import { isExternal } from '@/utils/validate'
export default {
name: 'Link',
functional: true,
props: {
to: {
type: String,
required: true
}
},
render(h, context) {
console.log(context)
const { props, scopedSlots } = context
const { to } = props
if (isExternal(to)) {
return h(
'a',
{
attrs: {
target: '_blank',
rel: 'noopener',
href: to
}
},
scopedSlots.default()
)
} else {
return h('router-link',
{
props: {
to: to
}
},
// scopedSlots.default()
context.children
)
}
}
}
</script>
对于上述两种实现方式,大致相同,有一些细节需要注意
functional: true
添加这个后,只能通过context
来进行上下文关联,而无法调用this
,同时这种方式会快一些,只是在使用slot
时,会有两种形式linkthis.$slots.default
更新为context.children
scopedSlots.default()
这种方式依旧在
- 当时用
functional: true
,文件名便可以改为js
为后缀了,若依旧使用vue
时,便需要<script> export default {}</script>
进行包裹了
总结
render
函数更多是,很多细节不能使用语法糖来进行处理,导致使用起来不顺手slot
插槽这块还是很有用的,只是文档说明等没有前面的那么详细了- 通过上述方式,便发现原来可以这么玩,而且细粒度已经都要一层标签了,若使用原来的方式,
root element
怕是就够处理好一会儿了
最新文章
- ajax浅析---ScriptManagerProxy
- cppcheck 下载与安装(Liunx)
- linux内核SPI总线驱动分析(二)(转)
- HDU 1104 Remainder
- NDK(14)Native的char*和Java的String相互转换
- 将Ecshop后台fckeditor升级更改为kindeditor 4.1.10编辑器
- [课堂实践与项目]手机QQ客户端--4期(SQLite的加入,注册,找回,登录界面的修改):建立关于QQ注册类,使用SQLite进行存储,
- careercup-数组和字符串1.2
- 图示Servelet请求过程
- Spring MVC在接收复杂集合参数
- Flask学习记录之Flask-Mail
- jquery中的uploadfile关于图片上上传的插件的应用
- Java 多态透析 详细理解
- python 的基础 学习 第七天 is id 编码的补充
- javascript基于对象的弹出框封装
- FFT 【JSOI2012】bzoj4332 分零食 (未解决)
- C#6.0语言规范(十七) 特性
- TFS 2015 Build Agent failing syncing the repository 获取源码 不全 失败
- Echarts 如何与 百度地图结合?
- (转)Elasticsearch NoNodeAvailableException None of the configured nodes are available
热门文章
- 成功解决internal/modules/cjs/loader.js:596 throw err; ^ Error: Cannot find module &#39;minimatch&#39;
- 解决eclipse无法部署工程到tomcat运行的问题
- CommandLineRunner and ApplicationRunner
- 关于Java 8 forEach
- Java密码处理
- 第五次实验报告&;学习总结
- Excel中使用Power Query获取网页json数据
- Singletom 单例
- 查看Linux基本系统信息
- 全面解读php-开发环境及配置