开发者

event is not defined in FireFox, but ok in Chrome and IE

开发者 https://www.devze.com 2023-01-02 01:32 出处:网络
I generate HTML using jQuery: $(\"<a />\") 开发者_C百科 .append(\"demo\") .click(function () { DemoFunc(event, value.Id) })

I generate HTML using jQuery:

$("<a />")
   开发者_C百科 .append("demo")
    .click(function () { DemoFunc(event, value.Id) })

This works perfect for Chrome and IE8, but in FireFox I got an error: "event is not defined". I changed the code like this:

.attr("onclick", "DemoFunc(event, " + value.Id + ")")

It works for Firefox, but not for Chrome and IE.

DemoFunc = function (e, assocGroupId) {
    var target = (e.target) ? $(e.target) : $(e.srcElement);
    ....
}

Why!? Help!!


In IE and Chrome, event is resolving to window.event. Firefox doesn't have this property and instead provides an event to an event handler function by passing it as a parameter. jQuery abstracts this difference for you by providing an event object parameter in all browsers:

$("<a />")
    .append("demo")
    .click(function (evt) { DemoFunc(evt, value.Id) });


If you have structured your code around working with the original event rather than the jQuery event, you can use evt.originalEvent to refer to the native event.

0

精彩评论

暂无评论...
验证码 换一张
取 消