Я чувствую, что мой скрипт действительно избыточен и может быть написан более эффективно. Если у кого-то есть лучший способ сделать это, пожалуйста, поделитесь.Ищете более эффективный способ написания базового сценария if else jQuery
В основном я показываю и скрываю div в зависимости от того, какой переключатель выбран, используя инструкции if else.
Вот JQuery
//SUMMARY REVIEW DROPDOWN MODULES(FILTER-DROPDOWN)
$(function() {
//Values of checked radio buttons
var cd_empty = $('input[id=m4]');
var adr_empty = $('input[id=m2]');
var ocpy_empty = $('input[id=m1]');
var revpar_empty = $('input[id=m3]');
var cd_checked = $('input[id=m4]:checked', '.ddm-inputs').val();
var adr_checked = $('input[id=m2]:checked', '.ddm-inputs').val();
var ocpy_checked = $('input[id=m1]:checked', '.ddm-inputs').val();
var revpar_checked = $('input[id=m3]:checked', '.ddm-inputs').val();
var module2 = $('.dd-module-2');
if(cd_checked === 'on') {
module2.fadeIn();
}
// else {
// module2.fadeOut();
// }
$(cd_empty).click(
function(e){
if ($(this).is(':checked')){
if(module2.css('display') === 'block') {
// module2.slideUp();
// alert('its already open');
preventDefault(e);
}
else {
module2.slideToggle();
}
}
});
$(adr_empty).click(
function(e){
if ($(this).is(':checked')){
if(module2.css('display') === 'block') {
// module2.slideUp();
// alert('its open');
module2.slideToggle();
}
else {
// alert('its not open');
module2.hide();
}
}
});
$(revpar_empty).click(
function(e){
if ($(this).is(':checked')){
if(module2.css('display') === 'block') {
// module2.slideUp();
// alert('its open');
module2.slideToggle();
}
else {
// alert('its not open');
module2.hide();
}
}
});
$(ocpy_empty).click(
function(e){
if ($(this).is(':checked')){
if(module2.css('display') === 'block') {
// module2.slideUp();
// alert('its open');
module2.slideToggle();
}
else {
// alert('its not open');
module2.hide();
}
}
});
});
Я понимаю, что мне не нужны все мои переменные. –
http://codereview.stackexchange.com/ –
Когда вы назначаете свои переменные, они уже являются объектами jQuery, вам не нужно перематывать их с помощью jQuery. Кроме того, * показать HTML *; jQuery сам по себе более или менее бесполезен, так как мы не можем * угадывать * на «лучших» методах. –