標籤:-- nbsp type 錯誤 val onclick http pre ref
JS中,單引號和雙引號其實沒啥區別,看你自己習慣了。但若雙引號中再使用雙引號,則需要用反斜線來禁止解析雙引號:alert("abc\"def\"ghi");
但如下情況需要明白:在一個網頁中的按鈕,寫onclick事件的處理代碼,不小心寫成如下:
<input type="button" onclick="alert("1")" /> -------------------不正確IE提示出錯後,再漫不經心地改為:
<input type="button" onclick="alert(\"1\")" /> ----------------不正確
結果還是出錯。這時,我就想不通了,雖然我知道最直接的解決方案是寫成這樣:
<input type="button" onclick="alert(‘1‘)" /> -------------------正確但為什麼javascript中的逸出字元\沒有效果了呢?
這是因為,這段代碼還是歸於HTML的管轄範圍,所以逸出字元應該使用HTML的,而不是javascript的。<input value="雙引號" type="button" onclick="alert("雙引號");" /> -------------------正確
<input value="單引號" type="button" onclick="alert('單引號');" /> -------------------正確
小結
<input value="外雙引號內雙引號-錯誤" type="button" onclick="alert("OK");" />
<input value="外單引號內單引號-錯誤" type="button" onclick=‘alert(‘OK‘);‘ />
<input value="兩個雙引號-錯誤" type="button" onclick="alert(""OK"");" />
<input value="兩個單引號-錯誤" type="button" onclick="alert(‘‘OK‘‘);" />
<input value="反斜線\+雙引號-錯誤" type="button" onclick="alert(\"OK\");" />
<input value="反斜線\+單引號-錯誤" type="button" onclick="alert(\‘OK\‘);" />
<input value="外雙引號內單引號-OK" type="button" onclick="alert(‘OK‘);" />
<input value="外單引號內雙引號-OK" type="button" onclick=‘alert("OK");‘ />
<input value="外部不使用引號-OK" type="button" onclick=alert(‘OK‘); />註:內部使用HTML的單引號或雙引號轉移字元時,都是可以的
來自為知筆記(Wiz)
JS HTML 單引號與雙引號