android原生和h5交互

本文介绍了如何在Android原生应用中嵌入H5页面,包括加载H5、启用JavaScript、处理点击事件、数据传递以及交互方法。通过设置WebChromeClient和WebViewClient,实现了H5与原生页面的跳转和通信。还详细讲解了如何处理H5中的a链接,以及使用addJavascriptInterface进行Java和JS的双向交互。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一:非集成,组件嵌套h5页面
(1)layout在页面添加webview组件;
(2) webView.loadUrl(“file:///android_asset/apps/oneapp/www/plus/nativeui.html”);//载入h5页面
(3)直接载入的h5**,js失效**需要原生开放权限
webView.getSettings().setJavaScriptEnabled(true);
webView.getSettings().setJavaScriptEnabled(true);
webView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);
因为某些不知道都原因,即使加了以上代码,js里面的alert依然不能被调用:
webView.setWebChromeClient(new WebChromeClient()); //js弹出框载体
(4)h5页面的a链接也会失效:
///激活h5页面的a链接////
webView.setWebViewClient(new WebViewClient(){
@SuppressLint(“MissingPermission”)
@Override
public boolean shouldOverrideUrlLoading
(WebView view, String url) {
Log.i(“用户单击超连接”, url);
//判断用户单击的是那个超连接
String tag=“tada:tel”;
if (url.contains(tag))
{
String mobile=url.substring(url.lastIndexOf("/")+1);
Uri uri=Uri.parse(“tel:”+mobile);
Intent intent=new Intent(Intent.ACTION_CALL,uri);
startActivity(in

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值