我有两个单选按钮连接到一个搜索字段,该字段控制用户想要的搜索类型
一个用于常规关键字搜索,另一个用于车牌搜索。
"关键字"单选按钮是预先选择的,但当检测到车牌模式时,如果可能的话,我希望使用jQuery自动将其切换到"车牌"。。。
车牌图案将始终以两个字母(A-Z)开头,然后是五个数字(0-9),如下所示:"AZ12345"。可能用这样的空格分隔:"ZA 98765"。
形式方法为_GET
。
按照您的指示,您可以使用此模式检测车牌
[A-Za-z]{2}'s?'d{5}
如果您想只匹配板(例如不是liasdjfaAG 00212lkfla),请使用^[A-Za-z]{2}'s?'d{5}$
。
您可以使用textchanged事件(看看这个答案),然后如果模式匹配,您可以更改单选按钮的"已检查"状态。
编辑:
在jsfiddle中实现,基本上代码看起来像这个
var rege = /^[A-Za-z]{2}'s?'d{5}$/;
$('#inpt').keyup(function(event) {
if (rege.test($('#inpt').val())) {
$('#plate').attr('checked', true);
} else {
$('#nonplate').attr('checked', true);
}
});
用这样的html:
<input type="text" id="inpt"/><br/>
<input type="radio" name="group1" id="plate" value="Plate"> Plate<br>
<input type="radio" name="group1" id="nonplate" value="NotPlate"> Not Plate
编辑2:
根据你的要求,我建议你阅读这个问题。基本上,使用setInterval()
,您可以每隔1或2秒检查输入的状态,以选择正确的单选按钮。您也可以缩短此间隔(将其设置为约100毫秒)
我相信您需要的是:
function checkPlate($s) {
$match = false;
$s = strtoupper($s);
$s = str_replace(" ","",$s);
if (strlen($s) == 7) {
preg_match(/[A-Z]{2}[0-9]{5}/, $s, $matches);
if (count($matches) == 1) {$match = true;}
}
return $match;
}