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

相关推荐
好好学习O(∩_∩)O3 分钟前
QT6引入QMediaPlaylist类
前端·c++·ffmpeg·前端框架
敲代码的小吉米3 分钟前
前端HTML contenteditable 属性使用指南
前端·html
testleaf14 分钟前
React知识点梳理
前端·react.js·typescript
站在风口的猪110814 分钟前
《前端面试题:HTML5、CSS3、ES6新特性》
前端·css3·html5
Xiao_die88815 分钟前
前端八股之CSS
前端·css
每天都有好果汁吃1 小时前
基于 react-use 的 useIdle:业务场景下的用户空闲检测解决方案
前端·javascript·react.js
穗余1 小时前
NodeJS全栈开发面试题讲解——P10微服务架构(Node.js + 多服务协作)
前端·面试·node.js
横冲直撞de1 小时前
前端下载文件,文件打不开的问题记录
前端
占星安啦1 小时前
一个html实现数据库自定义查询
java·前端·javascript·数据库·动态查询
love530love1 小时前
Windows 下部署 SUNA 项目:虚拟环境尝试与最终方案
前端·人工智能·windows·后端·docker·rust·开源