开发者

Updating onclick function within another function not using unbind/removeAttr

开发者 https://www.devze.com 2023-03-22 02:52 出处:网络
read final edit for solution I\'m try update the onclick function of a link using jquery. example would be best to explain:

read final edit for solution

I'm try update the onclick function of a link using jquery.

example would be best to explain:

html

<a href='' id='one_click' onclick='do_things_here("fighter","bitter",2)'>first clicker</a>

<a href='' id='two_click' onclick='do_things_here("abc","xyz",1)'>second clicker</a>

js (something like this - I don't this is actually correct logically speaking)

function do_thing_here(data, info, source){

  *//things happen here*

  $('#two_click').click(function() {
    do_things_here(data,info,source)
    return false;

    });


}

That doesn't work as it goes into a recursive loop as do_things_here gets set off when resetting the onclick on 'two_click'.

edit

I've tried to set a reset flag to prevent do_things_here running on re-setting the onclick

function do_thing_here(data, info, source,reset){
      if (reset){
           return false;
      }


      *//things happen here*

      $('#two_click').click(function() {
        do_things_here(data,info,source,true)
        return false;

        });


    }

but that did seems a bit hack-ish and I don't think it worked, I still had issues - I'll try to do it again and see what the issues where.

I've tried unbinding and removeAttr/attr in an attempt to reassign as explained here

JavaScript: changing the value of onclick with or without jQuery

those methods do not seem to work in all browsers

  • Using jQuery attr("onclick", js) doesn't work with both Firefox and IE6/7.
  • Using setAttribute("onclick", js) works with Firefox and IE8, but not IE6/7.
  • Using onclick = function() { return eval(js); } doesn't work because you are not allowed to use return is code passed to eval().

I've tried clearing out the onclick function in the html so nothing is set as default but that didn't have any effect.

I can simply reset/rejig the 开发者_如何学Clink as follows

<span id='change_two'><a href='' id='two_click' onclick='do_things_here("abc","xyz",1)'>second clicker</a></span>

and then

 function do_thing_here(data, info, source){

      *//things happen here*

      $('#change_two').html("<a href='' id='two_click' onclick='do_things_here('+data+','+info+','+soutce+')'>second clicker</a>");


    }

or something similar but I'm wondering if there is a better cleaner way to do it?

----edit:solution explained----

just for those googling on to this page:

if you set the onclick via html you need to removeAttr ($(this).removeAttr('onclick'))

if you set it via jquery (as the after the first click in my examples above) then you need to unbind ($(this).unbind('click'))

Then you simply rebind with bind ($(this).bind('click',function(event){//the code/function call})))

//important - removeAttr: use 'onclick' and unbind: use 'click' - I think that was my main problem!

wasn't sure if I should post this as an answer as the solution was right there in my question! Sorry folks for the brain failure.

I know in the question it states "not using unbind/removeAttr" - that was because I thought it was not working with those functions - but that was only due to the usage of the different functions.


Not sure what you are trying to achieve, but to unbind a click event, just use $(this).unbind('click')


Summarized answer that I used successfully,

if you set the onclick via html you need to removeAttr ($(this).removeAttr('onclick'))

if you set it via jquery (as the after the first click in my examples above) then you need to unbind ($(this).unbind('click'))

0

精彩评论

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