CSDM-WX 2022-01-04 11:20 采纳率: 33.3%
浏览 54
已结题

怎么改变一级菜单后面的+-符号?

<style>
    /* 加符号图片网址:"https://cdn.shopify.com/s/files/1/0569/4033/1217/t/17/assets/plus.png?v=16347368933442517759";
减符号图片网址:"https://cdn.shopify.com/s/files/1/0569/4033/1217/t/17/assets/minus.png?v=7518117718403207514"; */
    .menu {
        background-color: rgb(110, 225, 240);
        height: 26px;
        font-size: 18px
    }

    /* 显示 */
    .show {
        display: block;
    }

    /* 隐藏 */
    .hidden {
        display: none;
    }

    div {
        padding: 1px;
    }

    span {
        float: right
    }
</style>
<div id="menuContainer">

    <div>
        <!-- 一级菜单 -->
        <!-- 添加onclick事件 -->
        <div class="menu" onclick="subMenuChangStat(1);">
            财务管理<span position:right><img
                    src="https://cdn.shopify.com/s/files/1/0569/4033/1217/t/17/assets/plus.png?v=16347368933442517759"
                    alt="" class="hamburger" id="image" onclick="changeImage()"></span>
        </div>
        <!-- 二级菜单内容 -->
        <p id="subMenu1" class="hidden">财务管理展开内容。财务管理展开内容。财务管理展开内容。财务管理展开内容。财务管理展开内容。财务管理展开内容。财务管理展开内容。</p>
    </div>

    <div>
        <!-- 一级菜单 -->
        <div class="menu" onclick="subMenuChangStat(2);">财务报表<span position:right><img
                    src="https://cdn.shopify.com/s/files/1/0569/4033/1217/t/17/assets/plus.png?v=16347368933442517759"
                    alt="" class="hamburger" id="image" onclick="changeImage()"></span>
        </div>
        <!-- 二级菜单内容 -->
        <p id="subMenu2" class="hidden">财务报表展开内容。财务报表展开内容。财务报表展开内容。财务报表展开内容。财务报表展开内容。
        </p>
    </div>

    <div>
        <!-- 一级菜单 -->
        <div class="menu" onclick="subMenuChangStat(3);">仓库管理<span position:right><img
                    src="https://cdn.shopify.com/s/files/1/0569/4033/1217/t/17/assets/plus.png?v=16347368933442517759"
                    alt="" class="hamburger" id="image" onclick="changeImage()"></span></div>
        <!-- 二级菜单内容 -->
        <p id="subMenu3" class="hidden">
            仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。
        </p>
    </div>

</div>
  • 写回答

1条回答 默认 最新

  • CSDN专家-showbo 2022-01-04 11:54
    关注

    调用changeImage时传递this(当前点击的dom元素)作为参数,然后获取当前img的src属性判断后修改下src就行了。

    不过题主应该只需要subMenuChangStat一个处理函数就行了,不要同时添加2个事件,然后通过关系获取对应的dom对象进行操作

    img

        <style >
        /* 加符号图片网址:"https://cdn.shopify.com/s/files/1/0569/4033/1217/t/17/assets/plus.png?v=16347368933442517759";
        减符号图片网址:   "https://cdn.shopify.com/s/files/1/0569/4033/1217/t/17/assets/minus.png?v=7518117718403207514"; */
        .menu {
            background-color: rgb(110, 225, 240);
            height: 26px;
            font-size: 18px
        }
        /* 显示 */
        .show {
            display: block;
        }
        /* 隐藏 */
        .hidden {
            display: none;
        }
    
        div {
            padding: 1px;
        }
    
        span {
            float: right
        }
    </style>
    <div id="menuContainer">
        <div>
            <!-- 一级菜单 -->
            <!-- 添加onclick事件 -->
            <div class="menu" onclick="subMenuChangStat(this);">
                财务管理<span position:right>
                    <img src="https://cdn.shopify.com/s/files/1/0569/4033/1217/t/17/assets/plus.png?v=16347368933442517759"
                         alt="" class="hamburger" id="image">
                </span>
            </div>
            <!-- 二级菜单内容 -->
            <p id="subMenu1" class="hidden">财务管理展开内容。财务管理展开内容。财务管理展开内容。财务管理展开内容。财务管理展开内容。财务管理展开内容。财务管理展开内容。</p>
        </div>
        <div>
            <!-- 一级菜单 -->
            <div class="menu" onclick="subMenuChangStat(this);">
                财务报表<span position:right>
                    <img src="https://cdn.shopify.com/s/files/1/0569/4033/1217/t/17/assets/plus.png?v=16347368933442517759"
                         alt="" class="hamburger" id="image">
                </span>
            </div>
            <!-- 二级菜单内容 -->
            <p id="subMenu2" class="hidden">
                财务报表展开内容。财务报表展开内容。财务报表展开内容。财务报表展开内容。财务报表展开内容。
            </p>
        </div>
        <div>
            <!-- 一级菜单 -->
            <div class="menu" onclick="subMenuChangStat(this);">
                仓库管理<span position:right>
                    <img src="https://cdn.shopify.com/s/files/1/0569/4033/1217/t/17/assets/plus.png?v=16347368933442517759"
                         alt="" class="hamburger" id="image">
                </span>
            </div>
            <!-- 二级菜单内容 -->
            <p id="subMenu3" class="hidden">
                仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。仓库管理展开内容。
            </p>
        </div>
    </div>
    <script>
        function subMenuChangStat(el) {
            var img = el.querySelector('img'),//获取图片对象
                menu = el.parentNode.querySelector('p'),//获取子菜单
                plused = img.src.indexOf('plus.png') == -1;
            img.src = `https://cdn.shopify.com/s/files/1/0569/4033/1217/t/17/assets/${plused ? 'plus' : 'minus'}.png`;
    
            menu.classList[plused ? 'add' : 'remove']('hidden')
        }
    
    </script>
    

    img


    有其他问题可以继续交流~

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 1月12日
  • 已采纳回答 1月4日
  • 创建了问题 1月4日

悬赏问题

  • ¥15 请问有用MZmine处理 “Waters SYNAPT G2-Si QTOF质谱仪在MSE模式下采集的非靶向数据” 的分析教程吗
  • ¥50 opencv4nodejs 如何安装
  • ¥15 adb push异常 adb: error: 1409-byte write failed: Invalid argument
  • ¥15 nginx反向代理获取ip,java获取真实ip
  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥15 复杂网络,变滞后传递熵,FDA
  • ¥20 csv格式数据集预处理及模型选择