js"无缝"滚动原理(解决IE与"火狐"的差异)

 前几天,因为要做一个图片的无缝滚动,所以上网查了一下资料。发现虽然网上有很多的相关教程,但却没有多少个能说得详细和透彻的,通常都是给出一大段代码让人看得头晕。但没办法,总不能因为一点代码而不却步吧。呵,,

   闲话少说了。首先要介绍一下的是DHTML中的offsetWidth、scrollLeft(我做的是左滚动,所以就以这两个为例,其它方向的都差不多的了)

   offsetWidth简单来就就是对象的宽度,如

这样在js中,document.getElementById("obj").offsetWidth所得到的就是120。

   scrollLeft是对象相对左边的滚动的位置。

  滚动原理:主要是利用js控制包含滚动对象的“外对象”(我都不知该怎样表达了)的scrollLeft来实现。另外配合CSS中overflow:hidden实现陷藏滚动条的效果。具体点说就是:在CSS中,当对象内部的内容超出对象本身的宽度或高度时,可以用overflow来控制是否允许滚动或自动适应(注意:这里是关键。如果不允许滚动,那么什么“无缝”都是空谈的了)。所以我们要滚动一些对象(如几张图片)时,我们就可以在这些对象的外面加上一个比它们总的宽度或高度要小的对象,这样,就可以利用overflow来实现滚动了。

下面是我所画的一个原理图(点击查看大图):

  

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值