标签属性和CSS样式的优先级的比较

  • 先看代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>img标签</title>
    <style>
        img{
            width: 600px;
        }
    </style>
</head>
<body>
    <img width="200px" src="https://sqimg.qq.com/qq_product_operations/im/mac/6.0/sp-mac/sp-mac-xlarge.png" alt="">
</body>
</html>
  • 从最终的显示效果来看,很明显是 style 标签中的样式起了作用
  • 也就是说,CSS样式会优先于标签的属性
  • W3C标准提倡使用CSS样式,提倡用CSS样式代替HTML标签属性;网页制作标准是标签跟样式分离。因为在标签属性里设置,重复使用比较难,个人猜测这可能就是css样式优先级高于标签属性的原因
  • 虽然提倡使用CSS样式,但是W3School中进行了详细的介绍:“为图像指定 height 和 width 属性是一个好习惯。如果设置了这些属性,就可以在页面加载时为图像预留空间。如果没有这些属性,浏览器就无法了解图像的尺寸,也就无法为图像保留合适的空间,因此当图像加载时,页面的布局就会发生变化
  • 如果提供了一个百分比形式的 width 值而忽略了 height,那么不管是放大还是缩小,浏览器都将保持图像的宽高比例(因为不设置height时的默认值为auto自适应)。这意味着图像的高度与宽度之比将不会发生变化,图像也就不会发生扭曲
  • 在响应式布局(一个网站能够兼容多个终端——而不是为每个终端做一个特定的版本;这个概念是为解决移动互联网浏览而诞生的)的图片处理中,应该对 img标签设置 max-width: 100%; height: auto; 这两条属性,才可以保证成比例拉伸
  • 内联样式的优先级高于内部样式表
  • 外部样式表的优先级也高于img标签内部的height属性
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTML的CSS样式优先级是指当多个CSS规则同时应用到同一个元素上时,决定哪个规则的样式优先显示的规则。CSS样式优先级由高到低的顺序如下: 1. 内联样式(Inline Style):直接写在HTML元素的style属性中的样式具有最高的优先级。例如: ```html <p style="color: red;">这是红色文字</p> ``` 2. 内部样式表(Internal Style Sheet):在HTML文档头部的`<style>`标签中定义的样式表具有次高的优先级。例如: ```html <head> <style> p { color: blue; } </style> </head> <body> <p>这是蓝色文字</p> </body> ``` 3. 外部样式表(External Style Sheet):通过`<link>`标签引入的外部CSS文件具有比内部样式表低的优先级。例如: ```html <head> <link rel="stylesheet" href="styles.css"> </head> <body> <p>这是从外部样式表定义的样式</p> </body> ``` 4. 浏览器默认样式(Browser Default Styles):浏览器默认给定的样式是最低优先级的。如果没有定义任何样式,元素将应用浏览器默认样式。 5. 选择器特殊性(Selector Specificity):如果多个规则都是通过相同的选择器选中同一个元素,那么会根据选择器的特殊性来决定优先级。特殊性的计算规则是:ID选择器的特殊性最高,类选择器和属性选择器次之,标签选择器和伪类选择器再次之,通用选择器和伪元素选择器最低。例如: ```html <style> p { color: red; } .my-class { color: blue; } </style> <p class="my-class">这个段落的颜色将是蓝色,因为类选择器的特殊性比标签选择器高</p> ``` 需要注意的是,当样式优先级相同时,后定义的样式会覆盖前面定义的样式

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值