Vue 入门到实战 七

7章 渲染函数

目录

[7.1 DOM树](#7.1 DOM树)

[7.2 什么是渲染函数](#7.2 什么是渲染函数)

[7.3 h()函数](#7.3 h()函数)

[7.3.1 基本参数](#7.3.1 基本参数)

[7.3.2 约束](#7.3.2 约束)

[7.3.3 使用JavaScript代替模板功能](#7.3.3 使用JavaScript代替模板功能)


7.1 DOM树

7.2 什么是渲染函数

在多数情况下,Vue推荐使用模板template来创建HTML。然而在一些应用场景中,需要使用JavaScript创建HTML。这时可以用渲染函数,它比模板更方便。

【例7-1】根据不同等级的锚点,显示不同的标题。

【例7-2】使用渲染函数render改写【例7-1】。

<div id="app">

<anchored-heading :level="1" title="锚点1">Hello world111!</anchored-heading>

<anchored-heading :level="2" title="锚点2">Hello world222!</anchored-heading>

<anchored-heading :level="3" title="锚点3">Hello world333!</anchored-heading>

<anchored-heading :level="4" title="锚点4">Hello world444!</anchored-heading>

<anchored-heading :level="5" title="锚点5">Hello world555!</anchored-heading>

</div>

<script src="js/vue.global.js"></script>

<script>

const app = Vue.createApp({})

app.component('anchored-heading', {

render() {

return Vue.h('h' + this.level,//tag参数

//children参数 Vue.h( 'a',//tag参数 {//props参数 href: '#' + this.title }, this.$slots.default()//children参数 )

)

},

props: {

level: {

type: Number,

required: true

},

title: {

type: String

}

}

})

app.mount('#app')

</script>

render函数的主要神秘地方就是Vue的h函数。

7.3 h()函数

h()函数是一个用于创建虚拟节点(VNode)的程序,也可以更准确地将其命名为createVNode(),以便简洁使用,它被称为h()。

7.3.1 基本参数

1.tag

代表一个HTML标签(String)、一个组件(Object)、一个函数(Function)或者null。使用null将渲染一个注释。这是一个必选参数。例如,【例7-2】中的'a'。

2.props

一个与attribute、prop和事件相对应的数据对象(Object),用于向创建的节点对象设置属性值,在模板中使用。这是一个可选参数。例如,【例7-2】中的{ href: '#' + this.title}。

3.children

子VNode,使用h()函数构建,或使用字符串获取"文本VNode"(String|Array)或者有slot的对象(Object)。这是一个可选参数。

7.3.2 约束

7.3.3 使用JavaScript代替模板功能

1.v-if和v-for指令

在模板中可以使用Vue的内置指令,比如v-if、v-for。但在渲染函数render中,无法使用这些内置指令,只能通过原生JavaScript实现。

【例7-3】v-if和v-for指令在render中的替代方案。

2.v-model指令

在render函数中也没有与v-model指令对应的API,需要使用JavaScript实现v-model指令双向绑定的逻辑。

【例7-4】在render函数中渲染一个输入框,并使用value属性和input事件实现v-model的双向绑定功能。

3.v-on指令

在渲染函数render中,对于v-on指令也需要编程实现。实现v-on指令功能时,我们必须为事件处理程序提供一个正确的prop属性名称,例如,要处理click事件,prop名称应该是onClick。

【例7-5】在render函数中渲染一个按钮,并处理按钮事件click。

4.事件修饰符和按键修饰符

对于.passive、.capture和.once事件修饰符,Vue在渲染函数中提供了处理程序的对象语法。

相关推荐
崔庆才丨静觅10 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby606111 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了11 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅11 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅11 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅12 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment12 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅12 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊12 小时前
jwt介绍
前端
爱敲代码的小鱼12 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax