我是不是一直在为图像标签强制固定图像大小
Am I stuck with forcing fixed image size for image tags?
我有一个网站,它包含一个侧栏,有时还包含一个非常大的图像(约800像素宽),但我编写了代码,这样如果屏幕分辨率太小,图像就会根据我测试该网站的多个浏览器完美地缩小和缩放到较小的空间。我使用powermapper的sortsite演示版测试了该网站,网址为:
http://try.powermapper.com/Demo/
然后它继续抱怨说,"省略IMG WIDTH或HEIGHT属性意味着页面文本会随着图像加载而跳跃。可用性.gov 14:3"
我理解这一点,并试图包含这些属性,但图像缩放不正确。
这是我在图像本身上使用的CSS,如果我有一个最大屏幕宽度为800像素的监视器,可以缩放它:
@media screen and (max-width: 600px){#X IMG{width: 100%}}
我指定600px是因为我为侧边栏保留了200像素。
我不认为javascript会是一个答案,因为在页面加载过程中,图像占位符会跳到新的大小,如果我把代码放在开头附近,它会在一定程度上延迟页面的其余部分加载。
我也在考虑使用div标签并为图像设置背景,但问题是用户无法保存它,而我网站上的其他图像都是CSS精灵表的一部分。
我也在寻找一个解决方案,即使javascript被禁用,也能与尽可能多的网络浏览器配合使用。
有什么答案吗?
这个规则虽然正确,但当响应式设计出现时,它就消失了:
省略IMG WIDTH或HEIGHT属性意味着页面文本会跳转随着图像的加载。可用性.gov 14:3
如果你总是要使用一个给定的纵横比,那么你可以如下设置你的代码。如果你在img
标签上设置width
和height
属性,并在CSS中设置max-width: 100%
(或类似内容),就像人们在开发响应式网站时经常做的那样,那么当加载图像时,你的文本仍然会跳跃,因为它的初始高度将是你在标记中指定的,然后当加载图像,浏览器将保持max-width: 100%
工作所需的纵横比,并最终缩小高度——所以这也不能真正帮助你遵守可用性规则。
.img {
background-size: cover;
background: center no-repeat;
}
.ar {
height:0;
padding: 0 0 56.25% /* 16:9 aspect ratio */
}
<div class="img" style="background-image: url(https://placekitten.com/g/500/500);">
<div class="ar"></div>
</div>
尝试设置宽度和高度,然后通过媒体查询调整宽度和高度(而不是最大宽度和百分比宽度)。那么您就不应该遇到任何缩放问题。
@media screen and (max-width: 600px){#X IMG{width: 100%}}
这意味着IMG将具有其第一个父对象的全宽。该父元素可能不是X元素。你确定要吗
示例:
<div id='X'>
<div><div><div><div>
<img src=''>
</div></div></div></div>
</div>
如果您试图修复将height:auto;
放在width:100%;
之后的x:y img比率计算width
或height
,并始终使用auto
作为其他属性以保持图像缩放。
- 我是不是一直在为图像标签强制固定图像大小
- 取出图像标签alt:丢失"没有alt-id的图像标签是优选的并且不显示丢失的“;
- Wordpress:如何更改图像标签中的源属性
- 使用jQuery通过更改src属性来设置一个图像标签的动画
- 使用angularjs交换图像标签中的ng-src属性
- 输入类型文件未正确将图像放入图像标签
- IE不喜欢我的输入和图像标签
- 获取输入 IMG 类型的选定图片并加载到图像标签中
- 如何将图像标签插入超链接标签 在 动态使用 jQuery 中
- 更改背景图像标签..什么也没发生
- Chrome扩展程序 - 修复错误无限循环时的图像标签
- 将带有图像标签的 Svg 转换为 PNG
- 在 JavaScript 中为数组的每个对象生成 HTML 中的图像标签
- 单击元素(例如一个或多个图像标签)和相同的函数应在angularjs中调用
- 删除 DOM ready 上的凌乱图像标签并使用 JS 正确设置
- 如何通过JavaScript从HTML内容中获取图像标签的域名
- 如何在javascript中将图像标签打印到Rails资产中
- 将彩色带置于图像/标签+图像/文本对齐方式之上->JavaScript Titanium移动应用程序
- 如何使用JavaScript在每次点击图像时更改图像标签的URL
- 定向地附加图像标签