首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有ID和Hover的Jquery增量函数

带有ID和Hover的Jquery增量函数
EN

Stack Overflow用户
提问于 2021-11-12 10:43:11
回答 2查看 42关注 0票数 1

我如何才能在不重复每次相同代码的情况下编写下面的函数。谢谢你的帮助。

代码语言:javascript
复制
        $("#zone-1").hover(function(){
            $("#projects-1").addClass('visible');
        }, function(){
            $("#projects-1").removeClass('visible');
        });

        $("#zone-2").hover(function(){
            $("#projects-2").addClass('visible');
        }, function(){
            $("#projects-2").removeClass('visible');
        });

        $("#zone-3").hover(function(){
            $("#projects-3").addClass('visible');
        }, function(){
            $("#projects-3").removeClass('visible');
        });                     

        $("#zone-4").hover(function(){
            $("#projects-4").addClass('visible');
        }, function(){
            $("#projects-4").removeClass('visible');
        });
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-11-12 10:54:28

使用https://api.jquery.com/attribute-starts-with-selector/获取起始属性值类似的元素:"zone-“。然后使用$(this).attr('id');获取当前悬停元素的id

最后,用分隔符"-“分割id,然后得到这个数组的第二个元素"[1]”。https://www.w3schools.com/jsref/jsref_split.asp

最好使用toggleClass():https://api.jquery.com/toggleclass/,因为您更改的类名是相同的。

代码语言:javascript
复制
$("div[id^='zone-']").hover(function(){
   // current id number
  let getDivID = $(this).attr('id').split('-')[1];
  $("#projects-" + getDivID).toggleClass('visible');
  
  // debug infos
  console.clear();
  console.log(getDivID);
});
代码语言:javascript
复制
.projects { display:none }
.visible { display:block }
代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div id="zone-1">zone-1</div>
<div id="zone-2">zone-2</div>
<br><br>
<div id="projects-1" class="projects">projects-1</div>
<div id="projects-2" class="projects">projects-2</div>

票数 0
EN

Stack Overflow用户

发布于 2021-11-12 10:59:32

正如@connexo所建议的,您可以使用类而不是ids。

这段代码可能需要一些调整,因为您没有提供HTML。

代码语言:javascript
复制
$(".zone").hover(function(){
    $(this).next(".projects").addClass("visible");
}, function() {
    $(this).next(".projects").removeClass("visible");
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69941618

复制
相关文章

相似问题

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