webView.getSettings().setJavaScriptEnabled(true);//打开就可以用js的功能

 

webView.getSettings().setJavaScriptEnabled(true);//打开就可以用js的功能

Js代码,放在asset文件夹下,也可以在服务器端,这样改变内容,只需改服务器端,客户端不用修改

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>Insert title here</title>

<script type="text/javascript">

function btn_test() {

/* 打印,logcat里的tag是Web Console */

console.log("btn_test");

}

function call_java() {

/* js调用java代码,需要接口 */

Window.interface_test.showToastFromWeb("hello i am javascript!");

}

function test_alert() {

/* 弹出对话框 */

alert("hello i am javascript!");

}

function test_confirm() {

/* 弹出带确定和取消按钮的对话框 */

var v = confirm("hello i am javascript!");

console.log("onfirm " + v);

}

function test_prompt() {

/* 弹出带输入框的对话框 */

var v = prompt("input you name!", "tom");

console.log("prompt " + v);

}

</script>

</head>

<body>

<button onclick="btn_test()">test</button>

<button onclick="call_java()">call_java</button>

<button onclick="test_alert()">test_alert</button>

<button onclick="test_confirm()">test_confirm</button>

<button onclick="test_prompt()">test_prompt</button>

<label tel:800800284>tel:8008233</label>

</body>

</html>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>Insert title here</title>

<script type="text/javascript">

function btn_test() {

/* 打印,logcat里的tag是Web Console */

console.log("btn_test");

}

function call_java() {

/* js调用java代码,需要接口 */

Window.interface_test.showToastFromWeb("hello i am javascript!");

}

function test_alert() {

/* 弹出对话框 */

alert("hello i am javascript!");

}

function test_confirm() {

/* 弹出带确定和取消按钮的对话框 */

var v = confirm("hello i am javascript!");

console.log("onfirm " + v);

}

function test_prompt() {

/* 弹出带输入框的对话框 */

var v = prompt("input you name!", "tom");

console.log("prompt " + v);

}

</script>

</head>

<body>

<button onclick="btn_test()">test</button>

<button onclick="call_java()">call_java</button>

<button onclick="test_alert()">test_alert</button>

<button onclick="test_confirm()">test_confirm</button>

<button onclick="test_prompt()">test_prompt</button>

<label tel:800800284>tel:8008233</label>

</body>

</html>

Java代码里

webView.addJavascriptInterface(new Object(){

public void showToastFromWeb(String msg){

showToast(msg);

}

}, "interface_test");

webView.addJavascriptInterface(new Object(){

public void showToastFromWeb(String msg){

showToast(msg);

}

}, "interface_test");

webView.setWebChromeClient(new WebChromeClient(){

@Override

public void onProgressChanged(WebView view, int newProgress) {

//这里上一博文已提过

}

@Override

public boolean onJsAlert(WebView view, String url, String message,

JsResult result) {

// TODO Auto-generated method stub

return super.onJsAlert(view, url, message, result);

}

@Override

public boolean onJsConfirm(WebView view, String url,

String message, JsResult result) {

// TODO Auto-generated method stub

return super.onJsConfirm(view, url, message, result);

}

@Override

public boolean onJsPrompt(WebView view, String url, String message,

String defaultValue, JsPromptResult result) {

// TODO Auto-generated method stub

return super.onJsPrompt(view, url, message, defaultValue, result);

}

});

webView.setWebChromeClient(new WebChromeClient(){

@Override

public void onProgressChanged(WebView view, int newProgress) {

//这里上一博文已提过

}

@Override

public boolean onJsAlert(WebView view, String url, String message,

JsResult result) {

// TODO Auto-generated method stub

return super.onJsAlert(view, url, message, result);

}

@Override

public boolean onJsConfirm(WebView view, String url,

String message, JsResult result) {

// TODO Auto-generated method stub

return super.onJsConfirm(view, url, message, result);

}

@Override

public boolean onJsPrompt(WebView view, String url, String message,

String defaultValue, JsPromptResult result) {

// TODO Auto-generated method stub

return super.onJsPrompt(view, url, message, defaultValue, result);

}

});

// webView.loadUrl("javascript:btn_test()");

webView.loadUrl("file:///android_asset/test.html");

 

//          webView.loadUrl("javascript:btn_test()");

webView.loadUrl("file:///android_asset/test.html");

效果图

android webview与 java与javascript的交互的更多相关文章

  1. WebView中Java与JavaScript的交互

    原文首发于微信公众号:jzman-blog,欢迎关注交流! Android 开发过程中 WebView 的使用比较广泛,常用来加载网页,比如使用 WebView 加载新闻页面.使用 WebView 打 ...

  2. Android WebView 总结 —— Java和JavaScript交互

    交互如何实现 实现Java和js交互十分便捷.通常只需要以下几步. WebView开启JavaScript脚本执行 WebView设置供JavaScript调用的交互接口. 客户端和网页端编写调用对方 ...

  3. Android中Java与JavaScript之间交互(转)

    Android代码: package com.fyfeng.testjavascript; import android.app.Activity; import android.content.In ...

  4. 让Java和JavaScript进行交互

    本篇博文参考自:http://droidyue.com/blog/2014/09/20/interaction-between-java-and-javascript-in-android/ 我们在使 ...

  5. Android WebView 开发教程

    声明在先:必须在AndroidMainfest.xml 里面声明权限,否则在Java里面编写的所有WebView浏览网页的代码都无法正常使用 <uses-permission android:n ...

  6. Android WebView 加载超长 JS 数据

    在之前的文章里面,我总结过WebView如何与网页交互,也就是Java如何和JS交互 —— Android WebView 总结 —— Java和JavaScript交互. 基于这篇文章,我们基本上能 ...

  7. Android与javaScript的交互

    WebView与js的交互包含两方面,一是在html中通过js调用java代码:二是在安卓java代码中调用js. 一.html中通过js调用java代码 js中调用java代码其实就记住一点,Web ...

  8. WebView上实现Java与JavaScript交互

    在安卓开发上,考虑到开发效率和界面更新,有时使用WebView结合web页面技术,可以快速迭代地开发移动应用.WebView加载资源的速度并不慢,但是如果资源多了,就很慢.图片.css.js.html ...

  9. Android WebView与JavaScript交互操作(Demo)

    应用场景: 为了使Android移动项目能够在较短的时间内完成开发,同时降低技术人员开发的成本投入,往往会采用Hybrid APP的开发模式.相关Hybrid APP(混合型应用)参看:http:// ...

随机推荐

  1. 安装 RPM 包或者安装源码包

    安装 RPM 包或者安装源码包 在windows下安装一个软件很轻松,只要双击.exe的文件,安装提示连续“下一步”即可,然而linux系统下安装一个软件似乎并不那么轻松了,因为我们不是在图形界面下. ...

  2. yum只下载而不安装软件包?

    yum本身自带了两个选项, 用来只下载要安装的rpm包, 而并不实际安装包: yum --downloadonly --downloaddir=/root/Desktop  rpm-name1 rpm ...

  3. js中查找一个字符是否存在。

    <script> var a = 'd'; var re = a.indexOf('d'); ){ alert('存在'); } else { alert('不存在'); } </s ...

  4. More is better(MST)(求无向图中最大集合元素个数)

    More is better Time Limit:1000MS     Memory Limit:102400KB     64bit IO Format:%I64d & %I64u Sub ...

  5. LUA之string的使用

    --string.len(s)          --返回字符串s的长度 --string.rep(s, n)--返回重复n次字符串s的串,你使用string.rep("a", 2 ...

  6. [codeforces 260]B. Ancient Prophesy

    [codeforces 260]B. Ancient Prophesy 试题描述 A recently found Ancient Prophesy is believed to contain th ...

  7. 【转】java反射详解

    转自:http://www.cnblogs.com/rollenholt/archive/2011/09/02/2163758.html 本篇文章依旧采用小例子来说明,因为我始终觉的,案例驱动是最好的 ...

  8. cocos2d-x如何解决图片显示模糊问题

    转载http://zhidao.baidu.com/link?url=JTUKP5quGfMQixLZSvtC2XlKMkQDyQbYW72_DRyD6KDRpkLs8_6poQtKkwsyqzU8q ...

  9. ffplay mini 媒体播放器

    下载 http://pan.baidu.com/s/1dDcp3lZ 一定要解压到 D:\ffplay\ 目录下 双击 OpenWith_FFPlay_mini.reg 注册ffplay 在视频文件名 ...

  10. elk+redis分布式分析nginx日志

    一.elk套件介绍 ELK 由 ElasticSearch . Logstash 和 Kiabana 三个开源工具组成.官方网站: https://www.elastic.co/products El ...