iOS开发之用javascript调用oc方法而非url
2019/7/9 23:16:19
本文主要是介绍iOS开发之用javascript调用oc方法而非url,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
先来看看如何在项目中的webview上面点击一个按钮,就能达到调用oc代码
上面的这个页面是webview里面嵌套的一个项目的网页,打印订单点击之后(点击事件是一个js方法),需要调用oc里面集成好的蓝牙打印机功能,来完成打印。
所以这里只能用js代码来直接调用oc代码。
1.首先创建一个iOS类,因为这里一般都需要安卓端做一套,iOS端做一套,所以一般这样命名以示区别
.h #import <Foundation/Foundation.h> #import <JavaScriptCore/JavaScriptCore.h> /** * js调用oc里 main的代码,需要借助这个协议才行 */ @protocol JSObjectProtocol <JSExport> @required #pragma mark -js调用该oc方法,并且将jsonstring打印出来 - (void)print:(NSString *)jsonString; @end @interface iOS : NSObject<JSObjectProtocol> @end
.m @implementation iOS #pragma mark -打印jsonString - (void)print:(NSString *)jsonString{ //打印的具体事件 }
2. 在网页加载结束之后调用注册iOS注册
#pragma mark -网页加载完毕,注册ios对象,并且自动检查打印机是否自动连接 -(void)webViewDidFinishLoad:(UIWebView *)webView{ //首先创建JSContext 对象(此处通过当前webView的键获取到jscontext) //这个对象必须创建出来,否则会无法调用到协议里的方法 iOS *ios = [[iOS alloc] init]; JSContext *context = [self.webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"]; context[@"iOS"] = ios; }
3. 在js的点击事件里面类似下面这样调用即可(下面这段代码写在对应的js代码里面,而非你的oc代码里面)
if (window["Android"] && window["Android"]["jsPrint"]) { var andPrint = window.Android.jsPrint(JSON.stringify(d)); } else if (window["iOS"] && window["iOS"]["print"]) { window["iOS"]["print"](JSON.stringify(d)); } else { this.alert.autoCloseTip("找不到打印方法!", 1000); }
以上就是关于iOS如何使用javascript代码调用oc方法的全部内容,希望对大家学习IOS开发有所帮助。希望大家多多支持找一找教程网。
这篇关于iOS开发之用javascript调用oc方法而非url的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-12Axios库资料:新手入门必读教程
- 2024-11-11Axios库项目实战:新手入门教程
- 2024-09-29Axios库教程:初学者必备指南
- 2024-08-29Axios库资料:新手入门指南与基本使用教程
- 2024-03-14system bios shadowed
- 2024-03-14gabios
- 2024-02-07iOS应用提交上架的最新流程
- 2024-02-06打包 iOS 的 IPA 文件
- 2023-12-07uniapp打包iOS应用并通过审核:代码混淆的终极解决方案 ?
- 2023-11-25uniapp IOS从打包到上架流程(详细简单) 原创