iOS WebView加载本地js、css文件

html-css026

iOS WebView加载本地js、css文件,第1张

思路:对html进行操作,然后webView loadHtml

将需要的js、css资源导入创建好的bundle下,如上图

WKWebView *webView = [[WKWebView alloc]initWithFrame:frame]]

这个filePaths 就是需要加载的 js、css文件在本地的路径,是个数组,因为可能需要加载本地的多个js、css文件, 如果需要加载的js、css文件较多,可以让后台传给你对应js、css文件的路径,注意传的路径要跟导入本地的资源路径一致,否则会加载失败。

//路径path

NSArray *pathArray  = dict[@"filePath"]

if (pathArray) {            

NSError *error            

//获取网络的HTML            

NSString * online_HTML  = [NSString stringWithContentsOfURL:[NSURL URLWithString:url] encoding:NSUTF8StringEncoding error:&error]           

 if(!error) {                

//以分割               

 NSArray * array_HTML    = [online_HTML componentsSeparatedByString:@"</head>"]                                

NSMutableString *header_HTML = [[NSMutableString alloc]initWithString:array_HTML.firstObject]                                

for (NSString *path in pathArray) {                    

//注意这里的hightcharts.bundle,更改成你本地的bundle名

NSString *filePath = [[NSBundle mainBundle] pathForResource:[NSString stringWithFormat:@"hightcharts.bundle/%@",path] ofType:nil]                   

if ([filePath hasSuffix:@"js"]) {                       

[header_HTML appendFormat:@"<script src=\"%@\"><\script>",filePath]                   

}else if ([filePath hasSuffix:@"css"]){                        

[header_HTML appendFormat:@"<link rel=\"stylesheet\"               

[_webView loadHTMLString:header_HTML baseURL:[[NSBundle mainBundle] bundleURL]]            

       }        

}

中间过程就不说了.结果肯定是可以做到的,用到了神奇的 NSURLProtocol

这里主要做下笔记:

它是干什么的呢,是一个挺牛逼的类,它是一个抽象类,不能去实例化它,只能子类化 NSURLProtocol ,

每次在对一个 URL 进行请求的时候 URL Loading System 都会向 已经注册的 Protocol 询问是否可以处理该请求。这里就看出他的作用来了. 比如 : 拦截UIWebView的请求,忽略请求,重定向... ...

<br >

一个个的说

这个方法是决定这个 protocol 是否可以处理传入的 request 的如是返回 true 就代表可以处理,如果返回 false 那么就不处理这个 request 。

这个方法主要是用来返回格式化好的 request ,如果自己没有特殊需求的话,直接返回当前的request就好了。如果你想做些其他的,比如地址重定向,或者请求头的重新设置,你可以 cop y下这个 request 然后进行设置。

该方法主要是判断两个请求是否为同一个请求,如果为同一个请求那么就会使用缓存数据。通常都是调用父类的该方法。

开始处理这个请求和结束处理这个请求

我们处理(拦截)好请求之后,就要开始对他经常处理,这个时候就用到了父类里面的 client 对象.

他是一个协议,里面的方法和 NSURLConnection 差不多

上图可以看到截获的所有的请求地址,不管是js,css还是png图片都有

我在开发中发现 http 转 https 的时候 会有错误,有哪位大神指导下改如何去改,多谢.

我看这里学会的,上文大部分都是这里出来的,尊重原作者

推荐