webview与javascript交互相关技术
android 中webview 与javascript交互技术的介绍 内置详解
目录
1. Webview介绍与Javascript介绍
2. Webview与JavaScript交互用到的技术
3. Webview与JavaScript 交互步骤与参数流程
android 中webview 与javascript交互技术的介绍 内置详解
1. webview 介绍 与javascript 介绍
webview:
Android手机中内置了一个webkit的浏览器 ,在SDK中封装成了webview
Javascript :
JavaScript是一种能让你的网页更加生动活泼的程式语言,也是目前网页中设计中最容易学又最方便的语言。你可以利用JavaScript轻易的做出亲切的欢迎讯息、漂亮的数字钟、有广告效果的跑马灯及简易的选举,还可以显示浏览器停留的时间。让这些特殊效果提高网页的可观
android 中webview 与javascript交互技术的介绍 内置详解
3.Webview与JavaScript交互用到的方法。
WebViewClient主要帮助WebView处理各种通知、请求事件的,比如: onLoadResource //在加载页面资源时会调用,每一个资源(比如图片)的加载都会调用一次。
onPageStart //在页面加载开始时调用。
onPageFinish //在页面加载结束时调用。
onReceiveError
onReceivedHttpAuthRequest //身份验证请求时调用
WebChromeClient主要辅助WebView处理Javascript的对话框、网站图标、网站title、加载进度等比如JS、进度条等,就要用到WebChromeClient。 onCloseWindow(关闭WebView)
onCreateWindow()
onJsAlert (WebView上alert无效,需要定制WebChromeClient处理弹出) onJsPrompt//在客户端上显示一个提示对话框
onJsConfirm //在客户端上显示一个提交对话框
onProgressChanged //提示应用程序当前进度去加载一个页面
onReceivedIcon
onReceivedTitle
看上去他们有很多不同,实际使用的话,如果你的WebView只是用来处理一些html的页面内容,只用WebViewClient就行了,如果需要更丰富的处理效果,
android 中webview 与javascript交互技术的介绍 内置详解
4. Webview与JavaScript 交互步骤与参数流程
一 ,
1. AndroidManifest.xml中必须注册"android.permission.INTERNET"进行权限许可,(如果只是使用本地HTML,可以不用注册许可权限)否则会出Web page not available错误
2. 如果在web中使用js需要许可javascript执行:WebView webv =(WebView)findViewById(R.id.webv);//从xml中获取webview,
webv.getSettings().setJavaScriptEnabled(true);//允许JS执行
3.如果在用webview做应用的时候我们不希望新建webview进程,让程序跳来跳去那么进行如下设置
webv.setWebViewClient(new WebViewClient(){
public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url);//点击超链接的时候重新在原来进程上加载URL
return true;
}
});
4. 在做webview开发是经常会加载本机的html文件如下:
android 中webview 与javascript交互技术的介绍 内置详解
file:///android_asset/teste.html 加载项目assets下的文件teste.html file:///sdcard/index.html 加载sdcard下的index.html文件
5 . 在javascript中调用java方法 , 传递给java方法参数:
5.1先将一个当前的java对象绑定到一个javascript上面,使用如下方法
webv.addJavascriptInterface(this, "someThing");//this为当前对象,绑定到js的someThing上面,主要someThing的作用域是全局的。一旦初始化便可随处运行
5.2 Js中定义被调用的java方法
<a onClick="window. someThing.clickOnAndroid()">
6 . java中调用js代码,当然这个也需要触发,现在将上述html中的onload代码改变为onload="javascript:window.someThing.getJsData()" 然后在java中增加如下代码
public void getJsData(){
webv.loadUrl("javascript:dosomething(‘ ’)");
}
android 中webview 与javascript交互技术的介绍 内置详解
二,
这里还有几个知识点:
1)为了让WebView从apk文件中加载assets,Android SDK提供了一个schema,前缀为"file:///android_asset/"。WebView遇到这样的schema,就去当前包中的assets目录中找内容。如上面的
"file:///android_asset/demo.html"
2) addJavascriptInterface方法中要绑定的Java对象及方法要运行另外的线程中,不能运行在构造他的线程中,这也是使用Handler的目的。
…… 此处隐藏:772字,全部文档内容请下载后查看。喜欢就下载吧 ……
相关推荐:
- [实用模板]第八章:法国“新浪潮”与“左岸派”
- [实用模板]2021年北京上半年临床医学检验技师生物
- [实用模板]SAP GUI 7.10客户端安装配置文档
- [实用模板]2001年临床执业医师资格考试综合笔试试
- [实用模板]36机场工作实用英语词汇总结
- [实用模板](一)社会保险稽核通知书
- [实用模板]安全教育主题班会材料
- [实用模板]濉溪县春季呼吸道传染病防控应急演练方
- [实用模板]长沙房地产市场周报(1.30-2.3)
- [实用模板]六年级数学上册典中点 - 图文
- [实用模板]C程序设计(红皮书)习题官方参考答案
- [实用模板]中国证监会第一届创业板发行审核委员会
- [实用模板]桥梁工程复习题
- [实用模板]2011学而思数学及答案
- [实用模板]初中病句修改专项练习
- [实用模板]监理学习知识1 - 图文
- [实用模板]小机灵杯四年级试题
- [实用模板]国贸专业毕业论文模板
- [实用模板]教育学概论考试练习题-判断题4
- [实用模板]2015届高考英语一轮复习精品资料(译林
- 00Nkmhe_市场营销学工商管理_电子商务_
- 事业单位考试法律常识
- 诚信教育实施方案
- 吉大小天鹅食品安全检测箱方案(高中低
- 房地产销售培训资料
- 高一地理必修1复习提纲
- 新概念英语第二册lesson_1_练习题
- 证券公司内部培训资料
- 小学英语时间介词专项练习
- 新世纪英语专业综合教程(第二版)第1册U
- 【新课标】浙教版最新2018年八年级数学
- 工程建设管理纲要
- 外研版 必修一Module 4 A Social Surve
- Adobe认证考试 AE复习资料
- 基于H.264AVC与AVS标准的帧内预测技术
- 《食品检验机构资质认定管理办法》(质
- ABB变频器培训课件
- (完整版)小学说明文阅读练习题及答案
- 深思洛克(SenseLock) 深思IV,深思4,深
- 弟子规全文带拼音