Regex eficiente para la función de código postal canadiense

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;
}

La expresión regular busca el patrón A0A 1B1. pruebas verdaderas:

A0A 1B1

A0A-1B1

A0A1B1

A0A1B1C << problema niño

así que agregué un cheque para "-" o "" y luego un cheque para la longitud.

¿Hay una expresión regular, o un método más eficiente?

Respuestas a la pregunta(5)

Su respuesta a la pregunta