<?xml version="1.0" encoding="utf-8"?>
<feed xml:lang="en-us" xmlns="http://www.w3.org/2005/Atom"><title>Simon Willison's Weblog: instanceof</title><link href="http://simonwillison.net/" rel="alternate"/><link href="http://simonwillison.net/tags/instanceof.atom" rel="self"/><id>http://simonwillison.net/</id><updated>2009-01-12T10:55:07+00:00</updated><author><name>Simon Willison</name></author><entry><title>instanceof considered harmful (or how to write a robust isArray</title><link href="https://simonwillison.net/2009/Jan/12/isarray/#atom-tag" rel="alternate"/><published>2009-01-12T10:55:07+00:00</published><updated>2009-01-12T10:55:07+00:00</updated><id>https://simonwillison.net/2009/Jan/12/isarray/#atom-tag</id><summary type="html">
    
&lt;p&gt;&lt;strong&gt;&lt;a href="http://thinkweb2.com/projects/prototype/instanceof-considered-harmful-or-how-to-write-a-robust-isarray/"&gt;instanceof considered harmful (or how to write a robust isArray&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;
JavaScript’s instanceof operator breaks when dealing with objects that may have been created in a different document or frame, since constructors are unique to each frame. Instead, you can check for arrays using the default Object.toString method which the JS spec guarantees will return [object Array].


    &lt;p&gt;Tags: &lt;a href="https://simonwillison.net/tags/arrays"&gt;arrays&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/frames"&gt;frames&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/instanceof"&gt;instanceof&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/javascript"&gt;javascript&lt;/a&gt;, &lt;a href="https://simonwillison.net/tags/tostring"&gt;tostring&lt;/a&gt;&lt;/p&gt;



</summary><category term="arrays"/><category term="frames"/><category term="instanceof"/><category term="javascript"/><category term="tostring"/></entry></feed>