JavaScript学习之Android与JS交互
来源:互联网 发布:tomcat 多域名绑定 编辑:程序博客网 时间:2024/06/05 00:24
先学JS,再学jQuery,不学Angular:
1、Android调用JS函数更新网页数据
JSONObject ytbDetail = new JSONObject();
法一:
webview.loadUrl("javascript:jsRequest('"+ytbDetail.toString()+"')");
function jsRequest(appStr){
val str = new Function("return" + appStr)();
(此时str为json对象,可以直接str.key这样取值)
}
法二:
webview.loadUrl("javascript:jsRequest("+ytbDetail+")");
function jsRequest(str){
(此时str为json对象,可以直接str.key这样取值)
}
2、JS调用Android对象的方法进行跳转:
法一:<a class="f1" onclick="clickDetail('+val.borrowid+')" href="ytObjDetail.html">查看详情</a>
法二:'<a class="fl" href= "javascript:clickDetail('+ '\''+ val.borrowid + '\'' + ',' + '\'' + val.title + '\'' + ')">查看详情</a>'
字符串形式的参数要用单引号,否则会提示字符串未定义
function clickDetail(id,title){
window.JSInterface.getDetail(id,title);
}
Android:
webview.getSettings().setJavaScriptEnabled(true);
webview.addJavascriptInterface(new MyHandler,"JSInterface");
class MyHandler{
@JavascriptInterface
public void getDetail(String id,String title){
Intent intent = new Intent(ExcellentPlanActivity.this,YoutbDetaiActivity.class);
intent.putExtra("ytbData",ytbData);
intent.putExtra("title",title);
startActivity(intent);
}
}
1、Android调用JS函数更新网页数据
JSONObject ytbDetail = new JSONObject();
法一:
webview.loadUrl("javascript:jsRequest('"+ytbDetail.toString()+"')");
function jsRequest(appStr){
val str = new Function("return" + appStr)();
(此时str为json对象,可以直接str.key这样取值)
}
法二:
webview.loadUrl("javascript:jsRequest("+ytbDetail+")");
function jsRequest(str){
(此时str为json对象,可以直接str.key这样取值)
}
2、JS调用Android对象的方法进行跳转:
法一:<a class="f1" onclick="clickDetail('+val.borrowid+')" href="ytObjDetail.html">查看详情</a>
法二:'<a class="fl" href= "javascript:clickDetail('+ '\''+ val.borrowid + '\'' + ',' + '\'' + val.title + '\'' + ')">查看详情</a>'
字符串形式的参数要用单引号,否则会提示字符串未定义
function clickDetail(id,title){
window.JSInterface.getDetail(id,title);
}
Android:
webview.getSettings().setJavaScriptEnabled(true);
webview.addJavascriptInterface(new MyHandler,"JSInterface");
class MyHandler{
@JavascriptInterface
public void getDetail(String id,String title){
Intent intent = new Intent(ExcellentPlanActivity.this,YoutbDetaiActivity.class);
intent.putExtra("ytbData",ytbData);
intent.putExtra("title",title);
startActivity(intent);
}
}
阅读全文
0 0
- JavaScript学习之Android与JS交互
- android学习之 webview 原生与js的交互
- android与js(JavaScript)的交互
- Android与Javascript交互之入门
- WebView---Android与Javascript交互之入门
- Android与Javascript交互之入门
- [Android]WebView与Js交互的学习
- Android之webview与js交互
- Android 开发之 WebVIew 与 JS 交互
- Android 与 JS交互之取出 链接
- JavaScript 与 Android 交互
- JavaScript与Android交互
- Android与Javascript交互
- Android与Javascript交互
- Android与Javascript交互
- Android与javascript交互
- android与javascript交互
- android与javascript交互
- Ubuntu安装火狐57
- 猜数字,hdu1172
- 当浏览器的cookie被禁用了,怎么使用session
- 为什么 qt 成为 c++ 界面编程的第一选择?
- iOS11调用百度地图出现自定义 大头针不显示的问题
- JavaScript学习之Android与JS交互
- 怎么装easy_install
- jsp 中<c:forEach>的用法 获取items具体值的用法
- python练习001及002
- java 实用---去掉鸡肋的jsp预览
- Android手机可以通过adb执行按键操作
- target和currentTaeget填坑
- dubbo-9 hodson的安装与配置
- MVVM模式及与MVP和MVC的区别