Wydajne wyrażenie regularne dla funkcji kanadyjskiego kodu pocztowego
var regex = /[A-Za-z]\d[A-Za-z] ?\d[A-Za-z]\d/;
var match = regex.exec(value);
if (match){
if ( (value.indexOf("-") !== -1 || value.indexOf(" ") !== -1 ) && value.length() == 7 ) {
return true;
} else if ( (value.indexOf("-") == -1 || value.indexOf(" ") == -1 ) && value.length() == 6 ) {
return true;
}
} else {
return false;
}
Wyrażenie regularne szuka wzoru A0A 1B1. prawdziwe testy:
A0A 1B1
A0A-1B1
A0A1B1
A0A1B1C << problem dziecka
więc dodałem czek na „-” lub „”, a następnie czek na długość.
Czy istnieje metoda regularna lub bardziej efektywna?