gpt4 book ai didi

javascript - 简化 jQuery 代码 - Slide 和 SlideToggle

转载 作者:行者123 更新时间:2023-12-03 05:12:20 25 4
gpt4 key购买 nike

如何简化当前的 JavaScript 代码?看起来太复杂了。

// Data from AJAX response
var errorsJSON = {
"name-pl": ["The name-pl field is required."],
"name-en": ["The name-en field is required."]
}

var errorString = $(this).data('validate-multiple');
var errorNamesArray = errorString.split(", ");
var ul = $('<ul class="list-unstyled">');

$.each(errorNamesArray, function(key, value) {
if (errorsJSON.hasOwnProperty(value)) {
ul.append(`<li><span class="help-block">${errorsJSON[value]}</span></li>`);
}
});

if (! $(this).is(':visible') && ul.children('li').length > 0) {
$(this).find('div.controls').empty().append(ul);
$(this).slideDown(500);
} else if ($(this).is(':visible') && ul.children('li').length === 0) {
$(this).slideUp(500);
} else if ($(this).is(':visible') && ul.children('li').length > 0) {
$(this).slideUp(500, function() {
$(this).find('div.controls').empty().append(ul);
$(this).slideDown(500);
});
}

这里我粘贴了html和js代码http://jsfiddle.net/ecLjnnhm/我想指出 errorsJSON 可以更改,并且取决于用户在输入字段中输入的内容。

最佳答案

可读性:使用变量来存储 if 语句的条件,而不是每次都使用冗长的声明。

效率:将 $(this) 缓存为变量,这样 jQuery 只需要做一次工作。

个人偏好:我建议在任何 jQuery 对象变量(如您的情况下的 ul)前面加上 $ 来表明它们是一个 jQuery 对象。

// Data from AJAX response
var errorsJSON = {
"name-pl": ["The name-pl field is required."],
"name-en": ["The name-en field is required."]
}

var errorString = $(this).data('validate-multiple');
var errorNamesArray = errorString.split(", ");
var $ul = $('<ul class="list-unstyled">');
var $t = $(this);
var isVisible = $t.is(':visible');
var hasErrors = false;

$.each(errorNamesArray, function(key, value) {
if (errorsJSON.hasOwnProperty(value)) {
$ul.append(`<li><span class="help-block">${errorsJSON[value]}</span></li>`);
hasErrors = true;
}
});

if (!isVisible && hasErrors) {
$t.find('div.controls').empty().append(ul);
$t.slideDown(500);
} else if (isVisible && !hasErrors) {
$t.slideUp(500);
} else if (isVisible && hasErrors) {
$t.slideUp(500, function() {
$t.find('div.controls').empty().append(ul);
$t.slideDown(500);
});
}

关于javascript - 简化 jQuery 代码 - Slide 和 SlideToggle,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41748976/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com