Vue入门指北——渲染函数和jsx

简介: Vue入门指北——渲染函数和jsx

前言


在进行vue的开发时,我们往往会遵从vue的规范,在template标签中编写html,在script标签中编写JavaScript,在style标签中编写css。但在有些情况下,尽管这种方式也可以实现我们想要的效果,但是可能编写的时候会比较麻烦,需要很多的判断,但是,如果他能和JavaScript联动起来,我想它肯定会变得更加高效。


渲染函数


比如我们有一个title组件:


// title.vue
<h1>彼时彼刻,恰如此时此刻</h1>
复制代码


在父组件引用:


// page.vue
<title level="1"></title>
<title level="2"></title>
<title level="3"></title>
复制代码


title组件根据传来的level prop动态改变,h标签。你可能想到这么实现:


title.vue
...
<h1 v-if="level === 1">彼时彼刻,恰如此时此刻<slot><slot></h1>
<h2 v-if="level === 2">彼时彼刻,恰如此时此刻<slot><slot></h2>
<h3 v-if="level === 3">彼时彼刻,恰如此时此刻<slot><slot></h3>
...
...
props: {
    level: {
        type: Number,
        required: true
    }
}
...
复制代码


尽管这么写,实现我们想要的效果,但是每次写的时候,h都要再写一遍。如果是业务繁杂的话,结构将会更加复杂。


而这种情况,我们完全可以根据vue提供的render方法来解决。


// title.vue
render(createElement) {
    return createElement(
        'h' + this.level, 
        彼时彼刻,恰如此时此刻
    )
},
props: {
    level: {
        type: Number,
        required: true
    }
}
复制代码


这样看起来,是不是就方便多了。


jsx


当然,通过render回调的 createElement参数来编写可以解决我们的问题。但是如果结构复杂的话,这么写可以说是非常折磨的,而如果也能通过html的形式写的话,那是再好不过的。正好jsx就可以解决我们的问题:


JSX:是一个 JavaScript 的语法扩展。可以在JavaScript中编写html,具有 JavaScript 的全部功能。


具体特性,请参考文档。


安装


npm install @vue/babel-preset-jsx @vue/babel-helper-vue-jsx-merge-props
复制代码


// babel.config.js
module.exports = {
  presets: ['@vue/babel-preset-jsx'],
}
复制代码


有了jsx,我们就可以这样实现:


// title.vue
render(createElement) {
    const tag = `h${this.props.level}`
    return (
        <tag>
            彼时彼刻,恰如此时此刻
        </tag>
    )
},
props: {
    level: {
        type: Number,
        required: true
    }
}


相关文章
|
2天前
|
JavaScript 前端开发
vue(1),小白看完都会了
vue(1),小白看完都会了
|
2天前
|
JavaScript 开发工具 git
Vue 入门系列:.env 环境变量
Vue 入门系列:.env 环境变量
8 1
|
2天前
|
缓存 监控 JavaScript
探讨优化Vue应用性能和加载速度的策略
【5月更文挑战第17天】本文探讨了优化Vue应用性能和加载速度的策略:1) 精简代码和组件拆分以减少冗余;2) 使用计算属性和侦听器、懒加载、预加载和预获取优化路由;3) 数据懒加载和防抖节流处理高频事件;4) 图片压缩和选择合适格式,使用CDN加速资源加载;5) 利用浏览器缓存和组件缓存提高效率;6) 使用Vue Devtools和性能分析工具监控及调试。通过这些方法,可提升用户在复杂应用中的体验。
10 0
|
2天前
|
JavaScript
vue知识点
vue知识点
10 0
|
3天前
|
JavaScript 前端开发 定位技术
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
|
数据库
基于springboot+mybatisplus+vue的课程学分管理系统
基于springboot+mybatisplus+vue的课程学分管理系统
105 0
基于springboot+mybatisplus+vue的课程学分管理系统
基于Springboot+MybatisPlus+Vue的在线课程管理系统
基于Springboot+MybatisPlus+Vue的在线课程管理系统
112 0
基于Springboot+MybatisPlus+Vue的在线课程管理系统
|
JavaScript 前端开发 Java
基于Springboot+MybatisPlus+Vue的前后端分离的学生选课课程教务管理系统
基于Springboot+MybatisPlus+Vue的前后端分离的学生选课课程教务管理系统
189 0
基于Springboot+MybatisPlus+Vue的前后端分离的学生选课课程教务管理系统
|
JavaScript 开发者
Vue 课程介绍|学习笔记
快速学习 Vue 课程介绍
97 0
|
JavaScript 开发者
Vue课程介绍|学习笔记
快速学习Vue课程介绍
76 0