Vue Render函数原理及代码实例解析


Posted in Javascript onJuly 30, 2020

简单的说,在vue中我们使用模板HTML语法组建页面的,使用render函数我们可以用js语言来构建DOM

因为vue是虚拟DOM,所以在拿到template模板时也要转译成VNode的函数,而用render函数构建DOM,vue就免去了转译的过程。

当使用render函数描述虚拟DOM时,vue提供一个函数,这个函数是就构建虚拟DOM所需要的工具。官网上给他起了个名字叫createElement。还有约定的简写叫h

虽然在render里使用createElement函数创建DOM节点不是很直观,但是在部分独立组件的设计中还是可以满足一些特殊需求的。一个简单的render示例如下:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>
<body>
  <div id="app">
    <my-component :list="list"></my-component>
  </div>
  <script src="vue.js"></script>
  <script>
    Vue.component('my-component', {
      props: {
        list: {
          type: Array,
          default: () => []
        }
      },
      render(createElement) {
        if (this.list.length) {
          return createElement('ul', this.list.map(item => createElement('li', item)))
        } else {
          return createElement('p', 'Empty list')
        }
      }
    })
    new Vue({
      el: '#app',
      data: {
        list: ['html', 'css', 'javascript']
      }
    })
  </script>
</body>
</html>

另外,由于v-if,v-else,v-show等指令都无法在render里使用,需要自己手动实现,拿常用的v-model举个栗子:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Vue.component('my-component', {
  data() {
    return {
      message: ''
    }
  },
  render(createElement) {
    return createElement(
      'div',
      [
        createElement(
          'input',
          {
            on: {
              input: e => this.message = e.target.value
            }
          }
        ),
        createElement('p', this.message)
      ]
    )
  }
})
Javascript 相关文章推荐
jQuery选择头像并实时显示的代码
Jun 27 Javascript
SWFObject 2.1以上版本语法介绍
Jul 10 Javascript
一个基于jQuery的树型插件(OrangeTree)使用介绍
May 03 Javascript
js/jQuery对象互转(快速操作dom元素)
Feb 04 Javascript
jquery仿京东导航/仿淘宝商城左侧分类导航下拉菜单效果
Apr 24 Javascript
设置jquery UI 控件的大小方法
Dec 12 Javascript
BootStrapTable 单选及取值的实现方法
Jan 10 Javascript
利用HTML5+Socket.io实现摇一摇控制PC端歌曲切换
Jan 13 Javascript
详解Node中导入模块require和import的区别
Aug 11 Javascript
vue 项目如何引入微信sdk接口的方法
Dec 18 Javascript
详解vue中async-await的使用误区
Dec 05 Javascript
JS hasOwnProperty()方法检测一个属性是否是对象的自有属性的方法
Jan 29 Javascript
vue - props 声明数组和对象操作
Jul 30 #Javascript
vue项目,代码提交至码云,iconfont的用法说明
Jul 30 #Javascript
vue如何使用外部特殊字体的操作
Jul 30 #Javascript
在vue-cli3中使用axios获取本地json操作
Jul 30 #Javascript
JavaScript JSON使用原理及注意事项
Jul 30 #Javascript
解决vue cli4升级sass-loader(v8)后报错问题
Jul 30 #Javascript
基于JavaScript实现猜数字游戏代码实例
Jul 30 #Javascript
You might like
上传多个文件的PHP脚本
2006/11/26 PHP
php $_ENV为空的原因分析
2009/06/01 PHP
无法载入 mcrypt 扩展,请检查 PHP 配置终极解决方案
2011/07/18 PHP
thinkphp四种url访问方式详解
2014/11/28 PHP
php模拟用户自动在qq空间发表文章的方法
2015/01/07 PHP
PHP支付系统设计与典型案例分享
2016/08/02 PHP
thinkphp自带验证码全面解析
2016/09/18 PHP
PHP以json或xml格式返回请求数据的方法
2018/05/31 PHP
在PHP中实现使用Guzzle执行POST和GET请求
2019/10/15 PHP
laravel model 两表联查示例
2019/10/24 PHP
IE 下的只读 innerHTML
2009/08/21 Javascript
firefox下jquery ajax返回object XMLDocument处理方法
2014/01/26 Javascript
js跨浏览器的事件侦听器和事件对象的使用方法
2015/12/17 Javascript
javascript运动框架用法实例分析(实现放大与缩小效果)
2016/01/08 Javascript
javascript实现随机生成DIV背景色
2016/06/20 Javascript
JS组件系列之使用HTML标签的data属性初始化JS组件
2016/09/14 Javascript
canvas绘制爱心的几种方法总结(推荐)
2017/10/31 Javascript
详解vue使用vue-layer-mobile组件实现toast,loading效果
2018/08/31 Javascript
微信小程序 云开发模糊查询实现解析
2019/09/02 Javascript
vue实现简易计算器功能
2021/01/20 Vue.js
浅谈python import引入不同路径下的模块
2017/07/11 Python
python自定义异常实例详解
2017/07/11 Python
Python使用装饰器进行django开发实例代码
2018/02/06 Python
python实现对求解最长回文子串的动态规划算法
2018/06/02 Python
Django 解决开发自定义抛出异常的问题
2020/05/21 Python
python爬虫使用scrapy注意事项
2020/11/23 Python
pycharm配置QtDesigner的超详细方法
2021/01/25 Python
pandas apply使用多列计算生成新的列实现示例
2021/02/24 Python
迪卡侬(Decathlon)加拿大官网:源自法国的运动专业超市
2020/11/22 全球购物
志愿者活动总结报告
2014/06/27 职场文书
小学生运动会通讯稿
2014/09/23 职场文书
企业2014年度工作总结
2014/12/10 职场文书
golang中的struct操作
2021/11/11 Golang
vue实力踩坑之push当前页无效
2022/04/10 Vue.js
vue3种table表格选项个数的控制方法
2022/04/14 Vue.js
Golang 链表的学习和使用
2022/04/19 Golang