android 原生调用js,js调用原生

本文介绍了一种实现JavaScript与原生应用交互的方法,包括从原生调用JavaScript方法并传递参数,以及如何在JavaScript中调用原生方法来启动新的活动。通过具体的代码示例展示了创建JS接口类,并在WebView中添加该接口以实现双向通信的过程。

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

 原生调用js方法,带参数

activityBaseWebAddWebView.loadUrl("javascript:changeColor('" + viewColor + "')");//changeColor是js方法,viewColor是参数

js调用原生

 

1、创建js通信接口
 

    //js通信接口
    class JavascriptInterface {
        private Context context;

        JavascriptInterface(Context context) {
            this.context = context;
        }

        @android.webkit.JavascriptInterface
        public void openImage(String imageUrls, String img) {
            Intent intent = new Intent();
            intent.putExtra("imageUrls", imageUrls);
            intent.putExtra("curImageUrl", img);
            intent.setClass(GreetingCardWebActivity.this, PhotoBrowserActivity.class);
            startActivity(intent);
        }

        @android.webkit.JavascriptInterface
        public void toLogin() {
            startActivity(new Intent(getApplicationContext(), LoginActivity.class));
        }
        @android.webkit.JavascriptInterface
        public void toCompanyDetail(int epId, String accessPath) {
//            window.yxbl_app.toCompanyDetail()  //js调用android源码方法
            Intent intent = new Intent(GreetingCardWebActivity.this, CompanyDetailWebActivity.class);
            intent.putExtra("epId", epId);
            intent.putExtra("accessPath", accessPath);
            startActivity(intent);
        }
        @android.webkit.JavascriptInterface
        public void getGreetingCardProc(String title, String imgUrl, String content, String url) {
            mtitle = title;
            mlogo = imgUrl;
            mcontent = content;
            mshareUrl = url;
            mTitleText.setText(mtitle);
        }


    }
 

2、webview添加js通信接口

 

webView.addJavascriptInterface(new JavascriptInterface(this), "yxbl_app");

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值