|
今天做一个网站的banner轮播,程序里面自带的是自动改变图片的高宽比例达到自适用的目的。 目标想法是控制div宽度100%,图片大小不变,div宽度改变的情况下,图片始终居中显示,然后隐藏掉两边的图片。: t: y2 E `, f, T- i' E
/ b3 G, u- q& @9 i: d4 ~2 e6 ?
实现原理:) f4 L- S( F5 S1 q1 {5 K
固定div的高度为500px,宽度是100%,超出部分隐藏,以达到自适用浏览器宽度的要求。图片控制宽1920px,适用目前大部分电脑屏幕分辨率,然后就是设置margin了,想要他始终居中,就是中心的位置始终不变。在1920px的情况下,图片的中心x轴就是960px。那么在1800px就是900px,相比与标准的1920px宽度,向左移动了60px,只需要margin左边移动-60px即可。
, s' I4 V2 o7 I/ w; O 同理在100%的x轴坐标下,margin-left的值就是50%-960px,代码如下:; n7 t# D) Y' {( R
- <style>" |- ?( J7 c3 D8 b7 [
- #bn {0 h& `9 @0 B" [6 }! b/ h7 C: W6 q. t
- background-color:#FF0000;" r% ^ r' G% s8 O# e& Q
- width: 100%;
. c) c/ F: z u1 g8 R. i+ }3 O8 N; N - height:500px; ^. }$ ?8 O+ j- g! t$ z+ s
- overflow: hidden;% J- D0 V% W$ y
- }
0 L: }* d1 v9 Q4 h, D - #bn .img9 N* g9 g7 C: W7 z
- {
! q; _) T. `8 a' ~7 z9 L; c' ^ - width:1920px;- S3 a i* D8 b0 J9 E* h" |
- margin:0 calc(50% - 960px);2 S# L5 Y$ s6 H, n e/ Z3 y- _
- }5 e' w- u5 H& i( H; ^, }0 C" i$ n. c2 F
- </style>& e3 O {) K, n& ~* Y
6 T0 L5 y* G( V- <div id="bn"><img src="/image/1.jpg" class="img"/></div>
复制代码 ( C( G: s K! n. |0 S& c) n9 e
: Y* d A8 A: ~& c( e2 `1 B' f |
|