Android JS与原生交互,JS交互 ,JSBridge的使用方法

像我们在开发App的过程中难免会遇到App与前端H5的交互,那么我们就会碰到webView这样的控件,但是与前端JS交互起来会感觉到很繁琐,那么,我今天在这里发表一篇文章就是给你们解决原生的webView交互繁琐的问题。话不多说,直接开始吧:

简单介绍一下JSBridge:

它在Java和JavaScript之间架起了一座桥梁。
它提供了从js调用Java代码并从java调用js代码的安全方便的方法。
它是继承系统的webView所开发的一个库,使用起来其实跟系统的webView是一样的。

使用方法:

1.依赖

repositories {
    maven { url "https://jitpack.io" }
}
dependencies {
    implementation 'com.github.lzyzsd:jsbridge:1.0.4'
}

2.在你的res/layout/xxx.xml 里面构建你的BridgeWeb控件

<com.github.lzyzsd.jsbridge.BridgeWebView
        android:id="@+id/bridge_webView"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    </com.github.lzyzsd.jsbridge.BridgeWebView>

3.在Activity.java文件里创建代码

public class BridgeWebActivity extends AppCompatActivity {
     private BridgeWebView webView;
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
           super.onCreate(savedInstanceState);
           initView();
    }

    private void initView() {
          webView = findViewById(R.id.bridge_webView);
          
         //这里是关于web的一些配置
          configWebViewSettings();
         
          //***************************特别注意***********************
          //webView.setWebViewClient(...)这个方法一定不能写成new WebViewClient 
          //详细的问题请看步骤 4
          webView.setWebViewClient(new MyWebViewClient(webView){
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                return super.shouldOverrideUrlLoading(view, url);
            }

            @Override
            public void onPageStarted(WebView view, String url, Bitmap favicon) {
               //do you work
                super.onPageStarted(view, url, favicon);
            }

            @Override
            public void onPageFinished(WebView view, String url) {
                //do you work
                super.onPageFinished(view, url);
            }
        });
         webView.loadUrl("你的网址");
    }

    private void configWebViewSettings()  {
           //关于bridgeWeb的一些设置,我这里是根据一般的配置写的(可以根据你们的项目需求去修改)
           //上面介绍的时候已经说到bridgeWeb是继承自WebView的,所以webSetting可以自由的发挥了
          WebSettings webSettings = webView.getSettings();
          webSettings.setJavaScriptEnabled(true);//允许执行JS
          webSettings.setUseWideViewPort(true);
          webSettings.setLoadWithOverviewMode(true);
          webSettings.setAllowFileAccess(true); // 允许访问文件
          webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NARROW_COLUMNS);
          webSettings.setJavaScriptCanOpenWindowsAutomatically(true);//设置JS可以打开新的窗口
          webSettings.setLoadsImagesAutomatically(true);//支持自动加载图片
          webSettings.setTextZoom(100);
          webSettings.setSupportZoom(true);//支持缩放
          webSettings.setBuiltInZoomControls(true);//设置内置的缩放控件
          webSettings.setRenderPriority(WebSettings.RenderPriority.HIGH);//高性能渲染JS
          webSettings.setDefaultTextEncodingName("utf-8");//设置编码格式
          webSettings.setDomStorageEnabled(true);// 开启 DOM storage API 功能
          webSettings.setDatabaseEnabled(true);//开启 database storage API 功能
    }
    
}

4.我们自己创建一个MyWebViewClient类 继承自 BridgeWebViewClient ,然后在我们的Activity里面去调用它。
*如果我们直接使用WebView的WebViewClient,会导致java调用JS或者,JS调用java方法失效;
因此我们这样去做:

 public class MyWebViewClient extends BridgeWebViewClient {
    public MyWebViewClient(BridgeWebView webView) {
        super(webView);
    }

    @Override
    public boolean shouldOverrideUrlLoading(WebView view, String url) {
        return super.shouldOverrideUrlLoading(view, url);
    }

    @Override
    public void onPageStarted(WebView view, String url, Bitmap favicon) {
        super.onPageStarted(view, url, favicon);
    }

    @Override
    public void onPageFinished(WebView view, String url) {
        super.onPageFinished(view, url);
    }
}

5.JS调用java
在Java代码里注册一个方法:

        webView.registerHandler("showAndroidToast", new BridgeHandler() {
            @Override
            public void handler(String data, CallBackFunction function) {
                  //do you work 
                  /**
                     data :  JS端传递过来的参数
                      function: 这个方法可以是告诉js ,方法已经被调用了
                  */
                 Toast.makeText(BridgeWebActivity.this, "被JS函数调用啦" + data, Toast.LENGTH_SHORT).show();
            }
        });

在JS里面写入代码:

WebViewJavascriptBridge.callHandler(
        'showAndroidToast'
        , {'param':'调用java代码块!'}
        , function(responseData) {
            //这里是调用成功的回调方法
            //responseData 是java端返回的参数
        }
    );

6.Java调用JS
在JS里面注册一个方法供Java调用

 WebViewJavascriptBridge.registerHandler("functionInJs", function(data, responseCallback) {
        //do you work
        
       //responseCallback 这个方法可以告诉java 自己被调用了
        responseCallback('我被调用啦');
    });

在java里面写入调用js的代码

 webView.callHandler("functionInJs", "传到js的参数", new CallBackFunction() {
            @Override
            public void onCallBack(String data) {
            
                  //data : 是JS那边告诉java ,JS被调用成功啦
          
                Log.i(TAG, "onCallBack: " + data);
            }
        });

好啦!以上就是JSBridge的基本使用方法了,如果有什么问题或者错误的地方请在下方留言。谢谢!
JSBridge:https://github.com/lzyzsd/JsBridge

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,717评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,501评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,311评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,417评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,500评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,538评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,557评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,310评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,759评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,065评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,233评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,909评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,548评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,172评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,420评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,103评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,098评论 2 352

推荐阅读更多精彩内容

  • 链接:https://www.jianshu.com/p/fd61e8f4049e 一、简介 这部分主要介绍下 W...
    柒黍阅读 1,805评论 0 4
  • 随着H5性能的提升,在我们移动应用开发的过程中,我们会越来越多的在我们的App页面内嵌入H5页面,使得App变的更...
    Jensen95阅读 4,201评论 0 21
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,383评论 0 17
  • WebView·开车指南 2016-08-31BugDev 北京市东城区首席Bug布道师开山之作,一整月交通事故血...
    53c021c38a1d阅读 828评论 0 1
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,094评论 1 32