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?

questionAnswers(5)

yourAnswerToTheQuestion