前端HTML与苹果iOS设备之间的两种通信方式

  • 使用Web视图(WebView):

HTML(网页)可以通过以下几种方式与iOS设备进行通信:

WebView是iOS提供的一个用于显示网页的控件。通过在iOS应用中嵌入WebView,可以将网页内容加载到应用中,并且可以通过JavaScript调用WebView的方法和事件。这样,就可以通过WebView实现网页与iOS的交互。例如,在网页中添加一个按钮,通过JavaScript监听按钮点击事件,然后在iOS应用中通过WebView的evaluateJavascript方法来执行JavaScript代码。

HTML网页中:

<button onclick="sendMessageToiOS('Hello from HTML')">
    Send message to iOS
</button>

在iOS应用中:

-(void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error{}NSException *exception;
NSString *javascriptString = [NSString stringWithFormat:@"sendMessageToiOS('Hello from HTML')"];
UIWebView *webView;NSString *failUrl = @"http://example.com";
NSURL *failUrlUrl = [NSURL URLWithString:failUrl];UIWebView *webView = [[UIWebView alloc] initWithFrame:CGRectZero];
webView.delegate = self;
[webView loadRequest:[NSURLRequest requestWithURL:failUrlUrl]];
  • 使用AJAX:

AJAX是一种在不刷新整个页面的情况下更新页面的技术。在HTML中,可以使用JavaScript来使用AJAX将数据发送到iOS应用。在JavaScript中,可以使用XMLHttpRequest对象或fetch API来发送HTTP请求。

例如,使用fetch API发送GET请求:

var xhr = new XMLHttpRequest();
xhr.open('GET', 'http://example.com/api/data');
xhr.onreadystatechange = function() {
	if (xhr.readyState === 4 && xhr.status === 200) {
		// 处理响应数据
	}
};

在iOS应用中,可以使用以下代码来处理AJAX请求:

-(void)fetchDataFromWebView:(UIWebView *)webView{
	NSString *requestUrl = @"http://example.com/api/data";
	NSURL *url = [NSURL URLWithString:requestUrl];
	NSURLRequest *request = [NSURLRequest requestWithURL:url];
	NSData *data = [webView performSelector:@selector(sendDataToWebView:) withObject:request];
	// 处理响应数据
}
						
  • 使用WebSocket:

在iOS应用中使用WebSocket通信需要使用NSURLConnection和NSURLSession。

在HTML中,可以使用以下代码来建立WebSocket连接

var socket = new WebSocket("ws://example.com/socket");  
socket.onopen = function() {  
	// WebSocket连接已建立  
};  
socket.onmessage = function(event) {  
	// 处理从WebSocket接收到的消息  
};  
socket.onerror = function(event) {  
	socket.close();  
};

在iOS应用中,可以使用以下代码来现WebSocket接口来接收消息并返回响应:

-(void)webView:(UIWebView *)
webView didFailLoadWithError:(NSError *)error{}NSException *exception;
NSString *javascriptString = [NSString stringWithFormat:@"sendMessageToiOS('Hello from HTML')"];
UIWebView *webView;
NSString *failUrl = @"http://example.com";
NSURL *failUrlUrl = [NSURL URLWithString:failUrl];
UIWebView *webView = [[UIWebView alloc] initWithFrame:CGRectZero];
webView.delegate = self;
[webView loadRequest:[NSURLRequest requestWithURL:failUrlUrl]];

本demo是WKWebView的基本使用和交互 ,实现了原生调用js的方法、js调用原生的方法、通过拦截进行交互的方法;修改内容 加入沙盒 / /加载沙盒 不带参数 // NSArray * paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); // NSString * path = [paths objectAtIndex:0]; // path = [path stringByAppendingString:[NSString stringWithFormat:@"/app/html/index.html"]]; // NSURL *url = [NSURL URLWithString:[[NSString stringWithFormat:@"file://%@",path] stringByAddingPercentEncodingWithAllowedCharacters:[NSCharacterSet URLFragmentAllowedCharacterSet]] relativeToURL:[NSURL fileURLWithPath:NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES).firstObject]]; // [self.wkView loadFileURL:url allowingReadAccessToURL:[NSURL fileURLWithPath: [paths objectAtIndex:0]]]; // 带参数 /* NSArray * paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); NSString * path = [paths objectAtIndex:0]; path = [path stringByAppendingString:[NSString stringWithFormat:@"/app/html/index.html"]]; NSURL * url = [NSURL fileURLWithPath:path isDirectory:NO]; NSURLComponents *urlComponents = [NSURLComponents componentsWithURL:url resolvingAgainstBaseURL:NO]; [queryItemArray addObject:[NSURLQueryItem queryItemWithName:@"version" value:[[[NSBundle mainBundle] infoDictionary] objectForKey:@"CFBundleShortVersionString"]]]; [urlComponents setQueryItems:queryItemArray]; [self.wkView loadFileURL:urlComponents.URL allowingReadAccessToURL:[NSURL fileURLWithPath: [paths objectAtIndex:0]]]; */
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值