位置: IT常识 - 正文

uniapp中的renderjs使用(uniapp中的onload)

编辑:rootadmin
uniapp中的renderjs使用

推荐整理分享uniapp中的renderjs使用(uniapp中的onload),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:uniapp中的swiper包裹video滚动不了,uniapp中的uni-file-picker文件列表关闭,uniapp中的条件渲染和列表渲染的语法是什么,uniapp中的global,uniapp中的fab组件中的trigger,uniapp中的onload,uniapp中的fab组件中的trigger,uniapp中的swiper包裹video滚动不了,内容如对您有帮助,希望把文章链接给更多的朋友!

需求是用openlayers在uniapp框架下做一个移动gis类的软件,选择用renderjs实现地图与dom的交互,一开始也是小白,通过百度资料以及一步步测试后掌握了renderjs的使用,以及地图功能的实现。

                      

一、renderjs的作用是什么?

renderjs 主要服务于APP,因为uni-app为vue+js+html进行编写,整个是h5的技术栈。而app上并没有document等基础对象。那么,涉及到这些的前端类库就无法使用,例如html2、canvas、canvas2、image。而要用这些怎么办,这是用就出现了renderjs这种视图层工具来进行渲染。

运行在视图层的js

uniapp中的renderjs使用(uniapp中的onload)

大幅降低逻辑层和视图层的通讯损耗,提供高性能视图交互能力(减少通讯损耗提升性能,例如一些手势或canvas动画的场景)

在视图层操作dom,运行for web的js库(可以操作dom,意味着拥有window、document等这些全局变量,在app-vue的service层没有这些)

二、renderjs怎样使用?

1.原生层数据通过监听传入renderjs层(可以通过调用原生层的方法触发)

2.直接调用renderjs层方法传出数据

三、测试代码(借用网上一段代码,写的很全面)

<template> <view> <view :msg="msg" :change:msg="renderScript.receiveMsg" class="renderjs" id="renderjs-view">{{msg}}</view> <button @click="renderScript.emitData">直接调用renderjs中的emitData的方法</button><button @click="changeMsg" class="app-view">改变msg的值,直接调用renderjs中receiveMsg的值</button><button @click="renderScript.renferMsg">通过renderjs改变msg的值,同时调用renderjs中的emitData的方法</button> </view></template><script> export default { data() { return { msg: '我是service层原来的msg', }; }, methods: { // 触发逻辑层出入renderjs数据改变 changeMsg() { this.msg = "msg值改变了"; }, // 接收renderjs发回的数据 receiveRenderData(val) { console.log('renderjs返回的值-->', val); }, //接收renderjs发回的数据,同时触发:change:msg,调用enderjs中的emitData的方法 serviceClick(e){ this.msg=e } } };</script><script module="renderScript" lang="renderjs"> export default { data() { return { name: '我是renderjs数据' } }, methods: { renferMsg(event, ownerInstance) { // 调用 service层的serviceClick方法,传值console.log(event,ownerInstance) ownerInstance.callMethod('serviceClick', { test: '这是点击renderjs的区域,向service层传递变量' }) }, // 接收逻辑层发送的数据 receiveMsg(newValue, oldValue, ownerVm, vm) { console.log('msg变化了newValue', newValue) console.log('msg变化了oldValue', oldValue) console.log('msg变化了ownerVm', ownerVm) console.log('msg变化了vm', vm) }, // 发送数据到逻辑层 emitData(e, ownerVm) { ownerVm.callMethod('receiveRenderData', this.name) } } };</script>

注意:1.在renderjs层不能使用uni或其他框架的API,例如uni.request、uni.getlocation等等方法,需在原生层调用后触发监听将数据传入。

2.在APP端renderjs层的data与原生层的data互不相干

3.this.$ownerInstance.callMethod方法必须通过点击事件执行

4.地图方法都要写在renderjs层中,不能使用子组件

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

上一篇:Win11升级反馈:可使用Win7兼容性模式运行升级助手绕过系统兼容性测试(win10升级win11报错)

下一篇:Mac系统中如何给PDF文件加密(mac 怎么操作)

  • 资源税应该如何计算
  • 投标保证金保险怎么买
  • 在建无形资产入账
  • 个税申报赡养老人可以填公婆吗
  • 每月先报税还是先清卡
  • 充电桩收入属于什么类别
  • 业务员不拿工资怎么办
  • 防伪税控业务
  • 企业内部商品转移怎么核算
  • 确认销售收入的重要依据是什么
  • 交了定金签了合同
  • 境内企业借外债最新政策出台
  • 怎么结转销项税额
  • 总公司的哪些费用要交税
  • 所得税预提多了怎么处理
  • 工业结转成本方法有哪些?
  • 工资基数缴纳个税怎么交
  • 查账征收所得税计税依据
  • 贴现扣的钱叫什么
  • 怎么激活win10密钥
  • 电脑中病毒了怎么重装系统
  • Mac怎么用有线网络
  • 工商年报中生育保险本期实际缴费金额
  • 经营出租固定资产折旧额计入什么科目
  • 苹果电脑设置壁纸为什么重启就没了
  • 纳税调整需要调年度报表嘛
  • 广告业进项都能开什么票
  • phpexplode函数
  • adv举例
  • PHP:pg_consume_input()的用法_PostgreSQL函数
  • php的超级全局变量
  • 应付职工薪酬怎么做记账凭证
  • 财务管理公司属于什么行业类别
  • 关键点检测backbone
  • 苏格兰高地牛一个萌萌哒的合集
  • ros算法
  • SpringBoot+Vue实现简单用户管理平台第一篇(后端接口设计)
  • react生命周期详解
  • php微信公众号开源框架
  • 营改增小规模纳税人可以进项税额扣除对吗
  • 生产过程报废和返工产生的成本
  • phpcms数据库文件
  • phpcms程序
  • 出资比例为0
  • 报废的设备属于什么
  • 支付长期借款利息时,应借记什么账户
  • 餐饮服务税率是服务类税率还是货物类
  • 应付劳务费怎么做账
  • 职工教育经费的扣除限额
  • 出口退免税的税种包括增值税消费税企业所得税
  • 附加税多交了怎么抵税
  • 多栏式日记账核算组织程序优缺点
  • 开出银行汇票支付货款
  • 客户给的现金如何转到公司账上
  • 认缴资金 实缴资金
  • 以前年度应付款少记怎么入账
  • 咨询服务业成本比例
  • 公司发放给员工的福利又要回
  • 未实现融资收益借贷方向
  • 什么是固定资产清理
  • 残保金是否为强制缴纳
  • 微软补丁星期二更新吗
  • Win7系统连接vpn失败且提示错误代码868的2种解决方法
  • xp系统如何禁止软件联网
  • ubuntu安装chia
  • linux lv vg
  • 怎么判断电脑windows几
  • jquery简单例子
  • 什么是漫反射贴图
  • Node.js中的包管理工具是什么
  • unity3d模型怎么制作
  • javascriptcsdn
  • python多线程作用
  • Android studio 打包apk后卡在首屏
  • android屏幕适配的五种方式
  • 怎样从增值税发票查询
  • 残疾人创业有税收什么优惠政策
  • 消费税是由消费者完全负担的税种
  • 江西发票税率
  • 公司迁税务所流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设