美文网首页
iOS WebView加载本地js、css文件

iOS WebView加载本地js、css文件

作者: V_YC | 来源:发表于2017-08-10 09:56 被阅读0次

    iOS WebView加载本地js、css文件

    思路:对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\" href=\"%@\" />",filePath];               

           }               

     }                               

     [header_HTML appendString:@"</head>"];              

     [header_HTML appendString:array_HTML.lastObject];                

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

           }        

    }

    相关文章

      网友评论

          本文标题:iOS WebView加载本地js、css文件

          本文链接:https://www.haomeiwen.com/subject/bibcrxtx.html