我想要这样,以便当用户键入他们的邮政编码时,可以看到我们是否支持他们的区域。我已经完成了这一步,但是我没有将成千上万的邮政编码放入数组中。这是我到目前为止的内容:
var zips = ['CM14','CM11','CM12','CM13','SS16','SS15','CM1','CM2','CM4','SS12','SS13','SS14','CM15','SS11'];
var bad = ['CM16','CM17','CM18','CM19','CM20','CM21','CM23','CM24','CM25','CM26','CM2','CM28','CM29'];
$(function(){
$('input[name=zip]').on( 'blur' , function(){
var currentVal = $(this).val();
var res = currentVal.toUpperCase();
if($.inArray(res, bad)> -1){
$('.checkout_button').prop('disabled',true);
alert("if")
} else if($.inArray(res, zips)> -1){
alert("else if")
$('.checkout_button').prop('disabled',false);
} else {
alert("else")
$('.checkout_button').prop('disabled',true);
}
});
});
上面的方法有效,但我希望这样做,以便用户输入SS12 7HF时,如果SS12是SS12 7HF的一部分,它将返回其他内容。我要如何完成?
我是jQuery新手。
最佳答案
尝试使用空格进行拆分,并在匹配之前始终获取第一部分(zip):
var res = currentVal.split(' ')[0].toUpperCase();
码:
var zips = ['CM14', 'CM11', 'CM12', 'CM13', 'SS16', 'SS15', 'CM1', 'CM2', 'CM4', 'SS12', 'SS13', 'SS14', 'CM15', 'SS11'];
var bad = ['CM16', 'CM17', 'CM18', 'CM19', 'CM20', 'CM21', 'CM23', 'CM24', 'CM25', 'CM26', 'CM2', 'CM28', 'CM29'];
$(function() {
$('input[name=zip]').on('blur', function() {
var currentVal = $(this).val();
var res = currentVal.split(' ')[0].toUpperCase();
if ($.inArray(res, bad) > -1) {
$('.checkout_button').prop('disabled', true);
alert("if")
} else if ($.inArray(res, zips) > -1) {
alert("else if")
$('.checkout_button').prop('disabled', false);
} else {
alert("else")
$('.checkout_button').prop('disabled', true);
}
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input name="zip" />