欧美日韩一卡二卡三卡,一区二区三区四区精品视频,亚洲精品视频一区,日韩久久午夜影院

JavaScript的9個陷阱及評點
時間:2007年09月04日 內容來源: 互諾科技 瀏覽量:0

來自 Nine Javascript Gotchas , 以下是JavaScript容易犯錯的九個陷阱。雖然不是什么很高深的技術問題,但注意一下,會使您的編程輕松些,即所謂make life easier. 筆者對某些陷阱會混雜一些評點。

1. 最后一個逗號

如這段代碼,注意最后一個逗號,按語言學角度來說應該是不錯的(python的類似數據類型辭典dictionary就允許如此)。IE會報語法錯誤,但語焉不詳,你只能用人眼從幾千行代碼中掃描。

<script>
  var theObj = {
        city : "Boston",
        state : "MA",
  }
</script>

2. this的引用會改變

如這段代碼:

<input type="button" value="http://www.68design.net/Web-Guide/HTMLCSS/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="http://www.68design.net/Web-Guide/HTMLCSS/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的第一個參數應該是正則表達式。所以,正確的做法是這樣:

var fileName = "This is a title".replace(/ /g,"_");

 
 
主站蜘蛛池模板: 南丹县| 灵丘县| 中西区| 安仁县| 拉萨市| 吴江市| 方正县| 孟州市| 紫金县| 临沂市| 东安县| 扎鲁特旗| 开封县| 卢湾区| 横山县| 邵阳市| 岐山县| 西林县| 财经| 南康市| 德庆县| 西藏| 合作市| 竹北市| 瑞安市| 平江县| 雅安市| 定结县| 喜德县| 绩溪县| 繁昌县| 海淀区| 兴国县| 若尔盖县| 新乡市| 井研县| 广元市| 海丰县| 临桂县| 万盛区| 即墨市|