位置: 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 怎么操作)

  • 芒果tv vip可以登几个手机(芒果vip可以登录几个设备)

    芒果tv vip可以登几个手机(芒果vip可以登录几个设备)

  • 抖音隐藏作品在哪里(抖音隐藏作品在哪里我怎么看不到)

    抖音隐藏作品在哪里(抖音隐藏作品在哪里我怎么看不到)

  • 手机响但是没有看见有通知(手机响但是没有来电显示)

    手机响但是没有看见有通知(手机响但是没有来电显示)

  • 苹果11突然没信号(苹果11突然没信号怎么办)

    苹果11突然没信号(苹果11突然没信号怎么办)

  • 挂脖耳机充电口在哪里(挂脖耳机充电口防尘塞)

    挂脖耳机充电口在哪里(挂脖耳机充电口防尘塞)

  • 苹果11后壳容易碎吗(苹果11后壳容易刮花)

    苹果11后壳容易碎吗(苹果11后壳容易刮花)

  • lunix是什么(lunix是哪国的)

    lunix是什么(lunix是哪国的)

  • 微信备注修改有上限吗(微信备注修改有影响吗)

    微信备注修改有上限吗(微信备注修改有影响吗)

  • WPS幻灯片版式在哪个选项卡(wps幻灯片版式在哪里)

    WPS幻灯片版式在哪个选项卡(wps幻灯片版式在哪里)

  • 手机屏幕与机身分离还可以修复吗(手机屏幕与机身分离可以充电吗)

    手机屏幕与机身分离还可以修复吗(手机屏幕与机身分离可以充电吗)

  • 微信对方已删除账号是什么意思(微信对方已删除好友)

    微信对方已删除账号是什么意思(微信对方已删除好友)

  • 爱追剧app怎么播放不了(爱追剧网站怎么了)

    爱追剧app怎么播放不了(爱追剧网站怎么了)

  • vivoy97充电慢是怎么回事(vivoy79充电越来越慢)

    vivoy97充电慢是怎么回事(vivoy79充电越来越慢)

  • 华为手机高清通话怎么关(华为手机高清通话设置在哪里)

    华为手机高清通话怎么关(华为手机高清通话设置在哪里)

  • 微博加入黑名单的人还能看见我的微博吗(微博加入黑名单会怎么样)

    微博加入黑名单的人还能看见我的微博吗(微博加入黑名单会怎么样)

  • oppo手机横屏怎么关掉(OPPO手机横屏怎么截屏)

    oppo手机横屏怎么关掉(OPPO手机横屏怎么截屏)

  • iphone8有没有3dtouch(Iphone8有没有nfc)

    iphone8有没有3dtouch(Iphone8有没有nfc)

  • 怎样设置开机不自动启动(怎样设置开机不自动启动软件)

    怎样设置开机不自动启动(怎样设置开机不自动启动软件)

  • 苹果电池寿命75%要换吗(苹果电池效率75要换吗)

    苹果电池寿命75%要换吗(苹果电池效率75要换吗)

  • 抖音上怎么放图片视频(抖音上怎么放图片赚钱)

    抖音上怎么放图片视频(抖音上怎么放图片赚钱)

  • 拼多多主图怎么上视频(拼多多主图怎么做吸引人)

    拼多多主图怎么上视频(拼多多主图怎么做吸引人)

  • win10卸载xbox有影响吗(xbox卸载没事吧)

    win10卸载xbox有影响吗(xbox卸载没事吧)

  • 全民k歌怎么设置权限(全民k歌怎么设置隐身访问)

    全民k歌怎么设置权限(全民k歌怎么设置隐身访问)

  • 如何解决win10电脑键盘被锁住无法打开?(windows10 电脑)

    如何解决win10电脑键盘被锁住无法打开?(windows10 电脑)

  • 布里斯托尔海峡的伯恩贝克码头,英国滨海韦斯顿北索美塞得 (© Stephen Davies/Adobe Stock)(布里斯托尔景点)

    布里斯托尔海峡的伯恩贝克码头,英国滨海韦斯顿北索美塞得 (© Stephen Davies/Adobe Stock)(布里斯托尔景点)

  • 视同销售行为的涉税处理?
  • 养殖合作社属于什么行业
  • 一般纳税人支付给小规模纳税人的税率
  • 土地以租代卖,违法吗
  • 没有认证的增值税专用发票怎么做账
  • 企业弥补亏损的三个途径
  • 同一张记账凭证可以出现多笔分录吗
  • 物流公司进项发票分录
  • 增值税进项税金额是含税还是不含税
  • 土地税退税做什么分录
  • 对公付款没有发票
  • 购买股票如果公司亏损
  • 个体工商户个人所得税怎么计算
  • 贷款利息支出必须交税吗
  • 营改增试点实施办法的法律层次是
  • 所得税需要结转嘛
  • 兼营小规模纳税人增值税优惠
  • 纳税人必知的十七项增值税开票指南
  • 买卖投资证券基金怎么进行财税处理?
  • 雄安新区纳入综合考核
  • 对方公司已注销,我公司应付款怎样支付
  • 土地收储的含义
  • 研发费用入账
  • 资源税可能计入
  • 公司注销时债权债务怎么处理
  • 权益法核算的投资收益要做递延所得税吗
  • 剑灵玩一会就崩溃
  • 怎么用苹果6splus
  • macbook如何安装
  • 抵押,质押,留置的区别与联系
  • php实现保存网站内容
  • typecho安装插件
  • linux相关命令及用法
  • 计提本月应缴纳的所得税
  • 股东权益增加额/期初净经营资产
  • 股权转让所得怎么做账
  • 货物运输增值税管理
  • 如何办理车辆购置证变更手续
  • 税务新政策解读
  • 玄武湖公园游玩
  • 框架 frame
  • 睿智目标检测yolov8
  • 轮播图效果用css怎么实现
  • 应付职工薪酬账户期末余额可能是
  • 关联企业之间业务往来如何定价
  • 施工单位代建收费合法吗
  • 公司转让后原账本怎么处理
  • java基础运算符有哪些
  • 已申报营业税未开发票
  • 对于投资者而言购买债券型理财产品面临的最大风险来自
  • 银行承兑汇票进行贴现理财
  • sqlyog配置
  • 主营业务收入和营业外收入均属于收入
  • 退付现金什么意思
  • 受托加工的成本
  • 销售费用主要账户包括
  • 应发工资计入什么科目
  • 补缴以前年度的税
  • 哪些费用计入管理费用开办费
  • 公司注销怎么做
  • 出租使用权什么意思
  • 施工企业如何确权
  • 受托开发软件一般做什么
  • 融资租赁首付租金会计账务处理
  • win10安装sqlserver2016出错
  • SQLServer 通用的分区增加和删除的算法
  • winxp密码忘了
  • 双硬盘无法进入bios
  • win10预览版
  • win7安全更新kb4534314
  • excel中利用条件格式展示数据
  • nodejs test
  • python和java对接
  • jquery的validate前端表单验证
  • 国家税务稽查局举报中心
  • 工会开票要求
  • 企业自建房如何缴税
  • 企业税收筹划的最终目的
  • 乌鲁木齐税收政策
  • 银行前置利息什么意思
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设