Solved

Extract javascript block from ajax content and execute it

Posted on 2008-10-28
6
2,606 Views
Last Modified: 2012-05-05
HI,

I would like to extract a specific javascript block, which has an ID, from the content I received by making an ajax call and then execute that javascript block. Is it possible to do it using JQuery? Here's how I started out:
$(document).ready(function(){

           

   $.ajax({

            url: "Page2.aspx",

            type: "GET",

            success: function(content){

                    

                var scriptBlock = $(content).find('script#myscript');

                

                // Now execute the script block

            }

          });

});

Open in new window

0
Comment
Question by:wtor
  • 3
  • 2
6 Comments
 
LVL 9

Expert Comment

by:Shahzad Fateh Ali
ID: 22828857
What is in your response, a javascript code or html?
If it is only javascript then put your code in a function and then after ajax call you will be able to call that function.

see the example

/* response */

<script>

function fnOne(){

 alert("Function one called");

}

function fnTwo(){

 alert("Function two called");

}

</script>

/* end response */
 

/* after ajax call */
 

success: function(content){

                    

        eval(content);      // make the script executable

        fnTwo();            // call to the function

            

         // Now execute the script block

   }

Open in new window

0
 

Author Comment

by:wtor
ID: 22828916
Sorry I forgot to mention that my response was the entire HTML of Page.aspx.
0
 
LVL 9

Expert Comment

by:Shahzad Fateh Ali
ID: 22828931
Can you place your response html here?
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 

Author Comment

by:wtor
ID: 22828945
Here's the HTML:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 

<html xmlns="http://www.w3.org/1999/xhtml">

<head runat="server">

    <title>Untitled Page</title>

</head>

<body>

    <form id="form1" action="Page.aspx">
 

        <script id="myscript" type="text/javascript">

            

            function demoClass()

            {

                var myval;

            }

            

            var obj = new demoClass();

            obj.myval = 10;

            

            alert( "This is a script in page 2. Value: " + obj.myval );

        </script>
 

    </form>

</body>

</html>

Open in new window

0
 
LVL 16

Accepted Solution

by:
sh0e earned 250 total points
ID: 22828964

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.min.js"></script>

<script>

$(document).ready(function(){

   $.ajax({

            url: "Page2.aspx",

            type: "GET",

            cache: false,

            dataType: 'xml',

            success: function(xml){

                    

                eval($('script#myscript',xml).text())

            }

          });

});

</script>

Open in new window

0
 

Author Comment

by:wtor
ID: 22829168
Thanks sh0e for pointing me to the right direction. I just had to change the dataType to html and it worked!
I dont like using eval. If you google, you'll know why. Here's the final code:
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.min.js"></script>

<script>

$(document).ready(function(){

   $.ajax({

            url: "Page2.aspx",

            type: "GET",

            cache: false,

            dataType: 'html',

            success: function(html){

                    

            var myScript = new Function($('script#myscript',html).text());
 

myScript();

            }

          });

});

</script>

Open in new window

0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Introduction A frequently asked question goes something like this:  "I am running a long process in the background and I want to alert my client when the process finishes.  How can I send a message to the browser?"  Unfortunately, the short answer …
This article discusses four methods for overlaying images in a container on a web page
In this tutorial viewers will learn how add a full-size background image to a webpage using CSS3. Create a new HTML document with an internal stylesheet.: In CSS, define the html element to have a background image. Use a high resolution image.: In t…
In this tutorial viewers will learn how to style elements, such a divs, with a "drop shadow" effect using the CSS box-shadow property Start with a normal styled element, such as a div.: In the element's style, type the box shadow property: "box-shad…

929 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now