写的有点乱,如果有看到不懂的地方可以密我。
一些关键的地方用了颜色标记。。。
android端
java代码:
webView = (WebView) this.findViewById(R.id.webview);
WebSettings
ws = webView.getSettings();
ws .setJavaScriptEnabled(true);
ws .setDefaultTextEncodingName("UTF-8");
webView.setClickable(true);
ws.setUseWideViewPort(true);
webView.setInitialScale((int) 0.1);
ws.setSupportZoom(true);
ws.setBuiltInZoomControls(true);
ws.setDefaultZoom(ZoomDensity.FAR);
webView.getSettings().setUseWideViewPort(true);
webView.getSettings().setLoadWithOverviewMode(true);
webView.addJavascriptInterface(new LoadHtml(), "loadHtml"); // loadHtml 类用于给js调用java代码
webView.loadData(createWebForm(flowFormHtml), "text/html", "UTF-8"); // flowFormHtml是服务器端发回来的动态表单信息。
webView.setWebChromeClient(new MyWebClient());
//java调用js代码: webView.loadUrl("javascript:函数名(参数)");
protected final class LoadHtml {
public void returnValue(final String htmls) {
handler.post(new Runnable() {
public void run() {
// 这里判断htmls的值,然后显示告诉用户提交状态。
}
});
}
}
//
createWebForm 函数把flowFormHtml包装到html表单中,然后提交到服务器
html代码:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
<script type="text/javascript" >
function submit(){ //供java端调用,提交表单信息
document.getElementById(\"js_form\").submit();
}
fcunction setAaaaaValue(val){ //设置隐藏的非表单的信息
document.getElementById(“aaaaa”).value =val;
}
</script>
</head>
<body>
<form method="post" id="js_form" enctype="multipart/form-data" action="*******">
<input id ="aaaaa" style="display:none" /> //隐藏用于添加一些非表单信息
flowFormHtml //服务器端返回的数据
</form>
</body>
</html>
php端的返回值:
<script
type='text/javascript'>window.loadHtml.returnValue('{$returnState['state']}');</script> //会调用android端returnVlaue函数
php android
boolean true 1
boolean false ""
String true/false true/false
1:如果直接用返回boolean类型,android这端(用字符串接受)接受的结果会为
分享到:
相关推荐
qtwebview-everywhere-src-5.15.0
qtwebview-everywhere-src-5.15.0.tar
3D WebView-Windows-macOS-Web Browser 4.2.unitypackage.zip
Android8.0以下手机自带的android-system-webview版本过低使用
react-native-web-webview React Native用于RN的WebView的Web实现 入门 $ npm install react-native-web-webview --save 别名打包您的webpack配置中: resolve: { alias: { 'react-native': 'react-native-web...
安全架构 Android_WebView安全攻防指南2020 - 系统安全 勒索软件 终端安全 安全漏洞 安全管理
Unity实现内嵌网页插件,支持3d模式 包含2个插件, 3D_WebView_For_iOS_Android4.2.2和3D_WebView_For_Mac_Windows4.2
(16)2020.8.9 一步一步搭建可扩展高可靠的Android Webview模块(上)-Allen老师.rar
unity-webview-integration-master unity-webview-integration-master unity-webview-integration-master
react-native-webview.zip
Android 中不在用webview的情况下 执行js代码并得到返回值
解决React-Native的WebView不支持Android选择图片和拍照
安卓java获取webview源码 :warning: :warning: :warning: [ 已弃用 ] :warning: :warning: :warning: :backhand_index_pointing_right: 请使用由 React Native 社区维护的 。 React Native Android WebView 文件上传...
浏览器 关于webview--android android webview 浏览器 浏览器 关于webview--android android webview 浏览器
主要介绍了android webview中使用Java调用JavaScript方法并获取返回值,本文直接给出代码示例,需要的朋友可以参考下
react-native-webview-comlink react-native-webview-comlink的目标是将与React Native WebView组件集成在一起,允许Web浏览器中的js调用本地API。 安装 安装软件包和Comlink : npm i --save react-native-webview...
Webview侧滑菜单+父子页面切换!支持点击按钮开启侧滑菜单以及拖动打开和关闭。效果需要H5+支持,请下载hbuilder或自己打包成app查看,有问题可以私信
语言:العربية 向托管WebView的应用程序提供内容脚本。 WebView扩展通信:扩展简单代码
uniapp 使用webView通讯