- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
$(function(){
var m_small = $('.met_small');
var met_small = $('.metka_small');
m_small.on('click', function(){
var text = $(this).text();
$('#tmet2').find('h2').html(text);
m_small.each(function(){
$(this).children('p').css({
'color' : '#08579E'
});
});
var e = $(this);
e.children('p').css({
'color' : '#000'
});
met_small.each(function(){
$(this).removeClass('metka_small_active');
})
e.children('.metka_small').addClass('metka_small_active');
});
});
$(function(){
$('.met').not('.cont').on('click',function(){
var text = $(this).text();
$('#tmet2').find('h2').html(text);
$('.met').each(function(){
$(this).children('p').css({
'color' : '#08579E'
});
});
var e = $(this);
e.children('p').css({
'color' : '#000 '
});
$('.metka').each(function(){
$(this).removeClass('metka_active');
})
e.children('.metka').addClass('metka_active');
});
});
Я в js не давно. Возможно ли эти две функции объединить в одну ?
Они делают одно и тоже, просто для двух разных элементов.
scriptin 11.01.2013 12:46 # +7
Удали строки 21 и 22
Heckfy_top 11.01.2013 13:58 # 0
scriptin 11.01.2013 14:02 # +3
guest 11.01.2013 14:13 # +1
wvxvw 11.01.2013 14:25 # +6
Например, можно было начать с такого. (Убираем ненужный цикл переназначения классов = уменьшаем нагрузку при отрисовке, уменьшаем количество запросов к ДОМу, которые тоже недешевые, убираем кучу динамических выделений памяти нужные для создания новых функций). Если подумать дальше, то можно разобраться с тем, что именно делает removeClass и addClass и заменить их обычными функциями - после чего выбросить нахер Жквери. Аналогично с each.
Heckfy_top 12.01.2013 12:55 # 0
Eugene 12.01.2013 01:48 # +2
Может быть сначала имеет смысл подучить русский?
scriptin 12.01.2013 01:54 # 0
Eugene 12.01.2013 02:04 # −2
Я в js не гавно, а Д'Артаньян!
В нынешней интерпретации должно быть слитно.
Heckfy_top 12.01.2013 12:57 # 0