dojo的event.preventDefault()无效<a> tag</a>

时间:2011-11-03 14:49:00

标签: javascript html dojo

我对Dojo很新,但我正在尝试将现有的javascript界面​​从纯javascript转换为Dojo。

我被困在以下问题

基本上我试图转换

<a id="myLink" onclick="myfunction()">bla</a>

function myfunction() {
//some funny code
return false; //To PREVENT default link behaviour
}

以下

var handle = dojo.connect(dojo.byId('myLink'),'onclick',function (evt) {
    evt.preventDefault(); //took from dojo reference
        //same code that worked in pure js

});

我无法解决问题。 Chrome和Firefox都不会触发任何错误或异常,所以我猜,没有语法错误。

我尝试将该功能连接到输入提交而不是链接,并且工作但是我需要将其连接到链接....

也许我只是累了,但我发誓我看不到错误...

2 个答案:

答案 0 :(得分:2)

在您的HTML正文上:

<a id="myLink">bla</a>

在HTML标题上:

<script type="text/javascript>
    dojo.ready(function(){
        dojo.connect(dojo.byId("myLink"), "onclick", null, function(evt){
            evt.preventDefault();
            console.debug("Default behaviour prevented");
        });
    });
</script>

有关此内容的更多信息:http://dojotoolkit.org/reference-guide/quickstart/events.html

答案 1 :(得分:0)

我遇到了同样的问题,并认为我疯了。但后来我找到了这个道场方法:

event.stopImmediatePropagation();

在这里:http://dojotoolkit.org/reference-guide/quickstart/events.html,这最终阻止了超链接做了它的事情。显然,dojo提供了自己的事件对象,它不像本机事件那样。