栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

Android与JS之间跨平台异步调用实例详解

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Android与JS之间跨平台异步调用实例详解

Android与JS之间跨平台异步调用

 为什么突然要搞这个问题呢?

   在开发浏览器的时候遇到这个狗血的问题,花了将近1天的时间才想到这个解决方案,Android与JavaScirpt互调。

  因为接口是抓取的别人的,所以出现了JS跨域问题,Android闪亮登场搞定了。

 GIF动画演示

  

  WebView相关设置

WebSettings mWebSettings = getSettings();
mWebSettings.setDefaultTextEncodingName("UTF-8");//设置默认的显示编码

mWebSettings.setJavascriptEnabled(true);//调用JS方法.安卓版本大于17,加上注解 @JavascriptInterface



 直接放大招->贴代码

 Android

addJavascriptInterface(new Object() {
      @JavascriptInterface
      public void toastMessage(final String url, final int type, final int dir) {
 L.e("url = " + url + " type = " + type + " dir = " + dir);
 APIWrapper.getInstance()
     .getLenovoWord(url)
     .subscribeOn(Schedulers.io())
     .observeOn(AndroidSchedulers.mainThread())
     .subscribe(new RxSubscriber() {
@Override
public void _onNext(ResponseBody responseBody) {
  try {
    String data = responseBody.string();
    L.e("data = " + data);
    loadUrl("javascript:ResCompleted(" + data + "," + type + "," + dir + ")");
  } catch (IOException e) {
    e.printStackTrace();
  }
}

@Override
public void _onError(String msg) {
  loadUrl("javascript:ResCompleted(" + msg + ")");
}
     });
      }
    }, "Android");

 Html





  Js调用Android代码
  
    #button-call{
    width: 100%;
    padding: 20px;
    font-size: 20px;
    }
    #div_bg{
    background: #cccccc;
    margin-top: 50px;
    }
  
  







感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/160732.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号