다음은 문자 A-F 및 숫자 0-9로 구성된 35 자와 3 개의 대시 ("-")로 구성된 입력을 통해 제출 된 항목 코드를 확인합니다. 유효한 항목 코드의 예는이 될 것이다 : 16FA860F-E86A457B-A28A238B-2ACA6E3D길이가 널인 경우 조건을 전달해야 함
//Checks the item code to see if it meets requirements
if($("#input").val().length > 35) {
$("#errorLogContent").prepend("The item code <font color='#FFFFFF'>" + itemCode + "</font> is too long.<br>");
$("#ise").each(function(){
this.reset();
});
}
else if($("#input").val().length < 35) {
$("#errorLogContent").prepend("The item code <font color='#FFFFFF'>" + itemCode + "</font> is too short. Be sure to include dashes.<br>");
$("#ise").each(function(){
this.reset();
});
}
else if($("#input").val().match(/([^A-Fa-f0-9-]+)/gm)) {
$("#errorLogContent").prepend("The item code <font color='#FFFFFF'>" + itemCode + "</font> contains invalid characters.<br>");
$("#ise").each(function(){
this.reset();
});
}
else if($("#input").val().match(/[-]/g, "").length > 3) {
$("#errorLogContent").prepend("The item code <font color='#FFFFFF'>" + itemCode + "</font> is an invalid format. Please only use 3 dashes.<br>");
$("#ise").each(function(){
this.reset();
});
}
else if($("#input").val().match(/[-]/g, "").length < 3) {
$("#errorLogContent").prepend("The item code <font color='#FFFFFF'>" + itemCode + "</font> is an invalid format. Please include 3 dashes.<br>");
$("#ise").each(function(){
this.reset();
});
}
else {
//Rest of my code
}
에게 다음 작품 아니라, 아이템 코드는 길이 35 자입니다,하지만 대시가없는 경우를 제외하고. 1 또는 2 개의 대시가 포함되어 있으면이 코드가 캐치하지만 0이 포함되어 있으면 아무 것도 처리하지 않고 그냥 수행합니다. 나는 모든 것을 시도했지만 해결책이 무엇인지 파악할 수 없습니다. 길이가 null이기 때문에, 어떻게 든 쥐게한다 그것은 단지 hangs.The 부분은 이것이다 :
else if($("#input").val().match(/[-]/g, "").length > 3) {
$("#errorLogContent").prepend("The item code <font color='#FFFFFF'>" + itemCode + "</font> is an invalid format. Please only use 3 dashes.<br>");
$("#ise").each(function(){
this.reset();
});
}
else if($("#input").val().match(/[-]/g, "").length < 3) {
$("#errorLogContent").prepend("The item code <font color='#FFFFFF'>" + itemCode + "</font> is an invalid format. Please include 3 dashes.<br>");
$("#ise").each(function(){
this.reset();
});
}
나는 해결책이 쉬운 확신 해요,하지만 난 난처한 상황에 빠진입니다.
편집 : 다음은 CSS를 제외하고 대부분 모든 부분을 배치 한 방법입니다. http://jsfiddle.net/86KcG/1/
이 방법이 지나치게 복잡해 보입니다. 형식이 항상 같은가요? 즉, '-'는 항상 같은 위치에 있습니까? 하나의 정규 표현식이 작업을 수행 할 것입니다 ... –
길이가 35 인 경우 어떤 상태로 시작해야합니까 ?? – charlietfl
@ 마이클 예.하지만 좋을 지 몰라도, 지금 당장 확인하는 것이 너무 걱정되지 않습니다. 코드에 항상 세 개의 대시가 있는지 확인하는 데 초점을 맞추고, 그렇지 않은 경우 오류 메시지를 표시합니다.1 또는 2 만 있으면 작동하지만 아무 것도 없다면 아무 것도하지 않습니다. –