1. 最後一個逗號
如這段代碼,注意最後一個逗號,按語言學角度來說應該是不錯的(python的類似資料類型辭典dictionary就允許如此)。IE會報語法錯誤,但語焉不詳,你只能用人眼從幾千行代碼中掃描。
<script>
var theObj = {
city : "Boston",
state : "MA",
}
</script>
2. this的引用會改變
如這段代碼:
<input type="button" value="Gotcha!" id="MyButton" >
<script>
var MyObject = function () {
this.alertMessage = "Javascript rules";
this.ClickHandler = function() {
alert(this.alertMessage );
}
}();
document.getElementById(”theText”).onclick = MyObject.ClickHandler
</script>
並不如你所願,答案並不是”JavaScript rules”。在執行MyObject.ClickHandler時,代碼中紅色這行,this的引用實際上指向的是document.getElementById("theText")的引用。可以這麼解決:
<input type="button" value="Gotcha!" id="theText" >
<script>
var MyObject = function () {
var self = this;
this.alertMessage = “Javascript rules”;
this.OnClick = function() {
alert(self.value);
}
}();
document.getElementById(”theText”).onclick = MyObject.OnClick
</script>
實質上,這就是JavaScript範圍的問題。如果你看過,你會發現解決方案不止一種。
3. 標識盜賊
在JavaScript中不要使用跟HTML的id一樣的變數名。如下代碼:
<input type="button" id="TheButton">
<script>
TheButton = get("TheButton");
</script>
IE會報對象未定義的錯誤。我只能說:IE sucks.
4. 字串只替換第一個匹配
如下代碼:
<script>
var fileName = "This is a title".replace(" ","_");
</script>
而實際上,結果是”This_is a title“. 在JavaScript中,String.replace的第一個參數應該是Regex。所以,正確的做法是這樣:
var fileName = "This is a title".replace(/ /g,"_");