WebView加载本地html、js文件常见问题及解决办法

时间:2022-12-09 20:44:41

声明:基于android studio平台,php语言搭建服务器

目录:


一、JavaScript脚本语言没有反应

二、alert无法弹出

三、html页面之间不能跳转

四、屏幕缩放没有达到预期效果

五、使用$.ajax()跨域访问服务器的时候没反应

六、java跟JavaScript相互调用常见问题及解决办法

       1、Uncaught ReferenceError: functionName is not defined

       2、安全限制问题

一、JavaScript脚本语言没有反应


问题描述:

       webview加载本地html文件,html文件中常常包含很多js脚本代码,例如某个按钮的点击事件,但是js代码将不起作用;

解决办法:

       java代码在用webview加载html文件之前先对webview进行设置,让webview可以支持js代码:

WebSettings webSettings = webViMain.getSettings();
webSettings.setJavaScriptEnabled(true);

二、alert无法弹出


问题描述:

       webview加载本地html文件,html中的js文件包含alert弹出框代码,但是webview无法弹出alert;

解决办法:

       在java代码中添加下面这句:

webViMain.setWebChromeClient(new WebChromeClient() {});

三、html页面之间不能跳转


问题描述:

       webview加载本地html文件,想在html文件中实现跳转到另一个html文件(代码如下),html代码本身没问题,文件路径也是对的,但是跳转失败,显示文件不存在或被删除...

window.location.href="my_life.html";

解决办法:

       之所以不能实现html文件之间的跳转是因为上面那句跳转界面的代码只能在浏览器中才能被支持,可以为webview设置如下代码,相当于赋予webview代理浏览器的功能:

webViMain.setWebViewClient(new WebViewClient() {});

四、屏幕缩放没有达到预期效果


问题描述:

       webview加载本地html文件,html文件中是支持缩放的(代码如下),但是在手机运行程序的时候不支持缩放页面;

<meta name="viewport" content="width=device-width, initial-scale=1.0 user-scalable=yes">

解决办法:

       手机不能缩放是因为虽然html已经支持缩放了,但是webview仍然需要进行设置,让其支持html页面进行缩放:

WebSettings webSettings = webViMain.getSettings();
webSettings.setUseWideViewPort(true); //设置缩放后不会变形
webSettings.setBuiltInZoomControls(true); //设置可以缩放

五、使用$.ajax()跨域访问服务器的时候没反应


问题描述:

       webview加载本地html文件,html文件需要访问服务器(代码如下),代码本身没问题,但是访问失败,没有反应

$.ajax({
url: "http://suqhhhh.imwork.net:57037/App&Php_Dmo/login.php",
data: {
username: $("#username").val(),
password: $("#password").val(),
},
type: "POST",
timeout: 36000,
dataType: "text",
success: function(data, textStatus) {
if (data == "登录成功") {
window.location.href = "my_life.html"; //在原窗口加载新页面
//window.open("my_life.html"); //在新窗口加载新页面
} else {
alert(textStatus + ":" + data);
}
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
alert("error:" + textStatus);
}
});

解决办法:

       这里访问服务器涉及到跨域访问,需要在服务器代码添加header,让外部代码可以进行跨域访问,否则得不到访问权限:

<?php
// 指定允许其他域名访问
header('Access-Control-Allow-Origin:*');

六、java跟JavaScript相互调用常见问题及解决办法


1、Uncaught ReferenceError: functionName is not defined

问题描述:

       webview加载本地html文件,程序运行不起来,报错:

Uncaught ReferenceError: functionName is not defined...

解决办法:

       问题出现原因,网页的js代码没有加载完成,就调用了js方法。解决方法是在网页加载完成之后调用js方法:

webViMain.setWebViewClient(new WebViewClient() {
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
//在这里执行你想调用的js函数
}
});

2、安全限制问题

问题描述:

       如果只在4.2版本以上的机器出问题,那么就是系统处于安全限制的问题了。Android文档这样说的:

Caution: If you’ve set your targetSdkVersion to 17 or higher, you must add the @JavascriptInterface annotation to any method that you want available your web page code (the method must also be public). If you do not provide the annotation, then the method will not accessible by your web page when running on Android 4.2 or higher.

       中文大意为:

警告:如果你的程序目标平台是17或者是更高,你必须要在暴露给网页可调用的方法(这个方法必须是公开的)加上@JavascriptInterface注释。如果你不这样做的话,在4.2以以后的平台上,网页无法访问到你的方法。

解决办法:

将targetSdkVersion设置成17或更高,引入@JavascriptInterface注释

待补充。。。

WebView加载本地html、js文件常见问题及解决办法的更多相关文章

  1. WebView加载本地Html文件并实现点击效果

    Webview是用来与前端交互的纽,可以加载本地Html文件,和网页并实现交互的功能. WebView通过WebSetting可以使用Android原生的JavascriptInterface来进行j ...

  2. webView 加载本地文件 - html&sol;htm pdf docx tx

    - (void)viewDidLoad { [super viewDidLoad]; [self setupUI]; NSString *path = [[NSBundle mainBundle] p ...

  3. iOS WebView 加载本地资源&lpar;图片,文件等&rpar;

    https://www.cnblogs.com/dhui69/p/5596917.html iOS WebView 加载本地资源(图片,文件等) NSString *path = [[NSBundle ...

  4. JQuery 加载 CSS、JS 文件

    JS 方式加载 CSS.JS 文件: //加载 css 文件 function includeCss(filename) { var head = document.getElementsByTagN ...

  5. 使用getScript&lpar;&rpar;方法异步加载并执行js文件

    使用getScript()方法异步加载并执行js文件 使用getScript()方法异步请求并执行服务器中的JavaScript格式的文件,它的调用格式如下所示: jQuery.getScript(u ...

  6. 转&colon;Android Webview 加载外部html时选择加载本地的js&comma;css等资源文件

    原文地址:http://m.blog.csdn.net/blog/qduningning/43196819 在使用WebView加载网页的时候,有一些固定的资源文件如js的jquery包,css,图片 ...

  7. Android WebView加载本地html并实现Java与JS交互

    最近做的一个项目中,用到自定义地图,将自定义地图转换成html页面,现在需要做的是如何将本地的html加载到android中,并可以实现交互. 相关讲解: 其实webview加载资源的速度并不慢,但是 ...

  8. 解决WebView加载本地文件乱码

    一.问题描述 这几天现场反馈一些问题,主要是文件浏览有部分文件显示乱码,像这样: 而文件本身又是用WebView加载的,出现有的文件正常有的文件不正常. 二.问题解决 webView 加载主要有:lo ...

  9. Swift - 网页控件(UIWebView)加载本地数据,文件

    使用UIWebView加载本地数据或资源有如下三种方式: 1,使用loadHTMLString方法加载HTML内容 2,使用loadRequest方法加载本地资源(也可用于加载服务器资源) 3,先将内 ...

随机推荐

  1. Linux 程序启停脚本

    start.sh #!/bin/sh java -jar ./program.jar & echo $! > /var/run/program.pid stop.sh #!/bin/sh ...

  2. poj 3185 The Water Bowls 高斯消元枚举变元

    题目链接 给一行0 1 的数, 翻转一个就会使他以及它左右两边的都变, 求最少多少次可以变成全0. 模板题. #include <iostream> #include <vector ...

  3. 1059&period; C语言竞赛

    C 语言竞赛是浙江大学计算机学院主持的一个欢乐的竞赛.既然竞赛主旨是为了好玩,颁奖规则也就制定得很滑稽: 冠军将赢得一份"神秘大奖"(比如很巨大的一本学生研究论文集--). 排名为 ...

  4. netty入门demo(一)

    目录 前言 正文 代码部分 服务端 客服端 测试结果一: 解决粘包,拆包的问题 总结 前言 最近做一个项目: 大概需求: 多个温度传感器不断向java服务发送温度数据,该传感器采用socket发送数据 ...

  5. &period;6-浅析express源码之Router模块&lpar;2&rpar;-router&period;use

    这一节继续深入Router模块,首先从最常用的use开始. router.use 方法源码如下: proto.use = function use(fn) { var offset = 0; var ...

  6. 本文将详细介绍oracle 10g OEM常规错误

    本文将详细介绍oracle 10g OEM常规错误-------Unknown host specified解决方法,需要了解的朋友可以参考下 详细出处参考:http://www.jb51.net/a ...

  7. 关于jsp页面中时间显示问题

    首先说明一下情况,在MySQL数据库中获取的时间显示在jsp页面中不是按指定格式显示,显示的是类似于这种--Tue Jun 18 00:00:00 CST 2013.而想要的仅仅是年月日而已. 对于这 ...

  8. ssh软件及命令的使用

    常用软件安装及使用目录 第1章 ssh常用用法小结 1.1 连接到远程主机: 命令格式 : ssh name@remoteserver 或者 ssh remoteserver -l name 说明:以 ...

  9. Make a Crystal UVA - 11014 (容斥定理)

    题意:给定一个NxNxN的正方体,求出最多能选几个整数点,使得任意两点PQ不会使PQO共线. 思路:利用容斥原理,设f(k)为点(x, y, z)三点都为k的倍数的点的个数(要扣掉一个原点O),那么所 ...

  10. 使用nginx反向代理时,如何正确获取到用户的真实ip

    在记录日志的的时候,获取用户的信息,比如用户的ip,浏览器等等信息是十分重要的. 但是在使用nginx反向代理的时候,可能经过转发无法获取到用户的真实的ip, 在此情况下需要配置nginx,让其在转发 ...