iOS WebView加载本地js、css文件

html-css022

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

       }        

}

可以用js加载css。

webview.setWebViewClient(new WebViewClient() {

....

public void onPageFinished(WebView view, String url) {

src="file:///android_asset/xxx.js"

String baseUrl = "file:///android_asset"

view.loadDataWithBaseURL(baseUrl, strHtml, "text/html", "utf-8", null)

}

....

}

js文件如下:

function loadjscssfile(filename,filetype){

if(filetype == "js"){

var fileref = document.createElement('script')

fileref.setAttribute("type","text/javascript")

fileref.setAttribute("src",filename)

}else if(filetype == "css"){

var fileref = document.createElement('link')

fileref.setAttribute("rel","stylesheet")

fileref.setAttribute("type","text/css")

fileref.setAttribute("href",filename)

}

if(typeof fileref != "undefined"){

document.getElementsByTagName("head")[0].appendChild(fileref)

}

}

调用方式:

loadjscssfile("test.css","css")

项目中出现一个兼容性问题,Oppo、Vivo手机Webview加载本地JS、CSS不执行

一、前提 OV手机低于android 7.0版本,

二、baseUrl是Https的

三、使用: webView.loadDataWithBaseURL(baseUrl, html, "text/htmlcharset=UTF-8", "utf-8", null) 方法加载

解决办法

还有一种不太好的解决办法: webView.loadDataWithBaseURL(null, html, "text/htmlcharset=UTF-8", "utf-8", null)

但是这样会导致页面内不是完整路径的图片找不到。