<meta http-equiv="Content-Type" content="text/htmlcharset=utf-8">
<link rel="stylesheet" type="text/css" href="test.css">
<title>无标题 1</title>
</head>
----------------------------------------------------------------------------------------------
在<head></head>标签之间加入
<link rel="stylesheet" type="text/css" href="test.css">
"test.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\"
[_webView loadHTMLString:header_HTML baseURL:[[NSBundle mainBundle] bundleURL]]
}
}
1、使用 <link>标签导入
使用 <link>标签导入外部样式表文件:
<link href="001.css" rel="stylesheet" type="text/css" />
对各个属性的说明:
href 属性设置外部样式表文件的地址,可以是相对地址,也可以是绝对地址。
rel 属性定义关联的文档,这里表示关联的是样式表。
type 属性定义导入文件的类型,同 style 元素一样,text/css表明为 CSS 文本文件。
一般在定义 <link>标签时,应定义 3 个基本属性,其中 href 是必须设置属性。
也可以在 link 元素中添加 title 属性,设置可选样式表的标题,即当一个网页文档导入了多个样式表后,可以通过 title 属性值选择所要应用的样式表文件。
外部样式是 CSS 应用的最佳方案,一个样式表文件可以被多个网页文件引用,同时一个网页文件可以导入多个样式表,方法是重复使用 link 元素导入不同的样式表文件。
2、使用 @import 关键字导入
在 <style>标签内使用@import关键字导入外部样式表文件:
<style type="text/css">
@import url("001.css")
</style>
在 @import 关键字后面,利用 url() 函数包含具体的外部样式表文件的地址。
对比
两种导入样式表的方法比较:
link 属于 HTML 标签,而 @import 是 CSS 提供的。
页面被加载时,link 会同时被加载,而 @import 引用的 CSS 会等到页面被加载完再加载。
@import 只在 IE 5 以上才能识别,而 link 是 HTML 标签,无兼容问题。
link 方式的样式的权重高于 @import 权重。
一般推荐使用 link 导入样式表的方法,@import 可以作为补充方法使用。