Friday, May 17, 2024
 Popular · Latest · Hot · Upcoming
25
rated 0 times [  29] [ 4]  / answers: 1 / hits: 44561  / 11 Years ago, fri, may 3, 2013, 12:00:00

I've tried using .load() and $.ajax to get some HTML that needs to be appended to a container, but the Javascript within the returned HTML is not being executed when I append it to an element.



Using .load():



$('#new_content').load(url+' #content > *',function() {
alert('returned');
});


I've also tried switching to a $.ajax call. I then extracted the script from the returned HTML after which I appended it to the container, but same problem, the JS isn't being executed or even appended in this case, and as I understand it, trying to append a <script> to a DOM element like this is frowned upon?



Using $.ajax:



$.ajax({ url: url }).done(function(response) {
var source = $(<div>).html(response).find('#overview_script').html();
var content = $(<div>).html(response).find('#content').html();

$('#new_content').html(content);
$('<script>').appendTo('#new_content').text(source).html();

});


Ideally I would run this javascript in a callback after I have appended the HTML, but variables are being set to values that are returned from a controller.



So in summary, I am trying to get some HTML which contains JS that needs to be run after that HTML has been appended, but I have had no luck using .load() or $.ajax() as the script in the returned HTML either disappears upon appending it, or it does not execute at all.


More From » jquery

 Answers
29

When load() is used with a fragment selector the script element will be stripped out before the fragment is added thus the script will not get executed.




When calling .load() using a URL without a suffixed selector
expression, the content is passed to .html() prior to scripts being
removed. This executes the script blocks before they are discarded. If
.load() is called with a selector expression appended to the URL,
however, the scripts are stripped out prior to the DOM being updated,
and thus are not executed. An example of both cases can be seen below:




So Try



$.get('partial.html', function(result){
$result = $(result);

$result.find('#content').appendTo('#new_content');
$result.find('script').appendTo('#new_content');
}, 'html');


Demo: Fiddle


[#78459] Wednesday, May 1, 2013, 11 Years  [reply] [flag answer]
Only authorized users can answer the question. Please sign in first, or register a free account.
victorr

Total Points: 193
Total Questions: 86
Total Answers: 105

Location: Pitcairn Islands
Member since Thu, Jun 24, 2021
3 Years ago
victorr questions
Fri, Nov 13, 20, 00:00, 4 Years ago
Sat, Jul 25, 20, 00:00, 4 Years ago
Thu, Jun 11, 20, 00:00, 4 Years ago
;