为了账号安全,请及时绑定邮箱和手机立即绑定

this.time 评论里面找不到答案T T

问题1:this.time是个什么东西。。。发现可以用变量(var active)代替,但是页面效果不好。

time是属性吗。。。根本搜不到资料T T

代码中我把关键的this.time标出来了。

问题2:猜测两次的that,That不同,前面有一个赋值 var That=that;感觉两次的that是不同的对象

不知道想的对不对。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>导航菜单</title>
<style type="text/css">
* { margin: 0; padding: 0; font-size: 14px; }
a { color: #333; text-decoration: none }
ul { list-style: none; height: 30px; border-bottom: 5px solid #F60; margin-top: 20px; padding-left: 50px; }
ul li { float: left }
ul li a { display: block; height: 30px; text-align: center; line-height: 30px; width:120px; background: #efefef; margin-left: 1px; }
a.on, a:hover { background: #F60; color: #fff; }
</style>
<script>
window.onload=function(){
    var aA=document.getElementsByTagName('a');
    for(var i=0; i<aA.length; i++){
        aA[i].onmouseover=function(){
            var This=this;
            clearInterval(This.time);
            This.time=setInterval(function(){
                    This.style.width=This.offsetWidth+8+"px";
                    if(parseInt(This.style.width)>=160)
                    
                    clearInterval(This.time);
                },30)
        }
        aA[i].onmouseout=function(){
                clearInterval(this.time);
                var This=this;
                this.time=setInterval(function(){
                    This.style.width=This.offsetWidth-8+"px";
                    if(This.offsetWidth<=120){
                        This.style.width='120px';
                        clearInterval(This.time);
                    }
                },30)
        }
    }
}
</script>
</head>
<body>
<ul>
    <li><a class="on" href="#">首  页</a></li>
    <li><a href="#">新闻快讯</a></li>
<li><a href="#">产品展示</a></li>
    <li><a href="#">售后服务</a></li>
    <li><a href="#">联系我们</a></li>
</ul>
</body>
</html>

正在回答

2 回答

time是一个变量名,一般定义计时器的时候大多用 time 或者 timer,This = this;这个This就是this指针,鼠标滑动到哪一个块上 这个this就指向哪个块,也就代表着这个块;整体的意思就是  我的鼠标现在滑到  新闻快讯  这个块上了,那么this就指向这个块,然后这个块就执行定义好的动画内容,当鼠标指针离开这个块以后,再去执行定义好的离开的动画 

0 回复 有任何疑惑可以回复我~
!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>导航菜单</title>
<style type="text/css">
* { margin: 0; padding: 0; font-size: 14px; }
a { color: #333; text-decoration: none }
ul { list-style: none; height: 30px; border-bottom: 5px solid #F60; margin-top: 20px; padding-left: 50px; }
ul li { float: left }
ul li a { display: block; height: 30px; text-align: center; line-height: 30px; width:120px; background: #efefef; margin-left: 1px; }
a.on, a:hover { background: #F60; color: #fff; }
</style>
<script>
window.onload=function(){
    var aA=document.getElementsByTagName('a');
    for(var i=0; i<aA.length; i++){
        aA[i].onmouseover=function(){
            var This=this;
           /* clearInterval(This.time);*/
            This.time=setInterval(function(){
                    This.style.width=This.offsetWidth+8+"px";
                    if(parseInt(This.style.width)>=160)
                    
                    clearInterval(This.time);
                },30)
        }
        aA[i].onmouseout=function(){
                clearInterval(this.time);
                var This=this;
                this.time=setInterval(function(){
                    This.style.width=This.offsetWidth-8+"px";
                    if(This.offsetWidth<=120){
                        This.style.width='120px';
                        clearInterval(This.time);
                    }
                },30)
        }
    }
}
</script>
</head>
<body>
<ul>
    <li><a class="on" href="#">首  页</a></li>
    <li><a href="#">新闻快讯</a></li>
<li><a href="#">产品展示</a></li>
    <li><a href="#">售后服务</a></li>
    <li><a href="#">联系我们</a></li>
</ul>
</body>
</html>


0 回复 有任何疑惑可以回复我~
#1

别动我的猫 提问者

问题1:this.time是个什么东西。。。发现可以用变量(var active)代替,但是页面效果不好。 time是属性吗。。。根本搜不到资料T T 代码中我把关键的this.time标出来了。 问题2:猜测两次的that,That不同,前面有一个赋值 var That=that;感觉两次的that是不同的对象 不知道想的对不对。
2017-10-15 回复 有任何疑惑可以回复我~
#2

叫我yang

不好意思下面那个t忘了大写
2017-10-17 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
导航条菜单的制作
  • 参与学习       123899    人
  • 解答问题       813    个

水平、垂直、圆角导航条菜单,让您的技术探索之路更高效

进入课程

this.time 评论里面找不到答案T T

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信