位置: IT常识 - 正文

VUE3 之 render 函数的使用 - 这个系列的教程通俗易懂,适合自学(vue使用render)

编辑:rootadmin
VUE3 之 render 函数的使用 - 这个系列的教程通俗易懂,适合自学

目录

1. 概述

2. render 函数

3. 综述

4. 个人公众号


1. 概述

推荐整理分享VUE3 之 render 函数的使用 - 这个系列的教程通俗易懂,适合自学(vue使用render),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vuerender函数,vuerender函数,vue中render的用法,vue使用render,vue中render函数,vuerender函数,vue之render函数详解,vue之render函数详解,内容如对您有帮助,希望把文章链接给更多的朋友!

老话说的好:不用想的太多、太远,做好当天的事,知道明天要做什么就可以了。

言归正传,今天我们来聊聊 VUE 中 render 函数的使用。

2. render 函数

2.1 一个简单的例子

<body> <div id="myDiv"></div></body><script> const app = Vue.createApp({ template:` <my-h> 追风人 </my-h> ` }); app.component('my-h', { template:` <h1> <slot /> </h1> ` }); const vm = app.mount("#myDiv");</script>

 这个例子中,我们用到了之前学的 子组件 和 插槽,实现了对主组件中的文字加 h 标签的功能。

2.2 依据数据,改变 h 标签

const app = Vue.createApp({ data() { return { myLevel: 2 } }, template:` <my-h :level="myLevel"> 追风人 </my-h> ` }); app.component('my-h', { props: ['level'], template:` <h1 v-if="level===1"> <slot /> </h1> <h2 v-if="level===2"> <slot /> </h2> ` });

这个例子中,我们希望依据数据 myLevel 的值,改变主组件中文字的 h 标签,1 对应 h1,2 对应 h2。

2.3 更多的 h 标签

const app = Vue.createApp({ data() { return { myLevel: 3 } }, template:` <my-h :level="myLevel"> 追风人 </my-h> ` }); app.component('my-h', { props: ['level'], template:` <h1 v-if="level===1"> <slot /> </h1> <h2 v-if="level===2"> <slot /> </h2> <h3 v-if="level===3"> <slot /> </h3> <h4 v-if="level===4"> <slot /> </h4> <h5 v-if="level===5"> <slot /> </h5> ` });

我们希望可以有更多的 h 标签供选择,但显然这么写,非常的不优雅。

VUE3 之 render 函数的使用 - 这个系列的教程通俗易懂,适合自学(vue使用render)

2.4 使用 render 函数 简化代码

const app = Vue.createApp({ data() { return { myLevel: 6 } }, template:` <my-h :level="myLevel"> 追风人 </my-h> ` }); app.component('my-h', { props: ['level'], render() { const { h } = Vue; return h('h' + this.level, {name:"myh", id:"myh"}, this.$slots.default()) } });

这个例子中,我们使用 render 函数 代替 template。

const { h } = Vue;  这句是固定写法。

return h('h' + this.level, {name:"myh", id:"myh"}, this.$slots.default())

这句中,第一个参数 'h' + this.level 是标签,第二个参数 {name:"myh", id:"myh"} 是标签的属性,第三个参数 this.$slots.default() 是标签包裹的内容

生成的标签结果如下:<h6 name="myh" id="myh"> 追风人 </h6>

2.5 render 函数包裹更多的内容

const app = Vue.createApp({ data() { return { myLevel: 1 } }, template:` <my-h :level="myLevel"> 追风人 </my-h> ` }); app.component('my-h', { props: ['level'], render() { const { h } = Vue; return h('h' + this.level, {name:"myh", id:"myh"}, [ this.$slots.default(), h('br', {}), h('button', {onclick:"alert(123)"}, '按钮') ]) } });

 render 函数中 h 函数的第三个参数,可以是数组,例如上面的例子,生成的结果如下:

 <h1 name="myh" id="myh"> 追风人 <br><button οnclick="alert(123)">按钮</button></h1>

3. 综述

今天聊了一下 VUE 中 render 函数的使用,希望可以对大家的工作有所帮助,下一节我们继续讲 Vue 中的高级语法,敬请期待

欢迎帮忙点赞、评论、转发、加关注 :)

关注追风人聊Java,这里干货满满,都是实战类技术文章,通俗易懂,轻松上手。

4. 个人公众号

微信搜索公众号:追风人聊Java,欢迎大家关注

本文链接地址:https://www.jiuchutong.com/zhishi/281393.html 转载请保留说明!

上一篇:Linux标准的文件系统知识分享(Ext2/Ext3/Ext4)(linux标准文件和链接文件)

下一篇:系统资源不足无法完成请求的服务win10解决教程(系统资源不足,无法)

  • 产权转让印花税计税依据
  • 如何确定开票税率是否正确
  • 税前扣除什么意思
  • 征税和补贴对市场结果的影响
  • 关税消费税增值税计算公式
  • 个体户增值税按开票额来申报吗
  • 小规模纳税人季报还是月报?
  • 预付款与定金的比例
  • 法人资本个人资本
  • 差旅费包括哪些明细
  • 收到政府补贴现金流量表怎么填
  • 一般存款账户可以办理现金缴存
  • 小规模公司可以贷款吗
  • 运输营改增
  • 查账征收所得税计税依据
  • 财会【2016】22号文
  • 税收分类编码选错了有事吗
  • 六税两费减半征收政策2022
  • 污水处理厂的财务处理流程
  • 购入固定资产税费怎么算
  • 个税零申报工资填0吗
  • 投资性房地产转为存货
  • 小轿车折旧年限规定
  • 咨询费的税费
  • 要求快速启动
  • 关闭自动重新启动会怎样
  • 苹果macOS Big Sur 11.0.1全新系统壁纸
  • 开发成本怎么核算
  • 应收账款需要计提坏账准备吗
  • 委托境外机构研发费加计扣除80%
  • 国产设备投资抵免企业所得税
  • zendstudio怎么创建php项目
  • VUE -- defineExpose
  • vscode简单入门
  • php gzip压缩
  • 废钢收购无进项怎么处理
  • 制造费用期末有余额怎么处理
  • php中实现文件上传需要用到哪几个函数
  • thinkphp自动加载类
  • 小规模季报所得税不超多少不用交税
  • java sc
  • 对c++的认识与体会
  • 工业企业会计核算中常见的会计核算程序有哪些?
  • 所有者投入的资本属于什么会计要素
  • sql2008使用教程
  • 购买的机械设备算固定资产吗
  • 对方给我们等额的钱
  • 多缴附加税退税怎么做账
  • 进项票可以抵扣企业所得税吗
  • 拿工资要开发票,发票去哪儿开?
  • 股权转让如何计算股权原值
  • 业务招待费能计入项目成本吗
  • 已认证发票退回说明模板
  • 库存商品盘盈是什么意思
  • 合资注册公司应该注意什么
  • 核定征收方式的小型微利企业可以享受
  • 开办费没发票如何做账?
  • 公司账户收入金额有规定吗
  • mysql数据库性能
  • 数据库时区与url连接设置的时区
  • windows怎么彻底删除
  • Win7旗舰版系统文件名称
  • Win8系统Smartscreen筛选器界面变灰无法设置的解决方法
  • 硬盘磁盘保护
  • tcpsyncookies
  • solaris ip配置
  • xp系统蓝屏解决
  • 使用标准用户帐号的方法
  • 左手linux+gdb,右手unity+vs,一个bit一个bit地去调试是种什么体验
  • jquery可以实现哪些效果
  • cssimport
  • 滚动的纸箱
  • jquery发送json
  • linux安装nodejs xz格式
  • jq倒计时代码
  • 深入python3
  • javascript页面
  • 新形势下税务工作
  • 小规模纳税人个税税率
  • 丹阳税务局一分局领导
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设