超鸡 发表于 2014-9-27 00:23:08

求助,这个JS能不能简化一下。。

本帖最后由 超鸡 于 2014-9-27 00:30 编辑

//list1
document.querySelector('#list1-s').addEventListener ('click', function () {
document.querySelector('#list1').className = 'current';
document.querySelector('').className = 'left';
});
document.querySelector('#list1-h').addEventListener ('click', function () {
document.querySelector('#list1').className = 'right';
document.querySelector('').className = 'current';
});
//list2
document.querySelector('#list2-s').addEventListener ('click', function () {
document.querySelector('#list2').className = 'current';
document.querySelector('').className = 'left';
});
document.querySelector('#list2-h').addEventListener ('click', function () {
document.querySelector('#list2').className = 'right';
document.querySelector('').className = 'current';
});。。。
。。。
。。。
。。。
。。。
。。。
//list20
document.querySelector('#list20-s').addEventListener ('click', function () {
document.querySelector('#list20').className = 'current';
document.querySelector('').className = 'left';
});
document.querySelector('#list20-h').addEventListener ('click', function () {
document.querySelector('#list20').className = 'right';
document.querySelector('').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里边呢?

boyXP 发表于 2014-9-27 00:43:31

用jquery,只需一行

超鸡 发表于 2014-9-27 01:21:28

boyXP 发表于 2014-9-27 00:43 static/image/common/back.gif
用jquery,只需一行

jquery体积更大了…………。

衣服古月 发表于 2014-9-27 08:24:12

超鸡 发表于 2014-9-27 21:13:50

顶            

wangeng01 发表于 2014-9-27 21:15:33

代码很复杂,帮顶一下

bddyw 发表于 2014-9-28 00:07:56

var c = document.querySelector('');
document.addEventListener('click', function(e){
        var targtId = e.target.getAttribute('id') || '';
        if(/^list(\d+)\-$/.test(targtId)){
                var id = targtId.match(/^list(\d+)\-$/),
                        cls = targtId === 's' ? ['current', 'left'] : ['right', 'current'];
                document.querySelector('#list' + idx).className = cls;
                c.className = cls;
        }
});
页: [1]
查看完整版本: 求助,这个JS能不能简化一下。。