问题
Is there a simple way to combine these two jQuery functions into one, thereby removing the unnecessary duplication?
$('form#search input').on('keyup', function() {
if ($(this).val() == '') {
$('a#clear').hide();
}
else {
$('a#clear').show();
}
});
$('form#search select').on('change', function() {
if ($(this).val() == '') {
$('a#clear').hide();
}
else {
$('a#clear').show();
}
});
Thanks for any help.
回答1:
If you want to bind these conditionally in the most elegant, shortest way possible you can do this:
var $formSearch = $('form#search'),
hideShow = function () {
if ($(this).val() == '') {
$('a#clear').hide();
}
else {
$('a#clear').show();
}
};
$formSearch.find('input').on('keyup', hideShow);
$formSearch.find('select').on('change', hideShow);
If you want both event to be triggered for both selectors, you can do this. It might be okay to do this, since you might want these to be triggered anyways.
$('form#search input, form#search select').on('keyup change', function() {
if ($(this).val() == '') {
$('a#clear').hide();
}
else {
$('a#clear').show();
}
});
回答2:
Define one function to handle the event and then assign it as follows:
function inputChanged() {
if ($(this).val() == '') {
$('a#clear').hide();
}
else {
$('a#clear').show();
}
}
$('form#search input').on('keyup', inputChanged);
$('form#search select').on('change', inputChanged);
来源:https://stackoverflow.com/questions/25494133/how-to-combine-two-event-handlers-into-one-in-jquery