网站首页 > 博客文章 正文
由于现如今H5的热门,做过不少与H5的交互工作了,现在总结一下。
初始化WebView
/**
* 初始化WebView
*/
private void initWebView() { // 设置setWebChromeClient对象
mWb_main.setWebChromeClient(new WebChromeClient() { @Override
public void onReceivedTitle(WebView view, String title) { super.onReceivedTitle(view, title); //设置本地的ToolBar标题
mTv_main.setText(title);
}
}); //打开网页时不调用系统浏览器, 而是在本WebView中显示
mWb_main.setWebViewClient(new WebViewClient() { @Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url); return true;
}
});
WebSettings webSettings = mWb_main.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setDefaultTextEncodingName("UTF-8");//设置编码
webSettings.setUseWideViewPort(true);//设置此属性,可任意比例缩放webSettings.setLoadWithOverviewMode(true);
}
Android 调用JS的无参数方法
在HTML5中的header中加入这段代码
<script>
//这是被Android调用的JS方法function noParamFunction() {document.getElementById("noparam_ta").style.fontSize =40+"px";
}</script>
然后在Android里边我们调用
/**
* Android 调用 JS代码
*/
mButton.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View v) {
mWb_main.loadUrl("javascript:noParamFunction();");
}
});
Android 调用JS的有参数方法
在HTML5中的header中加入这段代码
<script>
//这是被Android调用的JS方法function noParamFunction() {
document.getElementById("noparam_ta").innerHTML=data;
}</script>
然后在Android里边我们调用的时候需要加入‘”+str+”’ 这种形式的,才可以想HTML传递参数
/**
* Android 调用 JS代码
*/
String str = "Hello JS"
mButton.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View v) {
mWb_main.loadUrl("javascript:noParamFunction('"+str+"');");
}
});
JS调用Android 代码
首先我们要定义一个类供JS调用,这里需要注意在4.2以前,不需要在方法前加上 @JavascriptInterface,4.2以后的系统就需要加上了,代码如下
public class JavaScriptinterface {
private Context mContext; /** Instantiate the interface and set the context */
public JavaScriptinterface(Context c) {
mContext = c;
}/**
* 安卓系统4.2以上的系统需要加上 @JavascriptInterface,才可以让webview读取自己的方法
* @param toast
*/
@JavascriptInterface
public void showToast(String toast) {
Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
Log.e("----","--------------------------------------------showToast");
}
}
然后在HTML中header里边加入script代码
<script>
//这是js调用Android的方法
function showAndroidToast(str) {
javascript:window.android.showToast(str);
}</script>
在Body标签加入
<input type="button" value="调用安卓的方法" onClick="showAndroidToast('调用成功')" />
然后在我们Android 端写入如下代码就可以调用了
/**
* JS 调用 Android 代码
*/
mWb_main.addJavascriptInterface(new JavaScriptinterface(this), "android");1234512345
Android读取html的标题
// 设置setWebChromeClient对象
mWb_main.setWebChromeClient(new WebChromeClient() { @Override
public void onReceivedTitle(WebView view, String title) { super.onReceivedTitle(view, title); //设置本地的ToolBar标题
mTv_main.setText(title);
}
});
Android允许Html的Alert()对话框
// 设置setWebChromeClient对象
mWb_main.setWebChromeClient(new WebChromeClient() { //处理javascript中的alertpublic boolean onJsAlert(WebView view, String url, String message, final JsResult result) { //构建一个Builder来显示网页中的对话框
AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);
builder.setTitle("Alert");
builder.setMessage(message);
builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener() { public void onClick(DialogInterface dialog, int which) {
result.confirm();
}
});
builder.setCancelable(false);
builder.create();
builder.show(); return true;
} //处理javascript中的confirm
public boolean onJsConfirm(WebView view, String url, String message, final JsResult result) {
AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);
builder.setTitle("confirm");
builder.setMessage(message);
builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener() { public void onClick(DialogInterface dialog, int which) {
result.confirm();
}
});
builder.setNegativeButton(android.R.string.cancel, new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int which) {
result.cancel();
}
});
builder.setCancelable(false);
builder.create();
builder.show(); return true;
}
});
猜你喜欢
- 2025-04-26 微信小程序Webview上传图片闪退
- 2025-04-26 获取当前webview的URL(Uniapp必会)
- 2025-04-26 Android WebView远程执行代码漏洞浅析
- 2025-04-26 通过分享的链接无法打开app?
- 2025-04-26 您使用的App是用什么技术开发
- 2025-04-26 SpringBoot系列——基于mui的H5套壳APP开发web框架
- 2025-04-26 2个将HTML5打包成app的方法
- 2025-04-26 苹果,自家后院着火了
- 2025-04-26 为什么你做的H5开屏那么慢?H5首屏秒开方案探讨
- 2025-04-26 openinstall:微信小程序跳转H5,配置业务域名教程
你 发表评论:
欢迎- 369℃手把手教程「JavaWeb」优雅的SpringMvc+Mybatis整合之路
- 368℃用AI Agent治理微服务的复杂性问题|QCon
- 359℃初次使用IntelliJ IDEA新建Maven项目
- 352℃Maven技术方案最全手册(mavena)
- 349℃安利Touch Bar 专属应用,让闲置的Touch Bar活跃起来!
- 348℃InfoQ 2024 年趋势报告:架构篇(infoq+2024+年趋势报告:架构篇分析)
- 346℃IntelliJ IDEA 2018版本和2022版本创建 Maven 项目对比
- 344℃从头搭建 IntelliJ IDEA 环境(intellij idea建包)
- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)