创建一个菜单打开和关闭特效

这篇博客展示了一个HTML菜单的实现,通过JavaScript控制菜单的展开和收起。当鼠标悬停在图片上时,图片会改变,点击图片则会显示或隐藏下级菜单。内容包括CSS样式定义、JavaScript事件监听以及图片切换逻辑。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>开发菜单栏的开启关闭按钮</title>
    <script type="text/javascript" src="$function.js"></script>

    <style>
        #divid{
            width: 100px;
            height: 18px;
            line-height:18px;
        }
        .divclass:hover{
            background:lightskyblue;
        }
        #divid >img{
            width: 10px;
            height: 10px;
        }
        #content{
            width:100px;
            height: 100px;
            /*background: red;*/
        }
        #content #content_in{
            margin-left:10px;
            /*background:skyblue;*/
            display: none;
        }
        .image{
            width: 10px;
            height: 10px;
        }
        
    </style>
</head>
<body>
<div id="divid" class="divclass">
    <img src="images/1.png" id="imageid" class="image">
    我的电脑
</div>
<div id="content">
    <div id="content_in">
        <div class="divclass"><img src="images/1.png" id="imageid1" class="image">系统</div>
        <div class="divclass"><img src="images/1.png" id="imageid2" class="image">软件</div>
        <div class="divclass"><img src="images/1.png" id="imageid3" class="image">文档</div>
        <div class="divclass"><img src="images/1.png" id="imageid4" class="image">娱乐</div>
    </div>
    <div id="divids" class="divclass" >
        <img src="images/1.png" id="imageids" class="image" onclick="clk()">
        我的磁盘
    </div>
</div>

<script>
    //判断这几张图片的点击状态
     $("imageid").onclick = function(){
         /*
          获取点击对象内元素的时候 , 尽量使用event.target.id,不要使用this.id。
          当使用事件委托的时候,this指向的是绑定监听事件的元素,而非被点击的元素。
          event.target.id则始终指向被点击的元素。
          *///event.target.src
         var src = this.getAttribute("src");
        if(src == "images/1.png"){
            this.src = "images/2.png";
        }else if(src == "images/3.png"){
            this.src = "images/4.png";
        }else if(src == "images/2.png"){
            this.src = "images/1.png";
        }else if(src == "images/4.png"){
            this.src = "images/3.png";
        }
         xianshi();
    }
    //点击后调用此方法,使隐藏的下级div块显示出来,再次点击后隐藏
    function xianshi(){
        var a = $("content_in").style.display;
        $("content_in").style.display= "block";
        if(a == "block"){
            $("content_in").style.display= "none";
        }
    }

    //判断鼠标的指针是否在图片之上
    $("imageid").onmouseover = function(){
        var src = this.getAttribute("src");
        if(src == "images/1.png"){
            this.src = "images/3.png";
        }else if(src == "images/2.png"){
            this.src = "images/4.png";
        }
    }

    //判断鼠标的指针是否移开图片
    $("imageid").onmouseout = function(){
        var src = this.getAttribute("src");
        if(src == "images/3.png"){
            this.src = "images/1.png";
        }else if(src == "images/4.png"){
            this.src = "images/2.png";
        }
    }
</script>
</body>
</html>
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值