百独托管7500 紫田网络超高转化播放器收cps[推荐]速盾CDN 免实名免备防屏蔽阿里云 爆款特卖9.9元封顶提升alexa、IP流量7Q5团队
【腾讯云】中小企福利专场【腾讯云】多款产品1折起高防 随时退换 好耶数据小飞国外网赚带你月入万元炎黄网络4H4G10M 99每月
香港带宽CN2/美国站群优惠中客数据中心 服务器租用联盟系统移动广告平台 中易企业专场腾讯云服务器2.5折九九数据 工信部正规资质
腾讯云新用户大礼包代金券高价收cpa注册量高价展示【腾讯云】2核2G/9.93起租服务器找45互联 随时退换阿里云 短信服务 验证秒达

[闲聊畅谈] 求助,这个JS能不能简化一下。。 [复制链接]
查看:2950 | 回复:6

466

主题

2889

帖子

495

积分

落伍者(一心一意)

Rank: 1

贡献
3551
鲜花
50
注册时间
2009-3-17

QQ绑定

发表于 2014-9-27 00:23:08 | 显示全部楼层 |阅读模式 来自 中国山东济南
109积分
本帖最后由 超鸡 于 2014-9-27 00:30 编辑
//list1
document.querySelector('#list1-s').addEventListener ('click', function () {
  document.querySelector('#list1').className = 'current';
  document.querySelector('[data-position="current"]').className = 'left';
});
document.querySelector('#list1-h').addEventListener ('click', function () {
  document.querySelector('#list1').className = 'right';
  document.querySelector('[data-position="current"]').className = 'current';
});
//list2
document.querySelector('#list2-s').addEventListener ('click', function () {
  document.querySelector('#list2').className = 'current';
  document.querySelector('[data-position="current"]').className = 'left';
});
document.querySelector('#list2-h').addEventListener ('click', function () {
  document.querySelector('#list2').className = 'right';
  document.querySelector('[data-position="current"]').className = 'current';
});
。。。
。。。
。。。
。。。
。。。
。。。
//list20
document.querySelector('#list20-s').addEventListener ('click', function () {
  document.querySelector('#list20').className = 'current';
  document.querySelector('[data-position="current"]').className = 'left';
});
document.querySelector('#list20-h').addEventListener ('click', function () {
  document.querySelector('#list20').className = 'right';
  document.querySelector('[data-position="current"]').className = 'current';
});

监听点击事件的,大约有二十个点击的地方需要监听,点击一是list1,点击二是list2。。。。。一直到list20。


比如:
第一段代码点击list1-s
显示list1,点击list1-h是隐藏list1,
第二段代码点击list2-s是显示list2,点击list2-h是隐藏list2,
。。。
。。。
。。。
。。。
。。。
。。。

第二十段代码点击list20-s是显示list20,点击list20-h是隐藏list20。


如果这二十个每个都写一遍,JS体积就大了,JS代码也是有些规律的,能不能把这二十个写到一段JS里边呢?

回复

使用道具 举报

3155

主题

6万

帖子

5万

积分

落伍者(五谷丰登)

Rank: 8Rank: 8

贡献
2715
鲜花
114
注册时间
2002-1-31
发表于 2014-9-27 00:43:31 | 显示全部楼层 来自 中国北京
用jquery,只需一行
楼下鸡鸡短细软
回复

使用道具 举报

466

主题

2889

帖子

495

积分

落伍者(一心一意)

Rank: 1

贡献
3551
鲜花
50
注册时间
2009-3-17

QQ绑定

 楼主| 发表于 2014-9-27 01:21:28 | 显示全部楼层 来自 中国山东济南
boyXP 发表于 2014-9-27 00:43
用jquery,只需一行

jquery体积更大了…………。
回复

使用道具 举报

头像被屏蔽

295

主题

511

帖子

263

积分

禁言

贡献
531
鲜花
0
注册时间
2013-4-19

落伍手机绑定

发表于 2014-9-27 08:24:12 | 显示全部楼层 来自 中国陕西西安
提示: 作者被禁止或删除 内容自动屏蔽
签名被屏蔽
回复

使用道具 举报

466

主题

2889

帖子

495

积分

落伍者(一心一意)

Rank: 1

贡献
3551
鲜花
50
注册时间
2009-3-17

QQ绑定

 楼主| 发表于 2014-9-27 21:13:50 | 显示全部楼层 来自 中国山东潍坊
顶            
回复

使用道具 举报

115

主题

1225

帖子

907

积分

落伍者(一心一意)

Rank: 1

贡献
1479
鲜花
0
注册时间
2011-12-23
发表于 2014-9-27 21:15:33 | 显示全部楼层 来自 中国河北沧州
代码很复杂,帮顶一下
http://www.hbccq.com/袋式除尘器
http://www.btpenghe.com.cn/布袋除尘器
www.ygqcgs.com/除尘器
回复

使用道具 举报

30

主题

192

帖子

246

积分

落伍者(一心一意)

Rank: 1

贡献
267
鲜花
4
注册时间
2011-4-3
发表于 2014-9-28 00:07:56 | 显示全部楼层 来自 中国北京
var c = document.querySelector('[data-position="current"]');
document.addEventListener('click', function(e){
        var targtId = e.target.getAttribute('id') || '';
        if(/^list(\d+)\-[s|h]$/.test(targtId)){
                var id = targtId.match(/^list(\d+)\-[s|h]$/)[1],
                        cls = targtId[targtId.length - 1] === 's' ? ['current', 'left'] : ['right', 'current'];
                document.querySelector('#list' + idx).className = cls[0];
                c.className = cls[1];
        }
});

评分

参与人数 3鲜花 +3 收起 理由
超鸡 + 1
残夜留香 + 1 落伍有你更精彩!
boyXP + 1 落伍有你更精彩!

查看全部评分

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

论坛客服/商务合作/投诉举报:2171544 (QQ)
落伍者创建于2001/03/14,本站内容均为会员发表,并不代表落伍立场!
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论!
落伍官方微信:2030286 邮箱:(djfsys@gmail.com|tech@im286.com)
© 2001-2014

浙公网安备 33060302000191号

浙ICP备11034705号 BBS专项电子公告通信管[2010]226号

  落伍法律顾问: ITlaw-庄毅雄

手机版|找回帐号|不能发帖?|Archiver|落伍者

GMT+8, 2024-11-29 12:32 , Processed in 0.084286 second(s), 32 queries , Gzip On.

返回顶部