WebViewとJavaScriptのインタラクション
7343 ワード
Html 5の台頭に伴い、現在人気のあるReact Native、Cordovaなどのフレームワークのように、Web ViewとJavaScriptのインタラクションに遭遇することは避けられません.
まずWebViewを構成します
1.Android呼び出しJavaScript無参メソッド
jsメソッド
Android呼び出しjsのsendMsgメソッド
JavaScriptのsendMsg関数をevaluateJavascriptメソッドで呼び出し、Jsがreturnで与えた文字列であるコールバック文字列を取得します.
残念ながら、この方法はAndroid API 19以上のバージョンでなければ使用できません.以下のバージョンを互換化するには、特殊な方法で処理しなければなりませんが、今日は以下のバージョンを互換化しません.現在はほとんど5.0以上のユーザーですから.
2.Android呼び出しJavaScriptにはメソッドがあります
jsメソッド
Androidメソッド
ここでAndroidはJsのgetAndroid Valueメソッドを呼び出し、jsに窓を弾かせる文字列パラメータを渡します.弾窓の内容は私たちが伝えたパラメータです
3.JavaScript Android非参照メソッドの呼び出し
jsコード
AndroidここにはJsのインターフェースがオープンしています
私たちはAndroid JSというクラスにいます.
4.JavaScriptがAndroidを呼び出す方法
Jsコード
AndroidがJsに露出する方法で、彼が与えた値を取得し、Toastが出てきます.
ヒント:
Android 5.0以下のバージョンJsの戻り値を取得するには、Jsメソッドを呼び出し、Jsにメソッドを呼び出して値を渡すことをお勧めします.
すべてのコード
testjs.html
Androidコード
まずWebViewを構成します
webview = (WebView) findViewById(R.id.webview);
webview.loadUrl("file:///android_asset/testjs.html");
findViewById(R.id.btn_call_js_no_params).setOnClickListener(this);
findViewById(R.id.btn_call_js_params).setOnClickListener(this);
settings = webview.getSettings();
settings.setJavaScriptEnabled(true);
settings.setJavaScriptCanOpenWindowsAutomatically(true);// JS
webview.setWebChromeClient(new WebChromeClient());
webview.addJavascriptInterface(new AndroidJs(), "JavaScriptObject");// Js ,Js
1.Android呼び出しJavaScript無参メソッド
jsメソッド
function sendMsg(){
return "Android Js ";
}
Android呼び出しjsのsendMsgメソッド
webview.evaluateJavascript("javascript:sendMsg()", new ValueCallback() {
@Override
public void onReceiveValue(String value) {
if (value != null) {
Toast.makeText(MainActivity.this, value, Toast.LENGTH_SHORT).show();
}
}
});
JavaScriptのsendMsg関数をevaluateJavascriptメソッドで呼び出し、Jsがreturnで与えた文字列であるコールバック文字列を取得します.
残念ながら、この方法はAndroid API 19以上のバージョンでなければ使用できません.以下のバージョンを互換化するには、特殊な方法で処理しなければなりませんが、今日は以下のバージョンを互換化しません.現在はほとんど5.0以上のユーザーですから.
2.Android呼び出しJavaScriptにはメソッドがあります
jsメソッド
function getAndroidValue(value){
alert(value);
}
Androidメソッド
String msg2Js = "Android Js";
webview.evaluateJavascript("javascript:getAndroidValue('" + msg2Js + "')", new ValueCallback() {
@Override
public void onReceiveValue(String value) {
}
});
ここでAndroidはJsのgetAndroid Valueメソッドを呼び出し、jsに窓を弾かせる文字列パラメータを渡します.弾窓の内容は私たちが伝えたパラメータです
3.JavaScript Android非参照メソッドの呼び出し
jsコード
function callAndroidNoParams(){
JavaScriptObject.noParams();
}
AndroidここにはJsのインターフェースがオープンしています
webview.addJavascriptInterface(new AndroidJs(), "JavaScriptObject");// Js ,Js
私たちはAndroid JSというクラスにいます.
class AndroidJs extends Object {
@JavascriptInterface
public void noParams() {
Toast.makeText(MainActivity.this, "Js Android ", Toast.LENGTH_SHORT).show();
}
}
4.JavaScriptがAndroidを呼び出す方法
Jsコード
function callAndroidParams(){
JavaScriptObject.paramsToast("js Android ");
}
AndroidがJsに露出する方法で、彼が与えた値を取得し、Toastが出てきます.
@JavascriptInterface
public void paramsToast(String content){
if (content!=null){
Toast.makeText(MainActivity.this, content, Toast.LENGTH_SHORT).show();
}
}
ヒント:
Android 5.0以下のバージョンJsの戻り値を取得するには、Jsメソッドを呼び出し、Jsにメソッドを呼び出して値を渡すことをお勧めします.
すべてのコード
testjs.html
Android JavaScript
function sendMsg(){
return "Android Js ";
}
function getAndroidValue(value){
alert(value);
}
function callAndroidNoParams(){
JavaScriptObject.noParams();
}
function callAndroidParams(){
JavaScriptObject.paramsToast("js Android ");
}
Hello World!!!
Androidコード
package com.wj.jsjavademo;
import android.os.Build;
import android.os.Bundle;
import android.support.annotation.RequiresApi;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.webkit.JavascriptInterface;
import android.webkit.ValueCallback;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.Toast;
@RequiresApi(api = Build.VERSION_CODES.KITKAT)
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private WebView webview;
private WebSettings settings;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initWebView();
}
private void initWebView() {
webview = (WebView) findViewById(R.id.webview);
webview.loadUrl("file:///android_asset/testjs.html");
findViewById(R.id.btn_call_js_no_params).setOnClickListener(this);
findViewById(R.id.btn_call_js_params).setOnClickListener(this);
settings = webview.getSettings();
settings.setJavaScriptEnabled(true);
settings.setJavaScriptCanOpenWindowsAutomatically(true);// JS
webview.setWebChromeClient(new WebChromeClient());
webview.addJavascriptInterface(new AndroidJs(), "JavaScriptObject");// Js ,Js
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.btn_call_js_no_params:
webview.evaluateJavascript("javascript:sendMsg()", new ValueCallback() {
@Override
public void onReceiveValue(String value) {
if (value != null) {
Toast.makeText(MainActivity.this, value, Toast.LENGTH_SHORT).show();
}
}
});
break;
case R.id.btn_call_js_params:
String msg2Js = "Android Js";
webview.evaluateJavascript("javascript:getAndroidValue('" + msg2Js + "')", new ValueCallback() {
@Override
public void onReceiveValue(String value) {
}
});
break;
}
}
class AndroidJs extends Object {
@JavascriptInterface
public void noParams() {
Toast.makeText(MainActivity.this, "Js Android ", Toast.LENGTH_SHORT).show();
}
@JavascriptInterface
public void paramsToast(String content){
if (content!=null){
Toast.makeText(MainActivity.this, content, Toast.LENGTH_SHORT).show();
}
}
}
}