InsertAfter - Find - On() -- Not Working
Solution 1:
The .find()
function looks for elements that are inside the current set of matched elements, but doesn't include those matched elements. Your <a class="del">
element is part of the set of matched elements so won't be picked up.
Use .filter()
instead:
....filter('.del').on('click', function() {...});
Solution 2:
Your .find()
selector doesn't actually return anything. If you look at how jQuery processes your HTML string:
> $('<input type="file" name="bild[]"/> <a class="del">X</a> <br/>')
[<input type="file" name="bild[]">, #text, <a class="del">X</a>, #text, <br>]
You'll see that it's actually parsing each of those elements and text nodes as separate elements in a selector. .find()
won't return anything, as it'll look only through the descendants of those elements, not the elements themselves:
> $('<input type="file" name="bild[]"/> <a class="del">X</a> <br/>').find('.del')
[]
I'd start with something like this:
$('<input type="file" name="bild[]"/>').insertAfter('#more');
$('<a class="del">X</a>').insertAfter('#more').on('click', function(){
alert('test');
});
$('<br/>').insertAfter('#more');
Or make a generic selector from the beginning that automatically handles click events, even for elements that don't exist yet:
$('#more').on('click', '.del', function() {
alert('test');
});
Solution 3:
Try this
function addmore(){
var element = $('<input type="file" name="bild[]"/> <a class="del">X</a> <br/>').insertAfter('#more');
element.filter(".del").on('click', function(){
alert('test');
});
}
Post a Comment for "InsertAfter - Find - On() -- Not Working"