首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >优化jQuery代码

优化jQuery代码
EN

Stack Overflow用户
提问于 2011-07-01 04:39:20
回答 4查看 95关注 0票数 1

以下哪种说法更好:

代码语言:javascript
复制
 var active = '-active';
 if ($j('body').hasClass('faqs')) { $j('.faqs-support').toggleClass('faqs-support' + active); }
 if ($j('body').hasClass('cameras')) { $j('.camera-support').toggleClass('camera-support' + active); }
 if ($j('body').hasClass('manuals')) { $j('.manuals-support').toggleClass('manuals-support' + active); }
 if ($j('body').hasClass('downloads')) { $j('.downloads-support').toggleClass('downloads-support' + active); }
EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2011-07-01 04:44:43

这样如何:

代码语言:javascript
复制
$j.each(['faqs', 'cameras', 'manuals', 'downloads'], function(i, e){
  if ($j('body').hasClass(e)) {
    $j('.'+e+'-support').toggleClass(e+'-support-active');
  }
});
票数 2
EN

Stack Overflow用户

发布于 2011-07-01 04:44:12

代码语言:javascript
复制
var $body = $j('body');
var arr = ['faqs', 'cameras', 'manuals', 'downloads'];
$j.each(arr, function(index, item) {
    if($body.hasClass(item)) $j('.' + item + '-support').toggleClass(item + '-support-active');
});

是关于我该怎么写的。不是更短,也不是更有效,而是更清晰。

票数 2
EN

Stack Overflow用户

发布于 2011-07-01 04:46:51

如果这是正文中唯一的类,那么只需获取完整的className,并将其用于DOM选择和.toggleClass()

代码语言:javascript
复制
var body_class = document.body.className + '-support';
$j('.' + body_class).toggleClass(body_class + '-active');

您只需要做一个更改,就是将'.camera-support'更改为'.cameras-support'。(添加“s”。)

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6540849

复制
相关文章

相似问题

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