android开发中经常使用WebView来加载网页,难免遇到Java与JavaScript的相互调用,记录下来,以便今后查阅。
Java调用JavaScript方法
这个很简单,只需一句代码:
webView.loadUrl("javascript:bb('这是Java调用JavaScript的结果')");
- 1
bb是html中的JavaScript的方法名,括号是参数。
JavaScript调用Java方法
webView.addJavascriptInterface(this, "obj");
- 1
在该Activity中添加一个方法供JavaScript调用:
@JavascriptInterface
public String cc(){
return "这是Java代码返回的结果";
}
- 1
注意,`必须得有@JavascriptInterface注解加在方法的前面,否则,不起作用。
然后就可以在JavaScript中调用该Java方法了:
window.obj.cc()
- 1
该方法将会返回Java中cc()方法的返回值。
说明:webView.addJavascriptInterface()方法有两个参数,第一个参数是一个类实例,该类里面提供我们要提供给javascript访问的方法;第二个参数是访问我们在类中声明的方法时候所用到的js对象,调用模式为window.obj.方法名()。
下面给出全部的代码,便于大家动手操作:
index.html处于assets中:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<Meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>首页</title>
<script type="text/javascript" language="javascript">
function aa(){
alert(window.obj.cc())
}
function bb(text){
alert(text)
}
</script>
</head>
<body>
<button type="button" onclick="aa()">调用Java代码</button>
</body>
</html>
- 1
MainActivity.java就是主Activity文件了,大家都知道:
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.webkit.JavascriptInterface;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
public class MainActivity extends AppCompatActivity {
private WebView webView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
webView = (WebView)findViewById(R.id.webView);
WebSettings webSettings = webView.getSettings();
// 设置WebView属性,能够执行Javascript脚本
webSettings.setJavaScriptEnabled(true);
webView.setWebViewClient(new WebViewClient(){
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
webView.loadUrl("javascript:bb('这是Java调用JavaScript的结果')");
}
});
webView.setWebChromeClient(new WebChromeClient() {});
webView.loadUrl("file:///android_asset/index.html");
webView.addJavascriptInterface(this, "obj");
}
@JavascriptInterface
public String cc(){
return "这是Java代码返回的结果";
}
}
- 1
最后还有一个activity_main.xml布局文件也贴出来:
<?xml version="1.0" encoding="utf-8"?>
<WebView
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:id="@+id/webView"
tools:context="com.example.webapplication.MainActivity">
</WebView>
- 1
原文地址:https://www.jb51.cc/wenti/3286086.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。