我想要这样,以便当用户键入他们的邮政编码时,可以看到我们是否支持他们的区域。我已经完成了这一步,但是我没有将成千上万的邮政编码放入数组中。这是我到目前为止的内容:

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" />

09-11 08:08