开发者

move onclick function to other element with jquery - reading attr() returns function

开发者 https://www.devze.com 2023-02-05 18:24 出处:网络
I have an <img src=\"blabla.png\" onclick=\"someFunction();\"> tag that I want to replace with an <a> tag (created dynamically).

I have an <img src="blabla.png" onclick="someFunction();"> tag that I want to replace with an <a> tag (created dynamically).

I want to move the onclick from the to the but when I read attr("onclick") it returns:

function onclick(event) {
  someFunction();
}

How can I extract only the someFunction(); call and set this to the onclick of the <a> tag?

After the answer I used it like this:

$(function(){
    $(".content img[src*=images]").each(function(){
        $(this).after("<a href=# class='button'></a>");
        $(this).next().text($(this).attr("alt"));
        $(this).next().click(this.onclick);
        /* remove old img */
        $(this).remove();
    }开发者_Python百科);
});


Use the this.onclick instead of $(this).attr('onclick'). It will be a function type and you can simply set the a.onclick = img.onclick.

Ideally however the image would have a click handler and would be bound unobtrusively.

var someFunction = function(){};
$('img').click(someFunction);

Then you could use the same function on the a

$('a').click(someFuncion);
0

精彩评论

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