01
02
03
给body标签指定背景图,这样背景图就可以填充整个浏览器viewport了。其实,该方案对所有的块级容器都可以生效。块级容器的宽高是动态的,那么背景图将自动伸缩,充满整个容器。
css body标签的样式如下:
如果你有一张比较绚烂的图片想做背景,可以这样设置:代码如下:
body{
background:url(img.jpg)
background-position:center
background-repeat:no-repeat
}
但效果很可能会是这样:
图片没有重叠,居中,并且...她太小了,无法占领全部的页面。
很可惜,CSS2中并没有图片全屏拉伸的属性,所以我自己想了个办法。
利用一个DIV层,在里面装载一个IMG标签。然后设置DIV和IMG的大小为100%,并固定到屏幕最底层,这样就实现了完美的拉伸并最大化图片的目的。
首先在Body中加入下面的代码:
代码如下:
<div
id="div1"><img
src="img.jpg"
/></div>
然后加入CSS代码:
div#div1{
position:fixed
top:0
left:0
bottom:0
right:0
z-index:-1
}
div#div1
>
img
{
height:100%
width:100%
border:0
}
最终效果:
拉伸浏览器、调整网页位置后,图片背景图片依然居中全屏:
火狐狸中的效果:
这样,我们实现了固定居中且自动拉伸全屏的背景图片,不过她是一个层,所以当用户在页面空白处右键的时候,显示的就是图片的信息,这可能会让用户感觉不方便。
实际上,火狐的拉伸效果比IE强很多,会自动羽化图片的细节。IE在图像拉伸后的像素点非常难看,所以建议用高分辨的图像作为背景。
新手向,高人请指导,谢谢。
纯css实现不到那个程度,因为,你想象,
在body里放一个div------让这个div无论何时都100%显示(里面要有内容不然显示不了,比如<img>,<p>,他们的长宽参数也设置成100%或者70%等等)-
当浏览器窗口长宽变化时,div和里面的内容总是跟着动的,这能做到(电脑屏幕如果只有800,那网页就会自动变长),但是要注意这绝对满足不了‘全屏’的要求,拉伸了面积,但是字号、边框宽度都是不变的,所以等于是在改变layout。
如果要做这个效果的话(拉伸浏览器、实时拉伸里面的内容使之永远‘全屏’):
在以前多是选择做成一个大的flash,100%的长宽贴在网页上,调一些scale参数(方便),
现在flash变的不那么流行了你可以用javascrip实现(有点麻烦,很少见到这样实现的),
或者html5的canvas能够达到此效果(可惜ie8以下就别想兼容了)