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

  • 漫步者蓝牙耳机怎么双耳模式(漫步者蓝牙耳机怎么恢复出厂设置)

    漫步者蓝牙耳机怎么双耳模式(漫步者蓝牙耳机怎么恢复出厂设置)

  • opporeno7pro屏幕多大(opporeno7pro屏幕多少厘米)

    opporeno7pro屏幕多大(opporeno7pro屏幕多少厘米)

  • 荣耀30pro支持无线快充的吗(荣耀30pro支持无线座充吗)

    荣耀30pro支持无线快充的吗(荣耀30pro支持无线座充吗)

  • 微信如何关闭自己的朋友圈,可以看别人的(微信如何关闭自己朋友圈功能)

    微信如何关闭自己的朋友圈,可以看别人的(微信如何关闭自己朋友圈功能)

  • 拍抖音怎么自动出歌词(拍抖音怎么自动识别歌词)

    拍抖音怎么自动出歌词(拍抖音怎么自动识别歌词)

  • 网页的元素包括(网页元素包括起始标记)

    网页的元素包括(网页元素包括起始标记)

  • iphone5屏幕点不动(iphone5触屏没反应)

    iphone5屏幕点不动(iphone5触屏没反应)

  • mp1710是什么型号(mp1710和mp1718)

    mp1710是什么型号(mp1710和mp1718)

  • word如何缩进字符(word如何缩进字间距)

    word如何缩进字符(word如何缩进字间距)

  • 计算机网络拓扑主要指(计算机网络拓扑结构主要取决于它的什么)

    计算机网络拓扑主要指(计算机网络拓扑结构主要取决于它的什么)

  • ps炫光怎么做(ps怎么做出炫酷光效效果)

    ps炫光怎么做(ps怎么做出炫酷光效效果)

  • vivox27可以面部识别吗(vivox27可以面部支付吗)

    vivox27可以面部识别吗(vivox27可以面部支付吗)

  • 京东商城怎样延长收货(京东怎么延长退货时间)

    京东商城怎样延长收货(京东怎么延长退货时间)

  • iqooneo支持红外吗(iqooneo3支持红外线)

    iqooneo支持红外吗(iqooneo3支持红外线)

  • bluet00th蓝牙耳机怎么连接(bluet00th蓝牙耳机有一个没声音了怎么办)

    bluet00th蓝牙耳机怎么连接(bluet00th蓝牙耳机有一个没声音了怎么办)

  • 不修改退款原因能退款吗(不修改退款原因怎么办)

    不修改退款原因能退款吗(不修改退款原因怎么办)

  • 华为手机树叶标志是什么(华为手机树叶标志)

    华为手机树叶标志是什么(华为手机树叶标志)

  • 手机怎么开启NFC功能(苹果手机怎么开启NFC)

    手机怎么开启NFC功能(苹果手机怎么开启NFC)

  • 苹果怎么不用wifi下载(苹果怎么不用wifi备份)

    苹果怎么不用wifi下载(苹果怎么不用wifi备份)

  • 腾讯视频如何投屏到电视(腾讯视频如何投影到电视上)

    腾讯视频如何投屏到电视(腾讯视频如何投影到电视上)

  • 桌面ie图标无法删除解决方法(苹果11怎么充不上电了)

    桌面ie图标无法删除解决方法(苹果11怎么充不上电了)

  • 最小的触屏手机是什么(最小的触屏手机有哪些)

    最小的触屏手机是什么(最小的触屏手机有哪些)

  • python怎么导入依赖包(python如何导入excel)

    python怎么导入依赖包(python如何导入excel)

  • 2022-8-29 javaweb  第一天  servlet/tomcat

    2022-8-29 javaweb 第一天 servlet/tomcat

  • 三公经费指的是什么
  • 小规模计提税金及附加会计分录怎么写
  • 契税印花税会计怎么做账务处理
  • 增值税先征后退会计处理
  • 垃圾处理费怎么算
  • 个体户定额多少不用交税
  • 自然人独资企业股东承担连带责任
  • 免抵退税额为什么等于出口价乘以退税率
  • 小规模不报税会怎么样
  • 固定资产进项税额
  • 通行费进项抵扣政策
  • 没收不还
  • 收到土地使用权转让金会计分录
  • 收到国家退税
  • 业务有提成个税怎么扣
  • 库存材料盘亏会计分录
  • 应付利息与应付利息区别
  • 免费送试用装的话术
  • 税收分类编码如何填写
  • 公司代扣代缴个人所得税能查到吗
  • 建筑公司工地买空调
  • 价内税和价外税区别
  • 土地使用税如何计算缴纳
  • 以旧翻新视频
  • 新注册公司季度资产为零
  • 小规模纳税人增值税优惠政策2023
  • 怎么防止电脑被别人远程控制
  • 购买机器设备配件账务处理
  • 清卡处于非征期是什么意思
  • 如何在电子税务局添加开票人
  • 购入未抵扣的固定成本
  • kzip_main.exe是什么
  • axios异步请求数据
  • 应收账款转让的限制约定
  • js正则表达式删除特定字符
  • 北方针叶林的特征有哪些?
  • 工会经费计税依据是上年工资还是当年工资
  • 租用办公设备
  • faster rcnn详解
  • 经营租赁出租方的会计处理
  • phpcms怎么样
  • 建筑业为什么要报统计局
  • 控股子公司破产清算 母公司账务处理
  • 销售返利可以税前扣除吗
  • 库存盘盈盘亏说明
  • 公司的车过户到个人名下需要什么手续
  • 事业单位会计怎么做
  • 实收资本可以以现金入账吗
  • 备用金怎么计入明细账
  • 工程款项目的发包人是谁
  • 投资的公司注销了怎么做账
  • 财务章和公章的样式区别图片
  • SQL Server 2012 sa用户登录错误18456的解决方法
  • sql group by语句
  • 直接内存访问控制器是什么
  • macos越狱教程
  • pe系统找不到系统
  • bios屏蔽nvme
  • ubuntu搭建hexo
  • 使用和启动故障的区别
  • fdb是什么文件
  • 如何关闭win8快速启动
  • win8系统网络设置在哪里
  • win 8系统怎么样
  • 如何关闭win8.1自动更新
  • linux怎么把网卡down
  • win7空间不足c盘
  • cocos2dx用checkbox实现单选框和button实现table按钮
  • perl -pe
  • angular页面加载完后执行方法
  • Python通过DOM和SAX方式解析XML的应用实例分享
  • javascript制作
  • unity飞机大战游戏毕业论文
  • 手把手教怎么说
  • 在windows中快捷键的作用
  • jquery点击方法
  • 内蒙古国家税务局网上电子税务局官网
  • 上海房屋出租交税
  • 公对私转账怎么开票
  • 增值税有哪些税目
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设