如何通过使用 jQuery 测试复选框的高值和低值来检查复选框?
How can I check checkboxes by testing their high and low values with jQuery?
我无法根据复选框的值测试和检查一组复选框。下面的示例显示了一些复选框,如果复选框的值高于选中的值,则应选中。如果该值等于或小于检查的值,则不应检查。
感谢大家的帮助!
<label class="checkbox"><input type="checkbox" name="a" value="5"> One</label>
<label class="checkbox"><input type="checkbox" name="a" value="5"> two</label>
<label class="checkbox"><input type="checkbox" name="a" value="15"> three</label>
<label class="checkbox"><input type="checkbox" name="a" value="25"> four</label>
JS
$('input[type="checkbox"]').change(function (e) {
var $value = $(this).val();
var $siblings = $('input[name="' + $(this).attr("name") + '"]').not(":checked");
$.each($siblings, function (i, input) {
console.log(input.value)
if ($value != input.value) {
$(this).prop('checked', true);
}
else if ($value > input.value) {
$(this).prop('checked', true);
}
else if ($value >= input.value) {
$(this).prop('checked', true);
}
else {
$(this).prop("checked", false);
}
})
});
你可以这样试试
var firstCheckboxVal = 0;
$('input[type="checkbox"]').change(function (e) {
if(firstCheckboxVal == 0)
firstCheckboxVal = $(this).val();
else {
if(parseInt($(this).val()) > parseInt(firstCheckboxVal))
$(this).prop('checked', true);
else
$(this).prop('checked', false);
}
});
我不确定,但我认为它适合你。
试试这个 JSFIDDLE
我遇到了值是字符串而不是 int 的问题,所以我只是使用 parseInt
在两个级别上修复它。
$('input[type="checkbox"]').click(function (e) {
var $value = parseInt($(this).val());
var $siblings = $('input[name="' + $(this).attr("name") + '"]').not(":checked");
$.each($siblings, function (i, input) {
var _this = parseInt(input.value);
if(_this > $value){
input.checked = true;
}
})
});
JSFIDDLE https://jsfiddle.net/seadonk/7wcs5sah/
此示例将检查所有值大于或等于选中复选框时选中的复选框的值。
取消选中时,所有值大于它的框都将保持选中状态,所有值小于它的框都将取消选中。
您可以使用 .siblings()
函数遍历所有同级复选框元素(如果它们位于同一个父容器中)。
复选框值以字符串形式返回,所以我使用 parseInt()
将它们转换为数字,然后再将它们相互比较。
$(function () {
$('input[type="checkbox"]').change(function (e) {
var checked = $(this).is(":checked");
var checkedValue = $(this).val();
var siblings = $('input[type=checkbox]');
siblings.each(function () {
var siblingValue = parseInt($(this).val());
//if checked, then check all boxes with values > checkedValue
//if unchecked, then uncheck all boxes with values <= checkedValue
$(this).prop('checked',
(checked && (siblingValue >= checkedValue)) ||
(!checked && (siblingValue > checkedValue)));
});
});
});
你可以做到
$('input[type="checkbox"]').change(function (e) {
var $value = parseInt($(this).val());
var $siblings = $('input[name="' + $(this).attr("name") + '"]:checked').not($(this));
var isCheck = true;
$siblings.each(function (i) {
var a = $(this).val() || 0;
if ($value <= a) {
isCheck = false;
}
});
$(this).prop("checked", isCheck);
});
$('input[name="' + $(this).attr("name") + '"]:checked').not($(this))
抓取不包括您单击的内容的复选框。
each()
循环简单地设置检查标志,然后根据结果设置点击框是否检查。这也将允许您取消选中单击的框
这应该可以做到。首先找到选中的最高值,然后取消选中此值是否小于或等于当前复选框。
请记住 .val()
returns 集合中第一个的值,因此排序。
$(':checkbox[name=a]').on('change', function() {
var max = +$(':checkbox[name=a]:checked').not(this).sort(function(a,b) {
return +b.value - +a.value;
}).val();
if( +this.value <= max ) {
this.checked = false;
}
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<label class="checkbox"><input type="checkbox" name="a" value="5"> One</label>
<label class="checkbox"><input type="checkbox" name="a" value="5"> two</label>
<label class="checkbox"><input type="checkbox" name="a" value="15"> three</label>
<label class="checkbox"><input type="checkbox" name="a" value="25"> four</label>
试试这个;
$("input[type='checkbox']").change(function (e) {
if (!$(this).is(":checked")) return;
var siblings = $("input[name='" + $(this).attr("name") + "']");
var value = parseInt($(this).val());
var elements = $("input[name='" + $(this).attr("name") + "']:not(:checked)");
$.each(elements, function (index, element) {
if (value > parseInt($(element).val())) {
$(element).prop('checked', true);
}
else {
$(element).prop("checked", false);
}
})
});
这里还有一个 JSFiddle link.
我不是你的 jQuery 的粉丝,因为它与 html 紧密耦合。我的答案是解耦你的复选框(基于 Philip Walton @ Google - Decoupling your Html, Css and Javascript)
HTML
<div class="js-checker-group">
<label class="checkbox"
<input class="js-checker-item" type="checkbox" name="a" value="5">
One
</label>
<label class="checkbox">
<input class="js-checker-item" type="checkbox" name="a" value="5">
two
</label>
<label class="checkbox">
<input class="js-checker-item" type="checkbox" name="a" value="15">
three
</label>
<label class="checkbox">
<input class="js-checker-item" type="checkbox" name="a" value="25">
four
</label>
</div>
jQuery:
$('.js-checker-group input[type="checkbox"].js-checker-item')
.change(function (e)
{
var $this = $(this);
var $group = $this.closest('.js-checker-group');
var thisValue = parseInt($this.val());
if ($group.length == 1
&& $this.prop('checked')
&& !isNaN(thisValue))
{
$group.find('input[type="checkbox"].js-checker-item')
.each(function()
{
var $other = $(this);
var otherValue = parseInt($other.val());
if (!isNaN(otherValue) && !$this.is($other))
{
var isGreater = otherValue < thisValue;
$other.prop('checked', isGreater);
}
});
}
});
我不鼓励你写 javascript 这取决于你如何写你的 html 兄弟姐妹,parents 等。一个改变可能会导致你的 javascript 根本不工作。
我无法根据复选框的值测试和检查一组复选框。下面的示例显示了一些复选框,如果复选框的值高于选中的值,则应选中。如果该值等于或小于检查的值,则不应检查。
感谢大家的帮助!
<label class="checkbox"><input type="checkbox" name="a" value="5"> One</label>
<label class="checkbox"><input type="checkbox" name="a" value="5"> two</label>
<label class="checkbox"><input type="checkbox" name="a" value="15"> three</label>
<label class="checkbox"><input type="checkbox" name="a" value="25"> four</label>
JS
$('input[type="checkbox"]').change(function (e) {
var $value = $(this).val();
var $siblings = $('input[name="' + $(this).attr("name") + '"]').not(":checked");
$.each($siblings, function (i, input) {
console.log(input.value)
if ($value != input.value) {
$(this).prop('checked', true);
}
else if ($value > input.value) {
$(this).prop('checked', true);
}
else if ($value >= input.value) {
$(this).prop('checked', true);
}
else {
$(this).prop("checked", false);
}
})
});
你可以这样试试
var firstCheckboxVal = 0;
$('input[type="checkbox"]').change(function (e) {
if(firstCheckboxVal == 0)
firstCheckboxVal = $(this).val();
else {
if(parseInt($(this).val()) > parseInt(firstCheckboxVal))
$(this).prop('checked', true);
else
$(this).prop('checked', false);
}
});
我不确定,但我认为它适合你。
试试这个 JSFIDDLE
我遇到了值是字符串而不是 int 的问题,所以我只是使用 parseInt
在两个级别上修复它。
$('input[type="checkbox"]').click(function (e) {
var $value = parseInt($(this).val());
var $siblings = $('input[name="' + $(this).attr("name") + '"]').not(":checked");
$.each($siblings, function (i, input) {
var _this = parseInt(input.value);
if(_this > $value){
input.checked = true;
}
})
});
JSFIDDLE https://jsfiddle.net/seadonk/7wcs5sah/
此示例将检查所有值大于或等于选中复选框时选中的复选框的值。 取消选中时,所有值大于它的框都将保持选中状态,所有值小于它的框都将取消选中。
您可以使用 .siblings()
函数遍历所有同级复选框元素(如果它们位于同一个父容器中)。
复选框值以字符串形式返回,所以我使用 parseInt()
将它们转换为数字,然后再将它们相互比较。
$(function () {
$('input[type="checkbox"]').change(function (e) {
var checked = $(this).is(":checked");
var checkedValue = $(this).val();
var siblings = $('input[type=checkbox]');
siblings.each(function () {
var siblingValue = parseInt($(this).val());
//if checked, then check all boxes with values > checkedValue
//if unchecked, then uncheck all boxes with values <= checkedValue
$(this).prop('checked',
(checked && (siblingValue >= checkedValue)) ||
(!checked && (siblingValue > checkedValue)));
});
});
});
你可以做到
$('input[type="checkbox"]').change(function (e) {
var $value = parseInt($(this).val());
var $siblings = $('input[name="' + $(this).attr("name") + '"]:checked').not($(this));
var isCheck = true;
$siblings.each(function (i) {
var a = $(this).val() || 0;
if ($value <= a) {
isCheck = false;
}
});
$(this).prop("checked", isCheck);
});
$('input[name="' + $(this).attr("name") + '"]:checked').not($(this))
抓取不包括您单击的内容的复选框。
each()
循环简单地设置检查标志,然后根据结果设置点击框是否检查。这也将允许您取消选中单击的框
这应该可以做到。首先找到选中的最高值,然后取消选中此值是否小于或等于当前复选框。
请记住 .val()
returns 集合中第一个的值,因此排序。
$(':checkbox[name=a]').on('change', function() {
var max = +$(':checkbox[name=a]:checked').not(this).sort(function(a,b) {
return +b.value - +a.value;
}).val();
if( +this.value <= max ) {
this.checked = false;
}
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<label class="checkbox"><input type="checkbox" name="a" value="5"> One</label>
<label class="checkbox"><input type="checkbox" name="a" value="5"> two</label>
<label class="checkbox"><input type="checkbox" name="a" value="15"> three</label>
<label class="checkbox"><input type="checkbox" name="a" value="25"> four</label>
试试这个;
$("input[type='checkbox']").change(function (e) {
if (!$(this).is(":checked")) return;
var siblings = $("input[name='" + $(this).attr("name") + "']");
var value = parseInt($(this).val());
var elements = $("input[name='" + $(this).attr("name") + "']:not(:checked)");
$.each(elements, function (index, element) {
if (value > parseInt($(element).val())) {
$(element).prop('checked', true);
}
else {
$(element).prop("checked", false);
}
})
});
这里还有一个 JSFiddle link.
我不是你的 jQuery 的粉丝,因为它与 html 紧密耦合。我的答案是解耦你的复选框(基于 Philip Walton @ Google - Decoupling your Html, Css and Javascript)
HTML
<div class="js-checker-group">
<label class="checkbox"
<input class="js-checker-item" type="checkbox" name="a" value="5">
One
</label>
<label class="checkbox">
<input class="js-checker-item" type="checkbox" name="a" value="5">
two
</label>
<label class="checkbox">
<input class="js-checker-item" type="checkbox" name="a" value="15">
three
</label>
<label class="checkbox">
<input class="js-checker-item" type="checkbox" name="a" value="25">
four
</label>
</div>
jQuery:
$('.js-checker-group input[type="checkbox"].js-checker-item')
.change(function (e)
{
var $this = $(this);
var $group = $this.closest('.js-checker-group');
var thisValue = parseInt($this.val());
if ($group.length == 1
&& $this.prop('checked')
&& !isNaN(thisValue))
{
$group.find('input[type="checkbox"].js-checker-item')
.each(function()
{
var $other = $(this);
var otherValue = parseInt($other.val());
if (!isNaN(otherValue) && !$this.is($other))
{
var isGreater = otherValue < thisValue;
$other.prop('checked', isGreater);
}
});
}
});
我不鼓励你写 javascript 这取决于你如何写你的 html 兄弟姐妹,parents 等。一个改变可能会导致你的 javascript 根本不工作。