4 回答

TA貢獻(xiàn)1906條經(jīng)驗(yàn) 獲得超10個(gè)贊
我非常喜歡Matt Kruse的Javascript Best Practices文章。他在其中指出,使用該href部分執(zhí)行JavaScript代碼是一個(gè)壞主意。即使您已經(jīng)聲明用戶必須啟用JavaScript,但也沒有理由沒有一個(gè)簡(jiǎn)單的HTML頁面,href如果有人在登錄后碰巧關(guān)閉了JavaScript ,則所有JavaScript鏈接都可以指向其部分。我強(qiáng)烈建議您仍然允許這種備用機(jī)制。這樣的事情將遵循“最佳實(shí)踐”并實(shí)現(xiàn)您的目標(biāo):
<a href="javascript_required.html" onclick="doSomething(); return false;">go</a>

TA貢獻(xiàn)1794條經(jīng)驗(yàn) 獲得超8個(gè)贊
可以使用addEventListener
/ 時(shí)為什么要這樣做attachEvent
?如果沒有href
-equivalent,則不要使用和<a>
,<button>
并相應(yīng)地設(shè)置其樣式。

TA貢獻(xiàn)2021條經(jīng)驗(yàn) 獲得超8個(gè)贊
您忘記了另一種方法:
5: <a href="#" id="myLink">Link</a>
使用JavaScript代碼:
document.getElementById('myLink').onclick = function() {
// Do stuff.
};
我無法評(píng)論哪個(gè)選項(xiàng)提供了最好的支持,或者哪個(gè)語義上是最好的,但是我只是說我更喜歡這種樣式,因?yàn)樗梢詫⒛膬?nèi)容與JavaScript代碼分開。它將所有JavaScript代碼保持在一起,這很容易維護(hù)(特別是如果您將其應(yīng)用到許多鏈接上),甚至可以將其放在一個(gè)外部文件中,然后將其打包以減小文件大小并由客戶端瀏覽器緩存。

TA貢獻(xiàn)1825條經(jīng)驗(yàn) 獲得超4個(gè)贊
<a href="#" onClick="DoSomething(); return false;">link</a>
我將這樣做,或者:
<a href="#" id = "Link">link</a>
(document.getElementById("Link")).onclick = function() {
DoSomething();
return false;
};
視情況而定。對(duì)于較大的應(yīng)用程序,第二個(gè)最好,因?yàn)檫@樣可以合并您的事件代碼。
添加回答
舉報(bào)