native invoke js和js invoke native
2016-07-21 12:07
477 查看
js与native相互调用的那些事
1.native invoke js
2.js invoke native
无论是js invoke native还是native invoke js,都是要执行那块我们想执行的代码块。我们都知道想执行代码块我们可以通过方法名来执行。
在这里也是如此。
熟悉webview的都人知道native invoke js 简单,只要使用webview中的loadurl即可,例如:mWebview.loadUrl("javascript:方法名('参数')")。
不过js invoke native时就有点问题,这个问题就是在4.2之前使用addjavascriptInterface接口引起的安全问题。可以通过反射来恶意执行一些操作。
不过这个问题可以通过prompt方法进行解决。这里就是用的prompt方法来解决的,只不过需要和前端协商好一套协议。
还是如前面说的,无论是js invoke native还是native invoke js都是方法的调用,所以在js invoke native其实就是js和native交互的一个过程,js把需要执行的方法名、参数、类名告诉native,让native执行这个方法
而js和native交互,可以使用webviewclient中三个回调:onJsAlert()、onJsConfirm()、onPageprompt()中的Message来传递协议。
我们可以用一个url来包装这个协议,然后通过Uri获取到message中的类名、方法名、参数,最后通过反射来调用指定的方法。
1.native invoke js
2.js invoke native
无论是js invoke native还是native invoke js,都是要执行那块我们想执行的代码块。我们都知道想执行代码块我们可以通过方法名来执行。
在这里也是如此。
熟悉webview的都人知道native invoke js 简单,只要使用webview中的loadurl即可,例如:mWebview.loadUrl("javascript:方法名('参数')")。
不过js invoke native时就有点问题,这个问题就是在4.2之前使用addjavascriptInterface接口引起的安全问题。可以通过反射来恶意执行一些操作。
不过这个问题可以通过prompt方法进行解决。这里就是用的prompt方法来解决的,只不过需要和前端协商好一套协议。
还是如前面说的,无论是js invoke native还是native invoke js都是方法的调用,所以在js invoke native其实就是js和native交互的一个过程,js把需要执行的方法名、参数、类名告诉native,让native执行这个方法
而js和native交互,可以使用webviewclient中三个回调:onJsAlert()、onJsConfirm()、onPageprompt()中的Message来传递协议。
我们可以用一个url来包装这个协议,然后通过Uri获取到message中的类名、方法名、参数,最后通过反射来调用指定的方法。
相关文章推荐
- javascript实现滚动效果的数字时钟实例
- js的原型继承
- Extjs学习
- JS中简单的继承与多态
- 需要掌握的es6特性(二)
- js打开新页面
- JavaScript的ready方法中获取某元素(如获取某个button,并设置onclick事件)的疑问?为什么要写在ready方法里,不用ready方法可以吗?
- Eclipse去除js(JavaScript)验证错误
- 看懂此文,不再困惑于javascript中的事件绑定、事件冒泡、事件捕获和事件执行顺序
- JS常用各种正则表达式
- JavaScript事件基础知识总结【思维导图】
- javascript的执行顺序
- 关于jsoup的select()
- JS获取指定的cookie值
- javascript控制input只允许输入数字
- Chrome 中的 JavaScript 断点设置和调试技巧
- 在C#中,Json的序列化和反序列化的几种方式总结
- 需要掌握的es6特性(一)
- WGS84 和 WebMercator 互转 Javascript实现
- 当浏览器窗口缩放时echarts()也随着变化用resize() 方法