Thank you both,
The only problem is that the right answer isn't 2, it's 3. I'm
actually looking for the index of item#my_item inside the contents
array. children() doesn't take into consideration the "!!" textnode.

On Dec 30, 9:43 pm, Ricardo Tomasi <ricardob...@gmail.com> wrote:
> var $items = $('<items><item>Hello</item><item>world</item><item
> id="my_item">Goodnight moon!</item></items>');
> var $my = $items.find('#my_item');
> console.info( $items.children().index($my) );
>
> or
>
> var $items = $('<items><item>Hello</item><item>world</item><item
> id="my_item">Goodnight moon!</item></items>');
> $items.children().each(function(i){
>    if ( this.id == 'my_item' ) console.info(i);
>
> });
>
> indexOf is a method of the String object, no use in this case.
>
> On Dec 30, 6:07 pm, nachocab <nacho...@gmail.com> wrote:
>
> > Actually that gives an error. It should be:
> > var $items = $('<items><item>Hello</item><item>world</item>!!<item
> > id="my_item">Goodnight moon!</item></items>');
> > for(var i=0; i <= $items.children().length; i++){
> >     if ( $items.contents()[i].id == 'my_item' )
> >         console.info(i)}
>
> > It also needs to work with $items.contents()[i].className
>
> > On Dec 30, 8:30 pm, nachocab <nacho...@gmail.com> wrote:
>
> > > Hi everyone,
> > > I'd like to know if there's a way to do this without using a for loop.
> > > You can just paste this in Firebug:
>
> > > var $items = $('<items><item>Hello</item><item>world</item>!!<item
> > > id="my_item">Goodnight moon!</item></items>');
> > > for(var i=0; i <= $items.children().length; i++){
> > >     if ( $items.contents()[i].id == 'my_item' )
> > >         console.info(i)
>
> > > }
>
> > > Keep in mind that I need to use contents() to also get the text node
> > > ("!!"). I can't seem to use contents().index() properly.
>
> > > Thanks,
>
> > > Nacho

Reply via email to