iOS WebView加载本地js、css文件

html-css019

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]]            

       }        

}

CSS加载失败,出现这个问题,一般是因为的css路径书写错,或者是在浏览器中禁止掉了css的加载,可以重新启动浏览器刷新,在文件中css的调用,一般都是通过link加上你的路径来实现,具体可以看下代码:

<!DOCTYPE html>

index

//注意好文件名的书写就没问题了。

ios上plus是一直存在的,不涉及等ready事件。但安卓上还是需要等plus ready。

在安卓环境中,通常情况下需要html页面解析完成后才会让5+ API生效,安卓的执行的顺序为:

1. 加载html页面,loading

2. 解析html页面(解析title节点、下载script/link等节点引用的资源,如js/css文件)

3. 触发DOMContentLoaded事件

4. 触发plusready事件

此文对执行顺序有详细描述:http://ask.dcloud.net.cn/article/571

我们总是在不停追求性能优化,生效时间越早,我们可以把app的体验做的更好。

在HBuilder7.5版本之后安卓版支持提前注入5+ API,可以在plusready事件触发之前调用5+ API,操作方法是在页面中添加以下节点:

<script src="html5plus://ready"></script>,示例如下:

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8"/>

<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no"/>

<title>HTML5+ API</title>

<script src="html5plus://ready"></script>

<script type="text/javascript" charset="utf-8">

// 这里可以调用5+ API了,为了更好的兼容性,应该使用以下代码进行判断

if(window.plus){

// 在这里调用5+ API

}else{// 兼容老版本的plusready事件

document.addEventListener('plusready',function () {

// 在这里调用5+ API

},false)

}

</script>

</head>

<body>

Hello HTML5 plus