首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jQuery将鼠标悬停在菜单上并在后面设置位置元素的动画

jQuery将鼠标悬停在菜单上并在后面设置位置元素的动画
EN

Stack Overflow用户
提问于 2011-09-21 00:01:52
回答 1查看 277关注 0票数 1

是否有提供与here相同功能的jQuery等价物?

JavaScript

代码语言:javascript
复制
var menuSlider=function(){
var m,e,g,s,q,i; e=[]; q=8; i=8;
return{
    init:function(j,k){
        m=document.getElementById(j); e=m.getElementsByTagName('li');
        var i,l,w,p; i=0; l=e.length;
        for(i;i<l;i++){
            var c,v; c=e[i]; v=c.value; if(v==1){s=c; w=c.offsetWidth; p=c.offsetLeft}
            c.onmouseover=function(){menuSlider.mo(this)}; c.onmouseout=function(){menuSlider.mo(s)};
        }
        g=document.getElementById(k); g.style.width=w+'px'; g.style.left=p+'px';
    },
    mo:function(d){
        clearInterval(m.tm);
        var el,ew; el=parseInt(d.offsetLeft); ew=parseInt(d.offsetWidth);
        m.tm=setInterval(function(){menuSlider.mv(el,ew)},i);
    },
    mv:function(el,ew){
        var l,w; l=parseInt(g.offsetLeft); w=parseInt(g.offsetWidth);
        if(l!=el||w!=ew){
            if(l!=el){var ld,lr,li; ld=(l>el)?-1:1; lr=Math.abs(el-l); li=(lr<q)?ld*lr:ld*q; g.style.left=(l+li)+'px'}
            if(w!=ew){var wd,wr,wi; wd=(w>ew)?-1:1; wr=Math.abs(ew-w); wi=(wr<q)?wd*wr:wd*q; g.style.width=(w+wi)+'px'}
        }else{clearInterval(m.tm)}
}};}();
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-09-21 00:44:25

这就是我想到的:http://www.gmarwaha.com/blog/2007/08/23/lavalamp-for-jquery-lovers/

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7488183

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档