【问题标题】:Is it possible to use responsive image technic technique for height and width together?是否可以将响应式图像技术技术用于高度和宽度?
【发布时间】:2015-05-01 07:23:10
【问题描述】:

我有一个宽度为 20% 的 li 元素;高度取决于视口。在小屏幕上我想要更大的高度。在里面我有一个响应的图像。问题是当我降低 li 元素的高度时,图像不会缩小。我想一起调整宽度和高度。代码笔:http://codepen.io/anon/pen/QbbOrb

 *, *:before, *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

ul {
  list-style:none;
  margin:0;
  padding:0;
}

li {
  width:20%;
  height:100px;
  display: inline-block;
  background: lightblue;
  padding: 15px;
}

img {
  max-width:100%;
  height:auto;
  display:block;
}

HTML

<ul>
  <li><div><img src="http://lorempixel.com/1450/600/"></div></li>
</ul>

【问题讨论】:

  • 您知道它确实在工作,只是图像本身无法正确调整到 li 的高度而不会丢失它的比例。

标签: html css responsive-design


【解决方案1】:

实际上,您可以使用另一种方法来缩放图像而不会丢失纵横比,方法是将li 的背景设置为使用图像,然后通过使用background-position:center centerbackground-size:cover 来适应“响应性”:

Demo Fiddle

*,
*:before,
*:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
li {
  width: 20%;
  height: 100px;
  display: inline-block;
  border: 15px solid lightblue;
  background-size: cover;
  background-position: center center;
}
<ul>
  <li style="background-image:url(http://lorempixel.com/1450/600/);"></li>
</ul>

【讨论】:

  • 是的,我知道这样,但是可以使用图像而不是背景图像吗?
  • 我添加了最大宽度和最大高度,看起来不错,但在 Firefox 中容器比图像大。 (我去掉了 li 的 20%)codepen.io/anon/pen/mJJqzo你知道为什么会这样吗?
【解决方案2】:

如果你这样做,它会按照你想要的方式工作。

li {
  width:20%;
  display: inline-block;
  background: green;
  padding: 15px;
}

img {
  max-width:100%;
}

【讨论】:

  • 我需要指定高度。你有固定高度的想法吗?
  • @user1452062 如果您希望图像具有响应性,则不能有固定的高度。
  • 我可以给容器固定高度,img会缩小。
猜你喜欢
  • 2012-09-29
  • 2018-07-27
  • 1970-01-01
  • 1970-01-01
  • 2020-05-26
  • 2013-07-28
  • 1970-01-01
  • 2014-05-16
  • 1970-01-01
相关资源
最近更新 更多