当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > 用CSS实现网页图片的预加载

CSS样式表
正确地利用css改进网站设计的3个技巧
CSS网页设计 把HTML标记分类
几个Reset CSS的八卦问题
css 网页虚线制作方法剖析
网页制作小技巧 dl dt dd标签用法
玩转CSS3色彩
RGBa色彩的浏览器支持分析
WEB标准心得之网页重构的思路
学习web标准的十个重要理由总结
CSS 星级评价效果代码
ie6 fixed bug的解决方法 (css+js)
html pre标签使文本自动换行
CSS word-wrap同word-break的区别
css 入门基础教程
IE7或者IE8全屏解决方案
JavaScript CSS Style属性对照表
优秀设计和卓越设计之间的细微区别
CSS教程:容易忽略的但是很熟悉的CSS属性
通过语义化的标签减少DIV简化网页代码
html和css实现数据图表的展示效果

CSS样式表 中的 用CSS实现网页图片的预加载


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-03   浏览: 62 ::
收藏到网摘: n/a

有很多种方法来实现图片的预加载,通常大部分使用Javascript让事情滚动。不要再受Javascript预载的束缚了吧,用CSS你就可以毫不麻烦的预载你的图片。

为什么使用预载

你为什么会考虑使用预载呢?你是否曾有个网站,在那个网站你要滚动你的导航然后有个延迟直到图片被加载完……嘿嘿。预载将在这方面帮助你。它将在页面加载的时候加载那些图片并将其存储在浏览器的缓存里面。这样当用户滚动导航的时候,很漂亮而且流畅,没有延迟。

CSS代码

这个概念就是写一个CSS样式设置一批背景图片,然后将其隐藏,这样你就看不到那些图片了。那些背景图片就是你想预载的图片。

这是一个例子:

#preloader {
/* Images you want to preload*/
background-image: url(image1.jpg);
background-image: url(image2.jpg);
background-image: url(image3.jpg);
width: 0px;
height: 0px;
display: inline;
}

这只是一种隐藏你的图片的方法,所以它们不会被显示。我也见到有人使用非常大的background-position值将图片推出去。或者给一个负的margin值。有很多中方法隐藏你要预载的图片,选择最适合你的吧。

另一种情况

有巨大的图片需要下载的情况并不会经常发生,如果你采用通常的做法,提供某种图片正在加载的表示。这里是一些CSS,可以给用户一个提示:图片正在加载。

	img { background: url(loadingHourGlass.gif) no-repeat 50% 50%; }

gif图片可以是动画,类似于mac上的沙滩球或者PC上的沙漏之类的东东。采用一个动画吧,这样用户就会知道事情正在进行。

结论

当预载有意义的时候做你最好的吧,你的用户将以此喜欢上你。事实上他们可能并没有注意到,但是这是一件好事情,如果他们注意到你的网站正在加载,那可能真的是太慢了。

查看Demo

PS:我来解释一下这个demo吧。可能原作者没有考虑太多,只是想演示一下预加载的效果,所以这个demo页面做的有些简单:他只是将预载的图片用于a:hover的背景了,这样在鼠标经过的时候,就可以无闪动的现实那张图片。嗯,也就是文中的第二种用法……