最简单的图像预装载办法是使用javascript新建一个新的Image()对象,然后将希望预装载的图片URL传递给此对象。假设我们拥有一个名为/images/NullPic.gif的图片文件,我们希望当用户鼠标指针移动到一张已有的图片上时显示此文件。为了能更快的对此文件进行预装载,我们简单的创建了一个名为heavyImage的新Image() 对象,然后将其通过onLoad()事件句柄同步装载到页面上。
html
head
script language = "JavaScript"
function preloader()
{
heavyImage = new Image();
heavyImage.src = "/images/NullPic.gif";
}
/script
/head
body
a href="#"
img name="img01" src="/images/NullPic.gif"/a
/body
/html
注意,图片的标签(tag)本身并不处理onMouseOver()以及onMouseOut()事件,这也正是上面示例中的img标签被包括在a标签中的原因。标签a则包括了对这些事件类型的支持。
通过数组(arrays)装载多个图片
在实际情况中,你很有可能需要预装载不止一张的图片;比如,对于包括多个图片的菜单条,或者希望实现平滑的动画效果。要实现这些并不困难,只需要利用JavaScript的数组,如下例所示:
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)script language="JavaScript"
function preloader()
{
// counter
var i = 0;
// create object
imageObj = new Image();
// set image list
images = new Array();
images[0]="image1.jpg"
images[1]="image2.jpg"
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)images[2]="image3.jpg"
images[3]="image4.jpg"
// start preloading
for(i=0; i=3; i++)
{
imageObj.src=images[i];
}
}
/script
在上面的例子中,定义了变量i以及名为imageObj的Image()对象。然后定义了新数组images[],每一个数组元素将存储需要预装载图片的地址d
function imagesLoaded()
{
document.location.href='index2.html';
}
/script
/head
body
Please wait, loading images...
/body
/html
当然,你也可以创建一个图片数组,然后循环,对每个元素进行预装载,然后跟踪每个阶段所装载的图片数量。一旦所有的图片都被装载,可以对事件句柄编程,以将浏览器带入下一个阶段(或完成其他的任务)。
预装载和多状态(Multi-State)菜单
现在,如何将刚刚学习到的所有理论知识应用到实际的应用程序中?下面是一段我最近编写的代码——一个包括按钮(图片链接)的菜单条,每一个按钮都可能处于三种状态中的一种:正常、鼠标悬浮和单击。由于按钮具有多种状态,所以必须使用图片预装载来确保菜单能足够快的对状态改变进行响应。列表A中的代码显示了如何实现此功能:
列表A中的HTML代码建立了一个包括四个按钮的菜单条,每一个按钮都有三种状态:正常、鼠标悬浮和单击。触发条件如下:
鼠标指针移动到处于正常状态的按钮,按钮则变为鼠标悬浮状态。鼠标移出按钮区域之后,按钮返回到正常状态。
鼠标单击按钮,按钮则变为单击状态。在另一按钮被单击之前,它将保持在此状态。
如果单击了某个按钮,其他任何按钮不能处于单击状态,只能是处于鼠标悬浮或正常状态。
每次只能单击一个按钮。
每次只能有一个按钮处于鼠标悬浮状态。
首要任务是设置存储菜单每种状态图片的数组。数组元素相应的元素img同样在HTML文档主体中创建,并且按照顺序命名。请注意,数组值的索引序列是从0开始,而相应的img元素则从1开始命名——这就要求在脚本的后半段要对相应数值作运算调整。
函数preloadImages()负责将所有图片装载到缓存中,因此留给鼠标的响应时间就会很少。循环for()被用来在第一阶段重复完成图片创建操作,并随后对每个图片进行预装载。
函数resetAll()是将所有图片重置为正常状态的非常方便的方法。这是必需的,因为当菜单上某个按钮被单击的时候,菜单上面其他所有按钮在被单击按钮改变状态前必须恢复到正常状态。
函数setNormal()、setHover()以及setClick()负责将特定图像(图像编号将作为函数参数传递)的图片源改变为相应正常、鼠标悬浮或单击状态的图片源。由于被单击的图像在另一图像被单击之前必须保持状态(参考规则#2),因此被单击图片将暂不接受鼠标动作。函数setNormal()以及setHover()代码仅完成图片不在单击状态的情况下改变图片状态的动作。
以上只是通过使用预装载技术加速JavaScript效果响应多种办法中的一种。在站点中可以使用以上技术,并且根据实际情况进行调整。祝一切顺利!