Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 7047657
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 28, 20262026-05-28T02:47:52+00:00 2026-05-28T02:47:52+00:00

Can someone tell me why I cannot use $.proxy to remove a dom element.

  • 0

Can someone tell me why I cannot use $.proxy to remove a dom element.

Update: I know I can use anonymous function, but I am particularly interested in knowing why $.proxy is not working.

<html>
    <head>
    <title>$.proxy Test</title>
    </head>
<body>
<ul id="test">    
</ul>
<script>
var test = $('#test');
    var li = $('<li>Test Entry</li>').appendTo(test);
    li.click($.proxy(li, 'remove')); // Does not work
    //li.click($.proxy(li.remove, li)); // Does not work
    //li.click(function(){li.remove();}); // Works

</script>
</body>
</html>

Update 2 : I did not want to use the usual function definition syntax, since I did not want a single statement to spread into multiple lines. Hence I decided to use the following syntax. I don’t know whether it is a good practice, but to me, the code looks cleaner this way.

$.proxy(new Function(‘this.remove()’), li);

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-28T02:47:53+00:00Added an answer on May 28, 2026 at 2:47 am

    In your code example:

    li.click($.proxy(li, 'remove'));
    

    it does call li.remove() upon the click, but it calls it with the click event as the first argument to .remove()

    like:

    li.remove(e);
    

    but .remove() is expecting a selector in that argument. In trying to use it as a selector, it apparently causes .remove() to fail, thus it doesn’t do anything.

    So, proxy is doing what you asked it to do, but that isn’t appropriate for this particular use because .remove() is expecting arguments that are incompatible with what the .click() event passes it.

    I discovered this myself when stepping through the proxy function in the jQuery source, but you can also see that when you click on the text to active the call to the proxied function, an exception is thrown. This particular exception happens because jQuery is expecting the selector argument to be a string with a .replace() method, but it’s a jQuery event object (from the click event) which doesn’t have this method.

    I’m not suggesting this as a meaningful solution, but to illustrate that $.proxy() works in this situation when you give it a function that isn’t expecting something other than a jQuery event object as it’s first argument, this code works:

    var test = $('#test');
    var li = $('<li>Test Entry</li>').appendTo(test);
    li.myRemove = function(e) {this.remove();};
    li.click($.proxy(li, "myRemove"));
    

    You can see it work here: http://jsfiddle.net/jfriend00/TyaeZ/. Here, I create a myRemove method that is expecting the arguments that .click() gives it and it works.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Can someone tell me why I cannot write a class as follows <?php class
Can someone tell me what i don't make as it should, why i cannot
Can someone tell me how i can change the .xml file that a flash
Can someone tell me the different between LinkButton.PostBackUrl and HyperLink.NavigateUrl? I've got a asp.net
Can someone tell me how to change directories using FtpWebRequest? This seems like it
Can someone tell what is wrong with this query? sqltext = SELECT utyp, count(*)
Can someone tell me what the code equivelant in VB.Net to this C# code
Can someone tell me what exactly the two above lines of javascript do? And
Can someone tell me why: var nl = Convert.ToInt64(17029268.1650117); fails, and instead you have
can someone tell me why the following behavior occurs (Oracle 10.2): SQL> create table

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.