网页中引用两个css冲突该怎么办?

html-css012

网页中引用两个css冲突该怎么办?,第1张

CSS代码修改。

有时候在写CSS的过程中,某些限制总是不起作用,这就涉及了CSS样式覆盖的问题,如下。

css的顺序是“元素上的style”>“文件头上的style元素”>“外部样式文件”,但对于样式文件中的多个相同样式的优先级怎样排列,没有详细说明。经过测试和继续搜索,得知优先级如下排列:

样式表的元素选择器选择越精确,则其中的样式优先级越高:id选择器指定的样式>类选择器指定的样式>元素类型选择器指定的样式。所以上例中,#navigator的样式优先级大于.current_block的优先级,及时.current_block是最新添加的,也不起作用。

对于相同类型选择器制定的样式,在样式表文件中,越靠后的优先级越高。注意,这里是样式表文件中越靠后的优先级越高,而不是在元素class出现的顺序。比如.class2在样式表中出现在.class1之后:

3.如果要让某个样式的优先级变高,可以使用!important来指定:

将border从#navigator中拿出来,放到一个class.block中,而.block放到.current_block之前:

问题详述: 当设置块级元素div颜色为粉色,页面背景颜色为白色时,div子元素比如<p>段落内容在浏览器界面没有显示出父元素div的粉色,而显现出了页面背景的白色。(如图1) 事发现场: <!doctype html> <html lang="zh-cn"> <head> <title>颜色覆盖问题还原</title> <meta charset="utf-8"> <style> *{ background-color:white } div{ background-color:pink } </style> </head> <body> <div>天呐我是一整段 <p>我是一段话</p> <p>我是一段话</p> <p>我是一段话</p> <p>我是一段话</p> </div> </body> </html> 问题解决方法: 简单 (:зゝ∠)把*{}改成body{},还我粉色世界! 问题参考链接: 和我的问题一样 http://bbs.51cto.com/thread-1151863-1-1.html这个问题更深一点 http://bbs.csdn.net/topics/380241918是不是很简单,是不是很炫酷,是不是觉得自己傻缺的可爱......

LZ,你的问题有点含糊。你说的CSS覆盖应该是优先级的覆盖吧???

除了本身优先级的原因以外,也就是常说的id优先级>class优先级>元素优先级。还有个CSS位置的问题。越靠后的优先级越大。比如你在页面定义了一个css类css1,但是你在类后面引入了一个css文件也含有类名css1,那么后面一个会覆盖前面一个。所以,你要把你希望覆盖的css放在最后。