问题
How could the following code sometimes evaluate to false?
(transport.responseText == '1' ||
transport.responseText == 'CARD_VALID')
My JavaScript code:
if (transport.responseText == '1' ||
transport.responseText == 'CARD_VALID') {
// do something.
}
else if (transport.responseText == 'CARD_INVALID' ||
transport.responseText == 'INVALID_CHECKSUM') {
// do something else....
}
else {
new Ajax.Request('/report_error.php?responseText='+transport.responseText);
// report error to user
}
What could cause JavaScript string compare ==
to return false when the strings are identical?
回答1:
Double equals is the appropriate way to compare strings in Javascript, it is returning false then there may be whitespace to the left and or right of one string.
Put a .trim()
on the end of the strings and my comparison should started working:
var panel = response.substr(0, response.indexOf("<")).trim();
if(panel == "combo"){
//do something
}
回答2:
I had a similar problem where two obviously identical strings would not be equal, and I was pulling my hair out trying to solve it, so I did this:
for (var c=0; c<string_1.length; c++) {
if (string_1.charCodeAt(c) != string_2.charCodeAt(c)) {
alert('c:'+c+' '+string_1.charCodeAt(c)+'!='+string_2.charCodeAt(c));
valid = false;
}
}
And I found that the last character on one string was 10, and the last character on the other was 13, I thought both strings were null terminated, but they were not.
回答3:
A1 = "speed"
A2 = "speed"
if(A1 == A2) => Error !!!
USE THIS TEST IN CONSOLE:
escape("speed")
result: "speed"
escape(A1)
result: "speed%0D" => This is the problem %0D !!!
escape(A2)
result: "speed" => OK !!!
Use correct code:
if(A1.slice(0, -1) == A2) This is OK!
回答4:
Try using ===
to match exactly (type and value). This is the recommended comparison operator in javascript.
Check the datatypes of the strings to make sure, and look for hidden unicode or control characters in both strings.
回答5:
I had the same problem and i noticed that i was comparing two objects
to solve this issue i had to use
JSON.stringify(user._id) === JSON.stringify(userId) // true
回答6:
Try capturing the value of responseText
into a different variable before entering that code block, in case the variable is updated somewhere in there.
I don't have that much experience directly using XmlHttpRequest, but I do know that javascript has a number of places where it uses volatile references to interface objects that can change during execution, rather than a simple value.
回答7:
If you want something a little less complicated and you are dealing with NUMERIC VALUES, use
parseFloat()
works like a charm
回答8:
Java servlet may send strings i.e.
out.println("CARD_VALID");
or
out.print("CARD_VALID");
These may look identical in Javascript, but there are white spaces at the end in the first case.
回答9:
I would advice you to use normalization preferably "NFKC" or "NFKD" as these seem to normalize non-breaking space into regular space.
So you can write your code as :-
string1.normalize("NFKC") === string2.normalize("NFKC")
来源:https://stackoverflow.com/questions/863524/javascript-string-compare-sometimes-fails