Je donne les résultats suivants:Comment puis-je distinguer entre une zone de texte vide et une zone de texte avec zéro dans JavaScript?
var NewCount = document.getElementById('MainContent_gv_NewCount_' + rowIndex).value;
if (NewCount != "") {
document.getElementById('MainContent_gv_lblTotal_' + rowIndex).innerHTML = "£" + ((originalCount - NewCount) * unitCost).toFixed(2);
} else {
document.getElementById('MainContent_gv_lblTotal_' + rowIndex).innerHTML = "";
}
Les calculs que je fais sont basés sur la valeur dans la zone de texte. (NewCount).
Je souhaite que l'étiquette soit mise à jour si la valeur est un nombre quelconque (y compris 0), mais qu'elle doit être effacée si l'utilisateur efface la zone de texte. Cependant, il traite pour le moment une zone de texte vierge et une zone de texte avec 0 dans la même zone.
Comment puis-je différencier les deux?
Je ne crois pas que le code affiché pourrait être responsable de ce que vous percevez aller mal. La comparaison que vous avez, 'NewCount! =" "', Sera 'true' quand la valeur de la boîte d'entrée est une chaîne non-vide, y compris la chaîne" 0 ". – Pointy
Voulez-vous traiter les espaces blancs de la même manière que ""? – JoeyRobichaud
@Pointy - Ce n'est pas comme ça que '! =' Fonctionne. Vous avez besoin de '! =='. – OrangeDog