|
今天做一个网站的banner轮播,程序里面自带的是自动改变图片的高宽比例达到自适用的目的。 目标想法是控制div宽度100%,图片大小不变,div宽度改变的情况下,图片始终居中显示,然后隐藏掉两边的图片。
9 G" ~# K0 c% V, R T; J
1 A, t5 g4 k; s: N 实现原理:2 n$ B& v! `' H1 L8 l" A
固定div的高度为500px,宽度是100%,超出部分隐藏,以达到自适用浏览器宽度的要求。图片控制宽1920px,适用目前大部分电脑屏幕分辨率,然后就是设置margin了,想要他始终居中,就是中心的位置始终不变。在1920px的情况下,图片的中心x轴就是960px。那么在1800px就是900px,相比与标准的1920px宽度,向左移动了60px,只需要margin左边移动-60px即可。
# c2 u4 g9 i1 t! ]( p 同理在100%的x轴坐标下,margin-left的值就是50%-960px,代码如下:* f+ n2 l, h0 B1 m7 d& T r# b
- <style>
9 X' t; _" x2 C$ |3 t0 ^% J - #bn {
0 k7 v/ Y" r2 K2 Q0 P+ K/ P$ m - background-color:#FF0000;; y" u; z/ |2 {, M- |
- width: 100%;4 Q/ {( W9 Q& _* `0 M# e+ g" {% T6 O6 Z
- height:500px;% Q4 r) f5 t- |3 }3 g0 _ Z* W
- overflow: hidden;
: e% F) V( ^" ?7 v) s# k7 I. J - }6 o8 Q3 [0 ]- O6 U; u
- #bn .img6 h* `9 g) ^, K- j, Q
- {/ X8 w( B& f. N* B o$ x
- width:1920px;8 s! U; E6 u4 `$ X5 x1 I* l7 i
- margin:0 calc(50% - 960px);
( c+ i2 b/ D( Y. E2 J) v: m - }
. }2 T8 j2 K5 q; e8 m2 H8 x8 a - </style># Q' y; X& i2 W
& y* Q* k. ~" k. e w1 y: [- <div id="bn"><img src="/image/1.jpg" class="img"/></div>
复制代码
: g/ e$ Q# h/ y4 g" n3 R
0 T4 f1 z% a+ R8 L3 @ |
|