0
我产生一些HTML与web2py gluon html
库(应用程序是独立的 - 没有嵌入web2py的框架 - 只有采用gluon.html佣工)避免CDATA标签
我加入一些风格给它。由于我通过电子邮件发送生成的html,因此我使用premailer预处理html。但premailer不接受CDATA
标签:
cssselect.parser.SelectorSyntaxError: Expected selector, got <DELIM '<' at 0>
我已经采取了看胶子代码,但我不明白这一点:
class STYLE(DIV):
tag = 'style'
def xml(self):
(fa, co) = self._xml()
# no escaping of subcomponents
co = '\n'.join([str(component) for component in
self.components])
if co:
# <style [attributes]><!--/*--><![CDATA[/*><!--*/
# style body
# /*]]>*/--></style>
return '<%s%s><!--/*--><![CDATA[/*><!--*/\n%s\n/*]]>*/--></%s>' % (self.tag, fa, co, self.tag)
else:
return DIV.xml(self)
目前我在做什么来建立我的风格是:
STYLE('body { font: normal 16px/1.6em "Open Sans",Arial,Helvetica,sans-serif; } ... ')
主要生产:
<style>
<!--/*-->
<![CDATA[/*><!--*/
body {
font: normal 16px/1.6em "Open Sans",Arial,Helvetica,sans-serif;
}
...
如何使用STYLE
帮手来避免使用CDATA
标签?或者我需要使用XML
帮手,手动添加<style>
分隔符?
作为一个问题:为什么要使用CDATA
标签?据我所知,it is not really needed为HTML
(脚本和样式标签已经默认为CDATA
)。
谢谢!我最终手动放置了样式标签。我仍然想知道为什么使用CDATA的web2py,因为如我的问题所述,它不是真的需要html(或者我错了吗?) – dangonfast
随意[post and issue](https://code.google.com/ p/web2py/issues/list)。 – Anthony