我随机地在我的JS应用程序中发生了一个非常奇怪的错误.基本上,脚本无法准确比较两个字符串.更具体地说,有时看不到两个相同的字符串相同:(‘blah’==’blah’)返回false.
有趣的是,在另一次尝试中,相同的两个字符串可以被认为是相同的(语句返回true).我从未设法弄清楚这种模式.我也试过用===而不是==;这没有用.
除了录制截屏视频之外,我想不出更好的方式来演示和证明这个荒谬的错误.所以这里是:http://www.screenr.com/klOs.我一直在为该视频中的每个测验给出正确的答案,但是接近结束时,你对“日本”和“台湾”的答案将被视为“错误”;控制台还会显示给定的答案字符串,正确的答案字符串以及比较结果(false?!!).
那么这可能是造成这种奇怪行为的原因,我该如何解决这个问题呢?
您可以在截屏视频中看到带有比较语句的代码. ‘params.givenAnswer’直接来自按钮文字标签:
//*** Options for answering the card quiz quizOptions = new Ext.Panel({ id: 'quizOptions',[…………] listeners: { el: { scope: this,tap: this.checkAnswer } } }); checkAnswer: function(container,element) { // Get the text value of the button clicked var answer = Ext.fly(element).dom.innerText; Ext.dispatch({ controller: 'Practice',action: 'checkAnswer',givenAnswer: answer }); },
更新感谢@JAAulde和@Mike!我试图在日志记录中包含引号和var类型,我得到了这个结果:
现在很明显为什么字符串比较失败了:第一个字符串中似乎有一个额外的换行符.它仍然非常奇怪,因为它在之前的日志记录中并没有显示为空白的新行,最重要的是,它随机出现在那里(注意这次“台湾”如何被接受而没有任何问题).
解决方法
使用===是严格的相等比较.这意味着正在比较数据类型和内容.它们(数据和类型)必须相同才能相等并返回true.
当您将严格比较切换为==时,即使数据类型不同,测试也应该有效.然而,由于额外的空格,它失败了.