Exploring the Heap Contents
This page demonstrates how object contents can be explored using the Heap Profiler. The entire contents can be viewed, regardless of the current context (as opposed to how debugger works). Moreover, it is possible to inspect variables of closures, and peek into objects internals.
Below is the source code of the script, for reference:
function createClosure(a, b, c) { var d = a + b; return function() { return c + d; }; } var closure = createClosure("a", "b", "c"); closure.a = "property a"; closure.d = "property d"; var consString = "aaa / " + document.URL + document.inputEncoding; var top_in_page = "inside page"; function init() { var iframe = document.createElement("iframe"); iframe.setAttribute("src", "heap-profiling-containment-files/iframe.html"); document.getElementById("iframe-host").appendChild(iframe); }
Try this:
- Take a heap snapshot
- Open the Containment view
The Containment view shows several top-level
entries, including DOMWindow
objects. By expanding
a DOMWindow
object, it is possible to examine all of its
properties. This page contains several iframe
, and it has its
own DOMWindow
object.
There are several interesting things to explore in the DOMWindow
object of the page:
- Find and expand the
closure
property. It will show the contents of the closure, as well as properties of the closure object itself. Color coding is used to distinguish closure variables from properties. - Find and expand the
consString
property. It will exhibit, that a concatenated string is stored as a linked list of its parts.
Simultaneously, you can view contents of an iframe without the need to switch contexts.