小编给大家分享一下JavaScript如何实现交互的示例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
示例:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Carson</title>
<script>
function callAndroid(){
test.hello("js调用了android中的hello方法");
}
function returnResult(){
alert("result is");
}
</script>
</head>
<body>
<button type="button" id="button1" onclick="callAndroid()"> 调用安卓代码 </button>
</body>
</html>
package com.example.webjs;
import android.annotation.SuppressLint;
import android.content.DialogInterface;
import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.webkit.JavascriptInterface;
import android.webkit.JsResult;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.Button;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
Button tojs;
WebView webView;
@SuppressLint("JavascriptInterface")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
webView = findViewById(R.id.web_id);
tojs = findViewById(R.id.calljs_but_id);
WebSettings webSettings = webView.getSettings();
// 设置与Js交互的权限
webSettings.setJavaScriptEnabled(true);
// 设置允许JS弹窗
webSettings.setJavaScriptCanOpenWindowsAutomatically(true);
//设置对象映射
webView.addJavascriptInterface(new JsToAndroid() , "test");
// 先载入JS代码
// 格式规定为:file:///android_asset/文件名.html
webView.loadUrl("file:///android_asset/text.html");
alteView(webView);
tojs.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String result = "你好";
// webView.loadUrl("javascript:returnResult(" + result + ")");
webView.loadUrl("javascript:returnResult()");
}
});
}
public class JsToAndroid{
@JavascriptInterface
public void hello(final String str ){
runOnUiThread(new Runnable() {
@Override
public void run() {
Toast.makeText(MainActivity.this , str , Toast.LENGTH_LONG).show();
}
});
}
}
public void alteView(WebView webView){
// webView.setWebChromeClient(new WebChromeClient());
webView.setWebChromeClient(new WebChromeClient(){
@Override
public boolean onJsAlert(WebView view, String url, String message, final JsResult result) {
Log.e("tag" ,"执行次数");
AlertDialog.Builder b = new AlertDialog.Builder(MainActivity.this);
b.setTitle("Alert");
b.setMessage(message);
b.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
result.confirm();
}
});
b.setCancelable(false);
// b.create().show();
return super.onJsAlert(view, url, message, result);
}
});
}
}
以上是“JavaScript如何实现交互的示例”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。