西西木科技丨Shopify开发机构 2023-01-31 18:47 采纳率: 96.4%
浏览 24
已结题

使用js和jq无法切换display效果

使用js和jq无法切换display效果,但是用alert有获取到div的display


<li>
<botton class="social-custom" style="cursor:pointer;" onclick="openwechat()">
   <img src="//cdn.shopify.com/s/files/1/0520/6396/1266/files/wechat.png?v=1675139232">
</botton>
</li>

<div id="wechatdiv" style="display:none;">
<botton style="cursor:pointer;" onclick="closewechat()"><img src="https://img.icons8.com/material-outlined/15/null/delete-sign.png"></botton>
<img src="//cdn.shopify.com/shopifycloud/shopify/assets/no-image-100-c91dd4bdb56513f2cbf4fc15436ca35e9d4ecd014546c8d421b1aece861dfecf_small.gif"></div>

<script>
 
      function openwechat(){
        var showWechat = document.getElementById("wechatdiv").style.display;
        if (showWechat = "none") {
                document.getElementById("wechatdiv").style.display = "block";
        } else {
                document.getElementById("wechatdiv").style.display = "none";
        }
    }

      function closewechat(){
        var showWechat = document.getElementById("wechatdiv").style.display;
        if (showWechat = "block") {
                document.getElementById("wechatdiv").style.display = "none";
        }
    }
  
</script>
  • 写回答

4条回答 默认 最新

  • CSDN专家-showbo 2023-01-31 20:29
    关注

    页面上出现了2个id为wechatdiv的容器,首先出现的是页头移动端的,然后才是页脚的wechatdiv,而document.getElementById("wechatdiv")只会得到第一个出现(就是页头的wechatdiv),而页头的wechatdiv的容器只有在移动端并且展开菜单后才会显示。所以pc端点击页脚的openwechat实际控制的移动端的openwechat,导致页脚的wechatdiv无法显示。

    改为属性选择,函数改成下面即可

    
        function openwechat() {
            var els = document.querySelectorAll('div[id="wechatdiv"]');//改为属性选择器
            for (var el of els) el.style.display = el.style.display == 'block' ? 'none' : 'block';
        }
    
        function closewechat() {
            //因为是关闭,不需要再判断了
            var els = document.querySelectorAll('div[id="wechatdiv"]');//改为属性选择器
            for (var el of els) el.style.display = 'none' ;
        }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 2月8日
  • 已采纳回答 1月31日
  • 创建了问题 1月31日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵