javascript - Get the id of a the item that is clicked - Stack Overflow

admin2025-04-03  0

I have this html code:

<b class = "edit" id = "foo1">FOO</b>
<b class = "edit" id = "foo2">FOO2</b>
<b class = "edit" id = "foo3">FOO3</b>

And I have this code in jQuery:

$('b.edit').click(function(){
    //GET THE ID OF THE b.edit: e.g foo1, foo2, foo3
    $('.editP').focus();
});

How can I get the id value of the b.edit, as there are multiple instances of b.edit, and I want to get the specific id of the one clicked? How can I do this?

Thanks, Sorry, I am pretty new to javascript.

I have this html code:

<b class = "edit" id = "foo1">FOO</b>
<b class = "edit" id = "foo2">FOO2</b>
<b class = "edit" id = "foo3">FOO3</b>

And I have this code in jQuery:

$('b.edit').click(function(){
    //GET THE ID OF THE b.edit: e.g foo1, foo2, foo3
    $('.editP').focus();
});

How can I get the id value of the b.edit, as there are multiple instances of b.edit, and I want to get the specific id of the one clicked? How can I do this?

Thanks, Sorry, I am pretty new to javascript.

Share Improve this question edited Jan 7, 2012 at 9:29 Felix Kling 818k181 gold badges1.1k silver badges1.2k bronze badges asked Nov 16, 2011 at 22:14 H BellamyH Bellamy 22.7k25 gold badges80 silver badges119 bronze badges 5
  • What framework do You use? jQuery? – Michas Commented Nov 16, 2011 at 22:16
  • 2 All this people advocating $(this).attr("id") instead of this.id make me very, very sad. – Domenic Commented Nov 16, 2011 at 22:25
  • @Domenic I can see your point ..... IF the OP was just getting the id and nothing else - however the very next instruction is to call a jQuery method ... (i know you going to say that you can use the focus method without jQuery - but it could be any jQuery method) – Manse Commented Nov 16, 2011 at 22:33
  • @ManseUK a jQuery method on a pletely different element. – Domenic Commented Nov 16, 2011 at 22:34
  • @Domenic :-( *walks off to grab some stronger glasses ...... – Manse Commented Nov 16, 2011 at 22:36
Add a ment  | 

10 Answers 10

Reset to default 3

I'm assuming from your sample code that you're using jQuery? If so you can get the id as follows:

$('b.edit').click(function(){
 this.id;
});

EDIT:

The direct reference to the attribute is indeed more efficient if all that is required is simply the id.

Also can be obtained from the jQuery object:

$('b.edit').click(function(){
 $(this).attr('id');
});

Sample fiddle: http://jsfiddle/5bQQT/

Try with this:

$('b.edit').click(function(e){ //When you use an event is better
                               //send the event variable to the 
                               //binding function.
    var id = e.target.id; //get the id of the clicked element.
   /*do your stuff*/
    $('.editP').focus();
});

try this. You can use keyword "this" to retrieve the attr ID...

$('b.edit').click(function(){ alert($(this).attr("id")); });

$('.edit').click(function(){
   var theId = $(this).attr('id');
}

This will get you the ID of anything clicked with a class of .edit

$('.edit').live('click', function() {
    alert( this.id );
});

Sample
http://jsfiddle/ck2Xk/

When passing a click handler in JQuery, you actually have a reference to something called an event object. This event object has a property called target, which is a reference to the element that was clicked.

$('b.edit').click(function(eventObject){
    eventObject.target // this is the element that was clicked.
});

Since you have a reference to the target element, you can do whatever you like. In this case, you could just access eventObject.target.id.

Since nobody has shown the simplest method yet that doesn't even need jQuery to get the id:

$('.edit').click(function() {
    alert(this.id);
});

I never understand why people use jQuery for getting simple attributes which involves two jQuery function calls (and a bunch of overhead to create a jQuery object) instead of one direct attribute reference.

something like this:

var id = $(this).attr('id');

More clearly:

$('b.edit').live('click', function(){
    var id = $(this).attr('id');

    // in this scope this.id works too
    // var id = this.id;
});

This is called event delegation in Javascript. More info can be found in Zakas blog http://www.nczonline/blog/2009/06/30/event-delegation-in-javascript/

The idea in few words is you attache the event to a parent node and then waiting for some event on the child node. In the example below I attach the onclick event to the document itself. Then inside the event handler you will write a switch statement to check the clicked element id, then do what you want to do for that element

document.onclick = function(event){
    //IE doesn't pass in the event object
    event = event || window.event;

    //IE uses srcElement as the target
    var target = event.target || event.srcElement;    

    switch(target.id){
        case "foo1":
            foo1();
            break;
        case "foo2":
            foo2();
            break;
        case "foo3":
            foo3();
            break;
        //others?
    }
};


//some dummy handlers
var foo1 = function(){ 
    alert("You clicked foo1");
    };

var foo2 = function(){ 
    alert("You clicked foo2");
    };

var foo3 = function(){ 
    alert("You clicked foo3");
    };

For how to implement event delegation in jQuery you can check http://api.jquery./on/#direct-and-delegated-events

Even though this is not a real answer to your question. I will try to explain why what your asking is not the way to go. Since you are new especially, since learing bad practices could be hard to unlearn. Allways try to search for an ID before finding an element by its Class. Also try to avoid giving every element the same class (and in this case ID to), just give it an encapsulating parent.

Furthermore, the id of an element is really specific and should preferably used to find / select / bind events to. An id should usually be unique for this to work, so in your case a couple of things could be optimized, lets say like:

<div id="foo"> 
  <b id="1">Foo</b>
  <b id="2">Other foo</b>
  <b id="3">Some foo</b>
</div>

Now if you want to know which was clicked there are multiple ways to acplish it, but a nice one is simply binding a parent its children (i.e <div id="foo"> .. </div>). This way you can alter the structure of your pretty fast, without changing all the classes and id's.

With jQuery you can get the attribute id using the .attr() function. However I told you the id was pretty specific and thus has its own rights in javascript world. An id can also be directly targeted ('DOMelement.id', but this would be too much to explain for now)

In two ways the <b> can be targetted:

Example a)

var b_elements = $("#foo").children();

Example b)

var b_elements = $("#foo").find('b');

We can add jQuery (or javascript events) to these found elements. The nice thing about jQuery is that it simplifies alot of work. So in your case if you would like to know an id of a certain clicked <b> field you could use a very verbose way:

b_elements.click(function()
{
  var clicked_element = $(this);
  alert(clicked_element.attr('id'));
});

Verbose because you can do it much much shorter, but who cares about a few bytes when your learning and this makes remembering functions and events alot easier. Say you wanted to get the class edit by finding the where you knew the id that was clicked:

b_elements.click(function()
{
  var clicked_element = $(this);
  alert(clicked_element.attr('class'));
});

And to conclude, the id of an element is ment to be unique because it makes searching through big documents alot faster. Also don't forget to look and learn plain javascript, as it helps coding in jQuery alot too, but not the other way around. Your given question would require a for loop in plain javascript since it cannot do a lookup by class nor id nor have they have a mon parent.

Good luck with learning :)

转载请注明原文地址:http://conceptsofalgorithm.com/Algorithm/1743623439a213728.html

最新回复(0)