超酷Javascript拖拽翻页效果,贴出核心代码(附DEMO)

 

超酷Javascript拖拽翻页效果,贴出核心代码。。。

 

最近在 合肥网
http://bbs.wehefei.com/
进行开发的过程用到这个非常酷的特效,也算是分享下吧。

 


 

 

ExpandedBlockStart.gif 代码
< script >
function  id(obj){
        
return  document.getElementById(obj);
}
var  page;
var  lm,mx;
var  md = false ;
var  sh = 0 ;
var  en = false ;
window.onload
= function (){
        page
= document.getElementsByTagName( " div " );
        
if (page.length > 0 ){
                page[
0 ].style.zIndex = 2 ;
        }
        
for (i = 0 ;i < page.length;i ++ ){
                page[i].className
= " page " ;
                page[i].innerHTML
+= " <span class=tip>第  " + (i + 1 ) + " / " + page.length + "  页 提示:左右拖拽翻页</span> " ;
                page[i].id
= " page " + i;
                page[i].i
= i;
                page[i].onmousedown
= function (e){
                        
if ( ! en){
                                
if ( ! e){e = e || window.event;}
                                lm
= this .offsetLeft;
                                mx
= (e.pageX) ? e.pageX:e.x;
                                
this .style.cursor = " w-resize " ;
                                md
= true ;
                                
if (document.all){
                                        
this .setCapture();
                                }
else {
                                        window.captureEvents(Event.MOUSEMOVE
| Event.MOUSEUP);
                                }
                        }
                }
                page[i].onmousemove
= function (e){
                        
if (md){
                                en
= true ;
                                
if ( ! e){e = e || window.event;}
                                
var  ex = (e.pageX) ? e.pageX:e.x;
                                
this .style.left = ex - (mx - lm) + 350 ;   
                                
                                
if ( this .offsetLeft < 75 ){
                                        
var  cu = ( this .i == 0 ) ? page.length - 1 : this .i - 1 ;
                                        page[sh].style.zIndex
= 0 ;
                                        page[cu].style.zIndex
= 1 ;
                                        
this .style.zIndex = 2 ;
                                        sh
= cu;
                                }
                                
if ( this .offsetLeft > 75 ){
                                        
var  cu = ( this .i == page.length - 1 ) ? 0 : this .i + 1 ;
                                        page[sh].style.zIndex
= 0 ;
                                        page[cu].style.zIndex
= 1 ;
                                        
this .style.zIndex = 2 ;
                                        sh
= cu;
                                }                 
                        }
                }
                page[i].onmouseup
= function (){
                        
this .style.cursor = " default " ;
                        md
= false ;
                        
if (document.all){
                                
this .releaseCapture();
                        }
else {
                                window.releaseEvents(Event.MOUSEMOVE
| Event.MOUSEUP);
                        }
                        flyout(
this );
                }
        }
}
function  flyout(obj){
        
if (obj.offsetLeft < 75 ){
                
if (                (obj.offsetLeft  +   350   -   20 )         >          - 275         ){
                        obj.style.left
= obj.offsetLeft  +   350   -   20 ;
                        window.setTimeout(
" flyout(id(' " + obj.id + " ')); " , 0 );
                }
else {
                        obj.style.left
=- 275 ;
                        obj.style.zIndex
= 0 ;
                        flyin(id(obj.id));
                }
        }
        
if (obj.offsetLeft > 75 ){
                
if (                (obj.offsetLeft  +   350   +   20 )         <          1125         ){
                        obj.style.left
= obj.offsetLeft  +   350   +   20 ;
                        window.setTimeout(
" flyout(id(' " + obj.id + " ')); " , 0 );
                }
else {
                        obj.style.left
= 1125 ;
                        obj.style.zIndex
= 0 ;
                        flyin(id(obj.id));
                }
        }
}
function  flyin(obj){
        
if (obj.offsetLeft < 75 ){
                
if (                (obj.offsetLeft  +   350   +   20 )         <          425                 ){
                        obj.style.left
= obj.offsetLeft  +   350   +   20 ;
                        window.setTimeout(
" flyin(id(' " + obj.id + " ')); " , 0 );
                }
else {
                        obj.style.left
= 425 ;
                        en
= false ;
                }
        }
        
if (obj.offsetLeft > 75 ){
                
if (                (obj.offsetLeft  +   350   -   20 )         >          425                 ){
                        obj.style.left
= obj.offsetLeft  +   350   -   20 ;
                        window.setTimeout(
" flyin(id(' " + obj.id + " ')); " , 0 );
                }
else {
                        obj.style.left
= 425 ;
                        en
= false ;
                }
        }
}
< / script>


 附DEMO,及下载地址:合肥网Labs

 欢迎进行交流,呵呵。。

转载于:https://www.cnblogs.com/jincon/archive/2011/02/13/1952937.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值