百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

uni-app使用经验—vue页面和html页面如何互相调用接口并传参

xsobi 2024-12-27 17:28 1 浏览

说明

最近在项目上有个移动端(uni-app)的需求,就是要在移动端APP上的vue页面中通过web-view组件来调用html页面,并且要实现在html页面中可以点击一个元素来调用vue页面中uni的API(扫码接口),同时也可以在vue页面中也可以调用html页面中的js函数并进行传参。

使用环境

1. HBuilderX版本:2.8.11.20200907

2. V3编译器

html页面调用vue页面中uni的API

引用依赖的文件

在 web-view 加载的 HTML 中调用 uni 的 API,需要在 HTML 中引用必要的 JS-SDK

<script type="text/javascript" src="//js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.0.1.52.js"></script>

注意:这些 JS 文件是在 web-view 加载的那个 HTML 文件中引用的,而不是 uni-app 项目中的文件。

监听 web-view 的 message 事件

监听 web-view 组件的 message 事件,然后在事件回调的 event.detail.data 中接收传递过来的消息。

<template>  

    <view>  

        <web-view src="http://192.168.1.1:3000/test.html" @message="handleMessage"></web-view>  

    </view>  

</template>  

<script>  

    export default {  

        methods: {  

            handleMessage(evt) {  

                console.log('接收到的消息:' + JSON.stringify(evt.detail.data));  

            }  

        }  

    }  

</script>

调用的时机

在引入上面的依赖文件后,需要在HTML中监听UniAppJSBridgeReady,事件触发后,

才能安全调用uni的API。

<script type="text/javascript" src="//js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.0.1.52.js"></script>

<script>

    document.querySelector('.btn-list').addEventListener('click', function(evt) {  

        var target = evt.target;  

        if (target.tagName === 'BUTTON') {  

            var action = target.getAttribute('data-action');  

            if(action === 'navigateTo') {  

				uni.postMessage({  

					data: {  

						action: 'postMessage'  

					}  

				});   

            }  

        }  

    }); 

</script>

上面代码的意思就是在html页面中点击按钮列表中的某个按钮,

触发了uni.postMessage接口,进而调用了vue页面methods中的handleMessage方法,

并将参数data传给了vue页面。

在vue页面中调用html页面的js函数

示例代码:

var currentWebview = this.$mp.page.$getAppWebview().children()[0];
currentWebview.evalJS("htmljsfuc('"+res.result+"')");

其中的htmljsfuc就是要在html页面中定义的js函数。

完整代码示例:

<template>

	<view>

		<web-view :src="url" @message="handleMessage" ref="webview"></web-view>

	</view>

</template>

<script>

export default {

	data() {

		return {

			url:'http://192.168.81.102:8021/test.html',

			

			webviewStyles: {

				progress: {

					color: '#FF3333'

				}

			}

		};

	},

	methods: {

		handleMessage(evt) {

			console.log('接收到的消息:' + JSON.stringify(evt.detail.data));

			var that=this;

			uni.scanCode({

			    success: function (res) {

			        console.log('条码类型:' + res.scanType);

			        console.log('条码内容:' + res.result);

                    //将扫码结果传给html页面

					var currentWebview = that.$mp.page.$getAppWebview().children()[0];

					currentWebview.evalJS("htmljsfuc('"+res.result+"')");

					

					uni.showModal({

						content: '扫码成功!\n'+'扫码结果:' + res.result,

						showCancel: false

					});

			    }

			});

		}

	}

}

</script>

<style></style>

相关推荐

一文揭秘领域驱动设计(DDD):领域和子域

★★★建议星标我们★★★2020年Java原创面试题库连载中...

DDD领域驱动设计最全详解(图文全面总结)

DDD领域驱动设计是现在非常火热的设计架构,而且大厂面试也经常考察,下面我就全面来详解DDD领域驱动设计@mikechen本篇已收于mikechen原创超30万字《...

领域驱动设计(Domain-Driven Design)的关键概念

领域驱动设计(Domain-DrivenDesign,DDD)是一种软件开发方法,旨在通过深刻理解业务领域来构建复杂的系统。在DDD中,开发者与领域专家密切合作,共同定义业务逻辑,并通过模型表达领...

终于有人把安卓程序员必学知识点全整理出来了,有如醍醐灌顶

阅读前请点击右上角“关注”,每天免费获取Android知识解析及面试解答。Android架构解析,只做职场干货,完全免费分享!Java相关无论什么级别的Android从业者,Java作为Android...

[Android开发]使用观察者的正确姿势

前言首先先问一个问题,你在做Android开发的时候有没有被传值整的蒙圈?例如Fragment之间的传值,Activity之间的传值(ActivityForResult比较常用),Fragment与A...

大厂永恒敲门砖——Android 系统启动流程详解

...

Android音频开发:如何采集一帧音频

AndroidSDK提供了两套音频采集的API,分别是:MediaRecorder和AudioRecord,前者是一个更加上层一点的API,它可以直接把手机麦克风录入的音频数据进行编码压缩(如...

安卓手机怎么录屏?这三种方法你还不会用么?

手机录屏指的是使用手机的录屏功能,将屏幕上的内容进行录制,保存为视频文件,以供后续观看或分享。使用手机录屏功能,可以方便地将手机屏幕上的任何内容进行录制,无论是游戏操作、软件教程、视频播放等,只需要点...

网易视频云技术分享:Android 消息机制学习

Android消息机制大家都不陌生,想必大家也都看过Handler、Looper的源码(看过可以直接看末尾重点,一款监控APP卡顿情况的控件),下面,网易视频云技术专家就整合一下这方面的资料,加深对这...

2021年四大流行Android手机自动化测试工具,全在这里了

Android自动化测试的工具非常多,但是目前主流使用的就那几个,我会详细说明他们各自的情况,你可以根据自己的需要决定使用哪款工具。...

好程序员Android培训 122天炼成技术达人稳赚高薪

好程序员从课程研发到开班至今,历经一年的时间,专注Android和iOS开发高端人才培养,目前已经毕业的三期学员,从平均薪资的11000到三期的16000,薪资记录在行业内遥遥领先。面对如此“诱人”的...

娃哈哈基课堂第3课。安卓手机的盲人模式深度讲解

上一节课我们说了苹果手机的盲人模式如何设置?今天我们通过长文的方式来讲解安卓手机的盲人设置是如何设置的,所有的安卓手机盲人模式都是通用的,但是有一些手机因为优化系统的问题无法通用,或者有些手机直接把安...

android培训学习的大纲 android软件开发培训

第一阶段android基础:1.基础javaJava概述,进制,数据类型,常量变量,运算符,表达式关系运算符,逻辑运算符,if语句,switch语句while循环,do...while循环,for循环...

Android Jetpack从入门到精通(深度好文,值得收藏)

阅读前请点击右上角“关注”,每天免费获取Android知识解析及面试解答。Android架构解析,只做职场干货,完全免费分享!前言即学即用AndroidJetpack系列Blog的目的是通过学习An...

小技巧:安卓苹果都有!这份玩机的教程,我愿称为最强

从提起适老化这个概念到现在,能真正感受到的,可能只是App上的一个按钮。...