首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JQuery效率需要让我的代码变得更好并学习

JQuery效率需要让我的代码变得更好并学习
EN

Stack Overflow用户
提问于 2012-06-05 16:55:44
回答 3查看 62关注 0票数 4

我有下面的代码,它做了我想要的,但我知道这是一个糟糕的方式来纠正它。我如何才能完成相同的事情,而不必为每一组项目复制代码。任何帮助都将不胜感激。

代码语言:javascript
复制
<script type="text/javascript">
$('#plink-1').click(function() {
    $('.active').slideUp().removeClass('active');
    $('#pshow-1').slideToggle().addClass('active');
});
$('#plink-2').click(function() {
    $('.active').slideUp().removeClass('active');
    $('#pshow-2').slideToggle().addClass('active');
});
$('#plink-3').click(function() {
    $('.active').slideUp().removeClass('active');
    $('#pshow-3').slideToggle().addClass('active');
});
$('#plink-4').click(function() {
    $('.active').slideUp().removeClass('active');
    $('#pshow-4').slideToggle().addClass('active');
});

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-06-05 16:56:53

代码语言:javascript
复制
$('#plink-1, #plink-2, #plink-3, #plink-4').click(function() {
    var index = this.id.replace('plink-','');  // will give you ->  1,2,..
    $('.active').slideUp().removeClass('active');
    $('#pshow-' + index).slideToggle().addClass('active');
});
票数 3
EN

Stack Overflow用户

发布于 2012-06-05 17:30:03

这应该是可行的:

代码语言:javascript
复制
$('a[id^="plink-"]').click(function() {
    $('.active').slideUp().removeClass('active');
    $('#pshow-' + $(this).prop('id').replace('plink-','')).slideToggle().addClass('active');   
})

使用此代码,您将不需要在添加或删除plink时更新jquery代码

票数 1
EN

Stack Overflow用户

发布于 2012-06-05 22:58:36

谢谢你的精彩回答,你让我的思路变得正确。根据我在CSS中创建的内容,我最终使用了以下函数。仍然在调整一些动画等,但它工作得很好。谢谢!

代码语言:javascript
复制
$('.pitem a').each(function(i) {
    $(this).click(function() {
        $('html, body').animate({ scrollTop: 0 }, 150);
        $('#portfolios').find('.active').fadeOut(500).removeClass('active');
        $('#portfolios').find('#pshow-'+i).fadeIn(500).addClass('active');
    });
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10894307

复制
相关文章

相似问题

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