FireBug's Console.dir() vs. DOM Tab

Posted January 14, 2009 at 9:27 AM

Tags: Javascript / DHTML

In my previous post on FireBug's Console object, Alan Pennell-Smith made a comment that got me thinking; he said that if one were to forget to use console.log() methods, the data would still be available in the DOM tab of FireBug's Javascript. To be honest, I didn't even know that the DOM tab included Javascript objects (like I said before - I know very little about the Javascript aspects of FireBug). But, this begged the question: is the consol.dir() output dynamic? Or, does it display static data that was available only at that given moment in run time?

To explore this, let's update my previous example:

 Launch code in new window » Download code as text file »

  • <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  • <html>
  • <head>
  • <title>FireBug Console Testing</title>
  •  
  • <script type="text/javascript">
  •  
  • // Define complex object.
  • var objGirl = {
  • Name: "Molly",
  • Hair: "Brunette",
  • Eyes: "Brown",
  • BestQualities:
  • [
  • "Smile",
  • "Laugh"
  • ]
  • };
  •  
  • // Debug data in FireBug.
  • console.dir( objGirl );
  •  
  •  
  • // Update the complex object.
  • objGirl.BestQualities = [
  • "Legs",
  • "Butt"
  • ];
  •  
  • // Debug updated data in FireBug.
  • console.dir( objGirl );
  •  
  • </script>
  • </head>
  • <body>
  •  
  • <h1>
  • FireBug Console Testing
  • </h1>
  •  
  • </body>
  • </html>

Here, we are creating the complex Javascript object and outputting it using console.dir(). Then, we update a property of the complex object and re-output it to the console. At this point, here is what the DOM tab shows us:

 
 
 
 
 
 
FireBug's DOM Tab Shows Only Final State Of Javascript Data Points. 
 
 
 

Notice that once the page has finished running, the DOM tab only shows us the final state of our complex Javascript object. If we flip over to the Console, however:

 
 
 
 
 
 
FireBug's Console Displays Static Data For Snapshot Of Runtime. 
 
 
 

... we can see that in the console, the output shows us a static version of our complex Javascript object in that given snapshot in time. FireBug console.dir() for the win!

Download Code Snippet ZIP File

Post Comment  |  Ask Ben  |  Other Searches  |  Print Page




Learning ColdFusion 9 - ColdFusion 9 tutorials, samples, examples, demos

Reader Comments

Jan 14, 2009 at 9:49 AM // reply »
2 Comments

Wow, that was a quick follow up and again very handy. Can already think of some uses where I could use this at work. Thanks!


Jan 14, 2009 at 9:57 AM // reply »
29 Comments

Just FYI, user defined variables show up in bold in the DOM panel. Well, I say user defined, but I really mean any non-native objects, including those added by Firebug itself. Built-in DOM elements show up in plain text.

As far as getting to JS variables without using the console object, you can also use the command line: http://getfirebug.com/commandline.html

The command line, combined with the breakpoints or the debugger keyword can be a very powerful tool.


Jan 14, 2009 at 10:40 AM // reply »
12 Comments

The DOM Tab shows endstate. Real value comes from the Watch tab of the Script tab, when stepping through a JS process. You can create a Breakpoint, for debugging, rerun your script, and step through line by line from your Breakpoint, inspecting each object at each step of your process. Great stuff...


Jan 14, 2009 at 10:44 AM // reply »
7,572 Comments

@Steve,

Mark Drew just showed me like 10 minutes ago how to use the step-debugger. Very cool stuff!


Jan 15, 2009 at 2:56 PM // reply »
25 Comments

For some real step-debugging fun try making an ajax call, stepping through that function that calls some cf page which is also set up for debugging (via CF debugging or Fusion Debug). Step through some CF in Eclipse and then return it to Firebug. Weeeee!


Post Comment  |  Ask Ben

Recent Blog Comments
Mar 22, 2010 at 3:08 AM
Ask Ben: Selecting XML Attributes Given Other XML Attributes
Thanks for the response. I finally discovered that I was getting this error because I had cfsetting enablecfoutputonly="yes" in Application.cfc, and was neither setting it to false elsewhere nor brac ... read »
Mar 21, 2010 at 8:57 PM
The Bourne Ultimatum Starring Matt Damon And Julia Stiles
late to the party, but my observation is this: rewatch carefully for the platonic nature of the relationship between nicki and jason. she never flirts with him. he never comes on to her. they alway ... read »
Mar 21, 2010 at 7:40 PM
Is Simulating User-Input Events With jQuery Ever A Good Idea?
A couple of things. One you embed the initial state of of more-info in the CSS. IMHO, that behavior should be in jQuery: moreInfo.hide(); It shows that the behavior your toggling and closing is mor ... read »
Mar 21, 2010 at 3:59 PM
Exploring ColdFusion Component Runtime Class Properties And Serialization
@Elliott, according to Ben's experiment, serializeJSON() doesn't access the private data by default - it doesn't even access the getHair() method - so trying to clone a Girl.cfc via serializeJSON/des ... read »
Mar 21, 2010 at 3:49 PM
Ask Ben: Javascript String Replace Method
I'm confused a bit by what you are asking, but if had this sentence: The color, red, is in the style statement; style: red;. and wanted to remove all or change all of the commas, colons, and semi-c ... read »
Mar 21, 2010 at 3:13 PM
Ask Ben: Javascript String Replace Method
I am trying to make a java program to count the number of times that these punctuation marks occur in a body of text: , : ; . ! - ' " ? / \ I am using this piece to ferret out the commas: numcommas ... read »
Mar 21, 2010 at 11:13 AM
A New Wrist Pain
@chiropractor suwanee, Spoken like someone trying to sell something. Other than for minor, temporary relief from some back pain, chiropractic treatment is nothing but placebo effect and quackery. ... read »
Mar 21, 2010 at 6:32 AM
ColdFusion CFPOP - My First Look
Apologies... The field name in the db for C. is "BounceCode" It stores the code / message which is returned in the email. Sorry for the confusion. ... read »