$ npm install jsdom
If this gives you trouble with errors about installing Contextify, especially on Windows, see below.
see: mailing list
Bootstrapping a DOM is generally a difficult process involving many error prone steps. We didn't want jsdom to fall into the same trap and that is why a new method,
jsdom.env(), has been added in jsdom 0.2.0 which should make everyone's lives easier.
You can use it with a URL
// Count all of the links from the Node.js build pagevar jsdom = ;jsdom;
or with raw HTML
// Run some jQuery on a html fragmentvar jsdom = ;jsdom;
or with a configuration object
// Print all of the news items on hackernewsvar jsdom = ;jsdom;
// Print all of the news items on hackernewsvar jsdom = ;var fs = ;var jquery = fs;jsdom;
The arguments are:
string: may be a URL, file name, or HTML fragment
scripts: a string or array of strings, containing file names or URLs that will be inserted as
config: see below
callback: takes two arguments
error: either an
Errorobject if something failed initializing the window, or an array of error messages from the DOM if there were script errors
window: a brand new
If you would like to specify a configuration object only:
config.html: a HTML fragment
config.file: a file which jsdom will load HTML from; the resulting window's
location.hrefwill be a
config.url: sets the resulting window's
config.fileare not provided, jsdom will load HTML from this URL.
referer: the new document will have this referer.
cookie: manually set a cookie value, e.g.
'key=value; expires=Wed, Sep 21 2011 12:00:00 GMT; path=/'.
cookieDomain: a cookie domain for the manually set cookie; defaults to
config.done is required, as is one of
If you want to spawn a document/window and specify all sorts of options this is the section for you. This section covers the
var jsdom = jsdom;var doc = ;var window = docparentWindow;
markup is an HTML/XML document to be parsed. You can also pass
null or an undefined value to get a basic document with empty
<body> tags. Document fragments are also supported (including
""), and will behave as sanely as possible (e.g. the resulting document will lack the
documentElement properties if the corresponding elements aren't included).
null (which means level3) by default, but you can pass another level if you'd like.
var jsdom = ;var doc = jsdom;
options see the Flexibility section below.
One of the goals of jsdom is to be as minimal and light as possible. This section details how someone can change the behavior of
Documents on the fly. These features are baked into the
DOMImplementation that every
Document has, and may be tweaked in two ways:
Documentusing the jsdom builder (
var jsdom = jsdom;var doc =;
Do note, that this will only affect the document that is currently being created. All other documents will use the defaults specified below (see: Default Features).
defaultDocumentFeatures =FetchExternalResources: "script"ProcessExternalResources: false;
Default features are extremely important for jsdom as they lower the configuration requirement and present developers a set of consistent default behaviors. The following sections detail the available features, their defaults, and the values that jsdom uses.
["script", "img", "css", "frame", "iframe", "link"]or
Enables/disables fetching files over the file system/HTTP.
/url to be skipped/or
Do not download and process resources with url matching a regular expression.
jsdom includes support for using the canvas package to extend any
<canvas> elements with the canvas API. To make this work, you need to include canvas as a dependency in your project, as a peer of jsdom. If jsdom can find the canvas package, it will use it, but if it's not present, then
<canvas> elements will behave like
var jsdom = ;var doc = new jsdomDocument;console; // outputs: #document
var jsdom = jsdom;var document = ;var window = documentparentWindow;console;// output: "<html><head></head><body>hello world</body></html>"console;// output: 1024console;// outputs: function
var jsdom = ;var window = jsdomparentWindow;jsdom;
var jsdom = jsdom;var window = parentWindow;window__myObject = foo: "bar" ;var scriptEl = windowdocument;scriptElsrc = "anotherScript.js";windowdocumentbody;// anotherScript.js will have the ability to read `window.__myObject`, even// though it originated in Node!
level1/core 535/535 100%level1/html 238/238 100%level1/svg 527/527 100%level2/core 283/283 100%level2/html 706/706 100%level2/style 15/15 100%level2/extra 4/4 100%level2/events 24/24 100%level3/xpath 93/93 100%window/index 7/7 100%window/history 5/5 100%window/script 10/10 100%window/console 2/2 100%window/frame 16/16 100%sizzle/index 14/14 100%jsdom/index 76/76 100%jsdom/parsing 11/11 100%jsdom/env 25/25 100%jsonp/jsonp 1/1 100%browser/index 34/34 100%---------------------------------------TOTALS: 0/2626 failed; 100% success
First you'll want to
npm install. To run all the tests, use
npm test, which just calls
test/runner directly, you can slice and dice which tests your want to run from different levels. Usage is as follows:
test/runner --helpRun the jsdom test suiteOptions:-s, --suites suites that you want to run. ie: -s level1/core,1/html,html [string]-f, --fail-fast stop on the first failed test-h, --help show the help-t, --tests choose the test cases to run. ie: -t jquery
Contextify is a dependency of jsdom, used for running
<script> tags within the
that pretends to be a browser environment instead of a server. You can see how this is an important feature.
For Mac and Linux users, this is usually fine. Their systems come preinstalled with the necessaries for compiling C++. For Windows users, however, things can be tricky. Thus, one of the most common problems with jsdom is trying to use it on Windows without the proper compilation tools installed. Here's what you need to compile Contextify, and thus to install jsdom, on Windows:
There are some slight modifications to this that can work; for example full versions of Visual Studio usually work, and sometimes you can even get an x64 version of Node.js working too. But it's tricky, so start with the basics!