我遵循这个解决方案
How can I change font color and font style of ePub Book in iOS?
然而它无法正常工作。例如在这段html中
<body>
<div id="HolubiPosta-E-2.html" xml:lang="cs-CZ">
<div class="Z-kladn--grafick--r-me-ek">
<p class="Nazev para-style-override-3" id="toc_marker-2">Holubí pošta</p>
<p class="Z-kladn--odstavec para-style-override-4"><span>Už od rána slunce sypalo hlava nehlava zlato.</span></p>
它会更改第二段中的字体,但不会更改第一段中的字体。
如何在所有html文档中正确更改font-family?
编辑:这是我正在使用的css添加功能
NSString *addCSSRule = @"function addCSSRule(selector, newRule) {"
"if (mySheet.addRule) {"
"mySheet.addRule(selector, newRule);" // For Internet Explorer
"} else {"
"ruleIndex = mySheet.cssRules.length;"
"mySheet.insertRule(selector + '{' + newRule + ';}', ruleIndex);" // For Firefox, Chrome, etc.
"}"
"}";
这就是我所说的:
NSString *setTextFont = [NSString stringWithFormat:@"addCSSRule('html, body, div, p, span, a', 'font-family: %@;')", m_str_font_name];
[webView stringByEvaluatingJavaScriptFromString:setTextFont];
CSS:
p.Nazev {
font-family : "Liberation Serif", serif;
font-weight : normal;
font-style : normal;
font-size : 1.33em;
text-decoration : none;
font-variant : normal;
line-height : 1.2;
text-align : center;
color : #0000ff;
text-indent : 0px;
margin : 0px;}
p.para-style-override-3 {
margin-bottom : 28px;
margin-top : 28px;}
p.para-style-override-4 {
text-align : justify;}
div.Z-kladn--grafick--r-me-ek {}
答案 0 :(得分:1)
这是一种方法。我可以确认它适用于iOS UIWebView
。将'serif'替换为您想要的font-family
。
[self.contentView stringByEvaluatingJavaScriptFromString:
@"var styleSheets = document.styleSheets;for( i=0; i < styleSheets.length; i++ ){for( j=0; j < styleSheets[i].cssRules.length; j++){var rule = styleSheets[i].cssRules[j]; rule.style['font-family'] = 'serif'}}"];
不是最优雅的方式,但基本上它遍历所有现有规则并设置字体系列。
我猜您的问题发生是因为您添加的新元素级规则被epub css中定义的某些现有类级规则覆盖。