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

相关推荐
三小河3 分钟前
overflow:auto 滚动的问题,以及flex 布局中如何设置
前端·javascript
薛定谔的算法6 分钟前
phoneGPT:构建专业领域的检索增强型智能问答系统
前端·数据库·后端
Hilaku7 分钟前
Token已过期,我是如何实现无感刷新Token的?
前端·javascript·面试
小文刀69611 分钟前
2025-35st-w-日常开发总结
前端
我是日安13 分钟前
从零到一打造 Vue3 响应式系统 Day 8 - Effect:深入剖析嵌套 effect
前端·vue.js
小lan猫17 分钟前
React学习笔记(一)
前端·react.js
晨米酱17 分钟前
JavaScript 中"对象即函数"设计模式
前端·设计模式
拜无忧18 分钟前
【教程】Nuxt v4 入门指南与实践 (vue前端角度开发)
前端·nuxt.js
云枫晖21 分钟前
手写Promise-什么是Promise
前端·javascript
拜无忧21 分钟前
html,svg,花海扩散效果
前端·css·svg