2015-04-03 68 views
0

我使用bbcode parser先解析bbcodeHTML,然后我默认的配置使其穿过HtmlPurifier,由于某种原因它前面加上一个额外的列表项到我的列表在HTML中。HtmlPurifier前面加上额外的列表项的所有列表

下面是HTML代码以前传递给HtmlPurifier:正在通过HtmlPurifier(请注意,我已经很好地格式化这个,因为它也消除了线路运行

<strong>bold text</strong><br /> 
<em><strong>bold italic</strong></em><br /> 
<span style="text-decoration: underline"><strong>bold underline</strong></span><br /> 
<em><span style="text-decoration: underline"><strong>bold underline italic</strong></span></em><br /> 
<strong>bold striked</strong><br /> 
<em><span style="text-decoration: underline"><strong>bold italic underlined striked</strong></span><br /> 
<br /> 
italic text</em><br /> 
<br /> 
<span style="color: #9966ff">colored text</span><br /> 
<br /> 
<span style="text-decoration: underline"><em>italic underlined</em></span><br /> 
<br /> 
<span style="text-decoration: underline">underlined text</span><br /> 
<br /> 
<span style="text-decoration: line-through">striked text</span><br /> 
<br /> 
align left<br /> 
<br /> 
<div style="text-align: center">align center</div><br /> 
<br /> 
<div style="text-align: right"><span style="text-decoration: underline"><strong>align right bold underline</strong></span><br /> 
<br /> 
<div style="text-align: left"><a href="http://moo.com">a text link</a></div><br /> 
<div style="text-align: left"><a href="http://moo.com">[color=#9966ff]a colored text link[/color]</a><br /> 
<span style="color: #6699ff"><a href="http://moo.com">[b]a bold text link[/b]</a></span><br /> 
<span style="color: #333333"><br /> 
<span style="font-size: large"><strong>My List</strong></span></span><br /> 
<br /> 
<ul><br /> 
<li>Cat</li><br /> 
<li>Dog</li><br /> 
<li>Fish</li><br /> 
<li>Duck</li><br /> 
</ul><br /> 
<span style="font-size: large"><strong>My List 2</strong></span><br /> 
:)<br /> 
:&#039;(<br /> 
<ol><br /> 
<li><strong><span style="color: #666633">Car</span></strong></li><br /> 
<li><strong><span style="color: #666633">Bike</span></strong></li><br /> 
<li><strong><span style="color: #666633">Tram</span></strong></li><br /> 
<li><strong><span style="color: #666633">Bus</span></strong></li><br /> 
</ol><br /> 
<span style="font-size: large"><strong><br /> 
My List 3</strong></span><br /> 
<br /> 
<ol><br /> 
<li><a href="http://moo.com">Moo</a></li><br /> 
<li><a href="http://quack.com">Quack</a></li><br /> 
<li><a href="http://woof.com">Woof</a></li><br /> 
<li><a href="http://meow.com">Meow</a></li><br /> 
</ol><br /> 
</div><br /> 
</div><br /> 
<br /> 
<span style="font-size: large"><strong><br /> 
My List 4</strong></span><br /> 
<br /> 
<ul><br /> 
<li>Cat</li><br /> 
<li>Dog</li><br /> 
<li>Fish</li><br /> 
<li>Duck</li><br /> 
</ul> 

下面是HTML代码后-breaks)

<strong>bold text</strong><br /><em><strong>bold italic</strong></em><br /><span style="text-decoration:underline;"><strong>bold underline</strong></span><br /><em><span style="text-decoration:underline;"><strong>bold underline italic</strong></span></em><br /><strong>bold striked</strong><br /><em><span style="text-decoration:underline;"><strong>bold italic underlined striked</strong></span><br /><br /> 
italic text</em><br /><br /><span style="color:#9966ff;">colored text</span><br /><br /><span style="text-decoration:underline;"><em>italic underlined</em></span><br /><br /><span style="text-decoration:underline;">underlined text</span><br /><br /><span style="text-decoration:line-through;">striked text</span><br /><br /> 
align left<br /><br /> 
<div style="text-align:center;">align center</div> 
<br /><br /> 
<div style="text-align:right;"> 
    <span style="text-decoration:underline;"><strong>align right bold underline</strong></span><br /><br /> 
    <div style="text-align:left;"><a href="http://moo.com">a text link</a></div> 
    <br /> 
    <div style="text-align:left;"> 
     <a href="http://moo.com">[color=#9966ff]a colored text link[/color]</a><br /><span style="color:#6699ff;"><a href="http://moo.com">[b]a bold text link[/b]</a></span><br /><span style="color:#333333;"><br /><span style="font-size:large;"><strong>My List</strong></span></span><br /><br /> 
     <ul> 
      <li><br /></li> 
      <li>Cat<br /></li> 
      <li>Dog<br /></li> 
      <li>Fish<br /></li> 
      <li>Duck<br /></li> 
     </ul> 
     <br /><span style="font-size:large;"><strong>My List 2</strong></span><br /> 
     :)<br /> 
     :'(<br /> 
     <ol> 
      <li><br /></li> 
      <li><strong><span style="color:#666633;">Car</span></strong><br /></li> 
      <li><strong><span style="color:#666633;">Bike</span></strong><br /></li> 
      <li><strong><span style="color:#666633;">Tram</span></strong><br /></li> 
      <li><strong><span style="color:#666633;">Bus</span></strong><br /></li> 
     </ol> 
     <br /><span style="font-size:large;"><strong><br /> 
     My List 3</strong></span><br /><br /> 
     <ol> 
      <li><br /></li> 
      <li><a href="http://moo.com">Moo</a><br /></li> 
      <li><a href="http://quack.com">Quack</a><br /></li> 
      <li><a href="http://woof.com">Woof</a><br /></li> 
      <li><a href="http://meow.com">Meow</a><br /></li> 
     </ol> 
     <br /> 
    </div> 
    <br /> 
</div> 
<br /><br /><span style="font-size:large;"><strong><br /> 
My List 4</strong></span><br /><br /> 
<ul> 
    <li><br /></li> 
    <li>Cat<br /></li> 
    <li>Dog<br /></li> 
    <li>Fish<br /></li> 
    <li>Duck<br /></li> 
</ul> 

任何想法为什么这样做?

回答

3

你传递名单像这些以HtmlPurifier:

<ul><br /> 
<li>Cat</li><br /> 
<li>Dog</li><br /> 
<li>Fish</li><br /> 
<li>Duck</li><br /> 
</ul><br /> 

但是,<br />元素不能为<ul><ol>元素的直接子:这些列表元素的所有儿童都必须<li>元素。因此,HtmlPurifier会将出现在之后的<br />元素折成<li>标签分成,li元素,因此会生成html,如<li>Cat<br /></li>。但是,第一个<br />标记没有<li>标记折叠到,因此会生成一个列表项以代替它。

要解决,你就必须让BB代码分析器输出HTML这样的代替:

<ul> 
<li>Cat</li> 
<li>Dog</li> 
<li>Fish</li> 
<li>Duck</li> 
</ul> 
+0

啊好吧,是有道理的。我猜bbcode解析器正在将新行变成'
'标签,因此这就是它们最终列在列表项上的原因。我将不得不尝试一些其他的bbcode解析器。谢谢! – Brett 2015-04-03 14:31:29