1.6 通过Javascript代码调用原生程序 [iOS开发中的神兵利器]

原文:http://coolketang.com/staticCoding/5a995088fe88c21c80b2df2d.html

1. 本节课将为您演示,如何通过网页中的脚本代码,调用设备的原生程序。首先创建一个网页文件,在项目文件夹上点击鼠标右键,弹出右键菜单。 



2. 在弹出的右键菜单中,选择[创建新文件]选项。 


3. 在弹出的文件模板窗口中,点击右侧的垂直滚动条,查看下方的文件模板。 


4. 然后选择[空白]模板选项。 


5. 点击下一步按钮,创建一个空白文件。 


6. 在弹出的文件存储窗口中,输入文件的名称。 


7. 最后点击创建按钮,完成空白文件的创建。 


8. 现在开始在空白文件中输入网页代码。 


9. 首先输入一对网页标签,作为网页代码的容器。 


10. 接着输入一对网页头标签,用来设置网页的属性信息。 


11. 设置网页的字符编码方式。 


12. 然后给网页添加标题文字,标题文字通常显示在浏览器的标签处。 


13. 接着添加一对脚本标签,用来编写脚本代码。 


14. 添加一个脚本函数,用来获得当前设备的属性信息。 


15. 当执行该函数时,浏览器将进行跳转,跳转的目标网址是一个特殊的字符串。通过在原生程序监听和捕捉该字符串,实现脚本调用原生程序的功能。 


16. 接着添加一对主体标签,网页中的元素通常都放在此处,同时设置其背景颜色。 


17. 添加一个按钮元素,当该按钮被点击时,执行刚刚创建的脚本函数。然后在左侧的项目导航区,打开视图控制器的代码文件。 


18. 现在开始编写代码,通过网页视图加载刚刚创建的网页文件,并监听网页视图的加载动作。 


19. 首先添加一个网页视图的代理协议,通过该协议中的方法,可以对网页视图的加载动作进行监听。 


20. 接着给类文件添加一个网页视图类型的属性。 


21. 获得当前设备的屏幕尺寸信息。 


22. 通过屏幕尺寸信息创建一个矩形区域。 


23. 然后通过矩形区域,初始化一个位于该显示区域的网页视图。 


24. 设置网页视图的代理对象,该代理对象是当前的视图控制器对象。 


25. 接着设置网页视图的背景颜色为无色。 


26. 设置根视图的背景颜色为橙色,并将网页视图添加到根视图中。 


27. 获得网页文件在项目中的路径,并将路径转换成网址的样式。 


28. 通过网页视图的加载请求方法,加载该网址路径下的网页文件。 


29. 添加一个代理方法,用来监听网页视图的加载动作。当网页视图即将开始加载动作时,调用此方法。 


30. 获得网页视图即将加载的网址字符串。 


31. 将网址以冒号进行分割,并生成一个包含两个字符串的数组。 


32. 获得数组中的第一个元素。 


33. 如果数组中的第一个元素,和我们在网页文件中编写的脚本一致,则执行之后的代码。 


34. 获得当前设备的模型信息。 


35. 接着获得当前设备的操作系统的名称。 


36. 获得当前设备的操作系统的版本号。 


37. 将以上获得的信息,拼接成一个字符串常量。 


38. 然后通过调用脚本的警告语句,在网页中打开警告窗口,并显示设备的属性信息。 


39. 最后返回假,使网页视图中止加载的动作。 


40. 当网页视图加载的网址,不是我们自定义的网址时,则返回真,以继续网页视图的加载动作。接着点击[编译并运行]按钮,启动模拟器预览项目。 


41. 在弹出的模拟器中,点击网页中的按钮,将弹出一个警告窗口。 


42. 在弹出的警告窗口中,显示了当前模拟器的属性信息。点击窗口中的确定按钮,关闭弹出窗口。 


本文整理自:《app开发中的神兵利器》,真正的[手把手]教学模式,用最快的速度上手iOS开发,苹果商店App Store免费下载:https://itunes.apple.com/cn/app/id1209739676,或扫描本页底部的二维码。课程配套素材下载地址:资料下载



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李发展

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值