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在渲染函数中提供了处理程序的对象语法。

相关推荐
LCG元1 小时前
Vue.js组件开发-如何实现异步组件
前端·javascript·vue.js
Lorcian1 小时前
web前端12--表单和表格
前端·css·笔记·html5·visual studio code
问道飞鱼1 小时前
【前端知识】常用CSS样式举例
前端·css
wl85111 小时前
vue入门到实战 三
前端·javascript·vue.js
ljz20162 小时前
本地搭建deepseek-r1
前端·javascript·vue.js
爱是小小的癌2 小时前
Java-数据结构-优先级队列(堆)
java·前端·数据结构
傻小胖2 小时前
vue3中Teleport的用法以及使用场景
前端·javascript·vue.js
Enti7c3 小时前
用 HTML、CSS 和 JavaScript 实现抽奖转盘效果
前端·css
LCG元3 小时前
Vue.js组件开发-使用Vue3如何实现上传word作为打印模版
前端·vue.js·word