Solved

Extract javascript block from ajax content and execute it

Posted on 2008-10-28
6
2,620 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
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 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
Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 

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

Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

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

Find out what you should include to make the best professional email signature for your organization.
When crafting your “Why Us” page, there are a plethora of pitfalls to avoid. Follow these five tips, and you’ll be well on your way to creating an effective page.
In this tutorial viewers will learn how to position items using CSS's three positioning types Create a new HTML document with an internal stylesheet.: Create another div in CSS and name it Absolute : Type "position:absolute;" and "top:10px; left:50p…
HTML5 has deprecated a few of the older ways of showing media as well as offering up a new way to create games and animations. Audio, video, and canvas are just a few of the adjustments made between XHTML and HTML5. As we learned in our last micr…

690 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