搜索
查看: 9715|回复: 0

[网站] 图片宽度超出div,css控制图片不改变原大小情况居中显示,图片超出div部分隐藏

[复制链接]
发表于 2020-4-27 11:51:31 | 显示全部楼层 |阅读模式
  今天做一个网站的banner轮播,程序里面自带的是自动改变图片的高宽比例达到自适用的目的。  目标想法是控制div宽度100%,图片大小不变,div宽度改变的情况下,图片始终居中显示,然后隐藏掉两边的图片。7 P+ l" g  s9 _4 A, L
1 j. Y) n4 C5 e
  实现原理:! i# A% ?* F) r" L
  固定div的高度为500px,宽度是100%,超出部分隐藏,以达到自适用浏览器宽度的要求。图片控制宽1920px,适用目前大部分电脑屏幕分辨率,然后就是设置margin了,想要他始终居中,就是中心的位置始终不变。在1920px的情况下,图片的中心x轴就是960px。那么在1800px就是900px,相比与标准的1920px宽度,向左移动了60px,只需要margin左边移动-60px即可。
! H# S& j1 C5 v' ]' a5 _  同理在100%的x轴坐标下,margin-left的值就是50%-960px,代码如下:
. w( Y8 Z2 d3 X) R
  1. <style>5 L& I- h1 t6 z- t  \  S4 P
  2. #bn {
      h3 n! {0 w1 n% C! w: `& n
  3.   background-color:#FF0000;6 p  y4 C; X# Y8 Q0 A0 I4 v4 D
  4.   width: 100%;
    % \/ [0 q9 e9 P7 _" e) p- A
  5.   height:500px;9 S1 y# y: q$ D
  6.   overflow: hidden;
    7 {2 Z  g$ _6 N( _2 |" H, ]- T. B
  7. }# ~( e* N0 y: g" H' W
  8. #bn .img
    7 s3 Y6 ^& X( K3 U
  9. {
    0 U3 u+ Q# Z! u+ U
  10.   width:1920px;
    , W% g* I/ g; h6 l7 E
  11.   margin:0 calc(50% - 960px);; x* i8 [2 B* _) G, J7 ~
  12. }! g% f% K# _0 p
  13. </style>
    $ ?2 |+ z- _' ~7 |

  14. % b" ^- P* ~! s% L
  15. <div id="bn"><img src="/image/1.jpg" class="img"/></div>
复制代码

! c/ P1 ~8 T& ~4 U5 n# `% w6 v( y9 i3 \4 z( Z1 r5 o$ [
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册帐号

本版积分规则

热议作品
精华帖子排行
精彩推荐

虾皮社区,成立十年了!

站长自己也搞不懂想做个什么,反正就是一直在努力的做!

Copyright © 2007-2019 xp6.org Powered by Discuz

QQ|Archiver|手机版|小黑屋|虾皮社区 鲁公网安备 37021102000261号 |网站地图
返回顶部 返回列表