搜索
查看: 13683|回复: 0

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

[复制链接]
发表于 2020-4-27 11:51:31 | 显示全部楼层 |阅读模式
  今天做一个网站的banner轮播,程序里面自带的是自动改变图片的高宽比例达到自适用的目的。  目标想法是控制div宽度100%,图片大小不变,div宽度改变的情况下,图片始终居中显示,然后隐藏掉两边的图片。5 H1 A' A  S6 _! j; t
. t0 @' |  T% e4 D/ F: o3 D; ?
  实现原理:8 B. Y  l: a0 ]2 c# A
  固定div的高度为500px,宽度是100%,超出部分隐藏,以达到自适用浏览器宽度的要求。图片控制宽1920px,适用目前大部分电脑屏幕分辨率,然后就是设置margin了,想要他始终居中,就是中心的位置始终不变。在1920px的情况下,图片的中心x轴就是960px。那么在1800px就是900px,相比与标准的1920px宽度,向左移动了60px,只需要margin左边移动-60px即可。
" l9 T0 ]7 @0 {( v+ Y' b4 \" a' f  同理在100%的x轴坐标下,margin-left的值就是50%-960px,代码如下:2 p) _0 I5 j$ J/ h( I
  1. <style>6 F% H) P$ n+ M) b& l9 k
  2. #bn {0 m% J3 I' ^; x. G
  3.   background-color:#FF0000;
    3 n  r  E# i! m7 u
  4.   width: 100%;- [# k" S; W, ?$ t+ k9 }
  5.   height:500px;% |/ K' P' M0 x; Z# a# r
  6.   overflow: hidden;
    0 g6 q3 O% ]% G* w+ C2 z
  7. }0 t  g. M& y, \- T* d
  8. #bn .img
    + Y6 M" G4 v$ o
  9. {! ?$ i3 i/ |2 v/ W5 `, c; _
  10.   width:1920px;8 n9 ?, y# S0 o
  11.   margin:0 calc(50% - 960px);
    ! ?- D9 t1 e  [9 D
  12. }
    0 i2 f3 u$ Z) `2 s
  13. </style>
    + h( [' g) W% w* D! M7 k8 x; N- Z
  14. / w; X; _! I3 s$ m( |
  15. <div id="bn"><img src="/image/1.jpg" class="img"/></div>
复制代码
) L/ C8 G& ]/ G* Z
0 D6 g  ]( X* Y3 b9 P
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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