Hi I have the following html:
<p>  
    <input type="text" name="field1"/> <input type="hidden" name="fieldh1"/>  
    <button type="button" class="sendInfo">Send</button>  
</p>  
<p>  
    <input type="text" name="field2" /> <input type="hidden" name="fieldh2"/>  
    <button type="button" class="sendInfo">Send</button>  
</p>  
What I want is that when user clicks the button, I need to send using ajax the contents of the field field.
This is what i'm trying to do with no success.
$(function() {
        $('button.sendInfo').live('click', function() {
            var id = $(this).parent().next('[type=text]').val();
            alert(id);
        });
    });
I plan to set what the user types in textbox to the hidden field, and the value received from the ajax call to normal textbox. But the problem is that i can´t even get the value of the textbox that is in the same line as the button the user clicks. Can anyone help me? Thanks a lot.
Try:
$(this).siblings('input:text').val();
Or change next to find:
$(this).parent().find('[type=text]').val();
as next only searches the immediate following sibling.
I can use jQuery.next() function.
Your issue is that "next()" is going to the next sibling of the parent -- and the parent is the <p> tag, so the sibling, if it exists, is the following <p> tag.  
You want $(this).parent().children('[type=text]').val() or $(this).parent().find('[type=text]')
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With