我有以下内容:
Text text text2 text text
text text text text text.
在某些时候我将其替换为:
Text text <div class="highlight" style="background-color:red;">text2</div> text text
text text text text text.
但是它推动了文本,我怎么能让它保持与以前相同的顺序?
这就是我的尝试:
float:left;
和
parent().css('overflow', 'auto');
它没有用。
你知道任何解决方案吗?
提前致谢。
答案 0 :(得分:8)
您有两种解决方案:
1)只需使用span
代替div
2)您可以使用div
,但必须定义以下样式
div.highlight {
display:inline;
}
在这里,您可以找到第二个解决方案的演示:http://jsfiddle.net/smWvA/2/
答案 1 :(得分:2)
您可以使用span而不是div
Text text <span class="highlight" style="background-color:red;">text2</span> text text
text text text text text.
答案 2 :(得分:1)
Div默认为display:block
,这是影响效果的原因。
因此,您可以使用SPAN
insteed,inline
作为属性的默认值display
如果您想了解有关display属性的更多信息,请查看: https://developer.mozilla.org/en/CSS/display
答案 3 :(得分:0)
你可以检查一下类突出显示是否没有它继承的任何父css。尝试查看text2的“Computed Style”。
Google Chrome: F12 ,找到你的元素 要么 简单地右键单击text2并检查Element。
Computed Style位于inspect元素窗口的右上角
答案 4 :(得分:0)
我在jsfiddle上做了一个例子。如果您决定使用div,则必须指定display:inline或inline-block。默认情况下,Span是内联的,因此最好在此处使用span ...