{"id":6,"date":"2023-08-25T17:22:14","date_gmt":"2023-08-25T17:22:14","guid":{"rendered":"\/\/api.jquery.com\/?page_id=6"},"modified":"2024-04-20T18:06:28","modified_gmt":"2024-04-20T18:06:28","slug":"Types","status":"publish","type":"page","link":"https:\/\/api.jquery.com\/Types\/","title":{"rendered":"Types"},"content":{"rendered":"<style>\nh2 { font-size: 1.9em !important; }\nh3 { font-size: 1.5em !important; }\nol ul li { font-size: 1em !important; }\nol ul { margin-left: 1.5em !important; }\n<\/style>\n<p>This page documents data types appearing in jQuery function signatures, whether defined by JavaScript itself or further restricted by jQuery. Unless explicitly stated otherwise, jQuery functions require primitive values where applicable, and do not accept their Object-wrapped forms. If you want to study these concepts in depth, take a look at <a href=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/JavaScript\">MDN<\/a>.\n<\/p>\n<p>You should be able to try out most of the examples below by just copying them to your browser's JavaScript Console.\n<\/p>\n<p>Whenever an example mentions that a type defaults to a boolean value, the result is good to know when using that type in a boolean context:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> x = <span class=\"hljs-string\">\"\"<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">if<\/span> ( x ) {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-built_in\">console<\/span>.log( <span class=\"hljs-string\">\"x defaulted to true\"<\/span> );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>} <span class=\"hljs-keyword\">else<\/span> {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-built_in\">console<\/span>.log( <span class=\"hljs-string\">\"x defaulted to false\"<\/span> );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>}<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>In this case, <code>\"x defaulted to false\"<\/code> is printed.\n<\/p>\n<p>To keep the examples short, the invert (\"not\") operator and double-negation are used to show a boolean context:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> x = <span class=\"hljs-string\">\"\"<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>!x <span class=\"hljs-comment\">\/\/ true<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>!!x <span class=\"hljs-comment\">\/\/ false (Double negation: Since \"not (empty string)\" is true, negating that makes it false)<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>On to the actual types.\n<\/p>\n<div id=\"toctitle\"><h2>Contents<\/h2><\/div>\n<ol>\n  <li class=\"toclevel-1\"><a href=\"#Anything\"><span class=\"toctext\">Anything<\/span><\/a>\n  <\/li><li class=\"toclevel-1\"><a href=\"#String\"><span class=\"toctext\">String<\/span><\/a>\n    <ul>\n      <li class=\"toclevel-2\"><a href=\"#Quoting\"><span class=\"toctext\">Quoting<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Built-in_Methods\"><span class=\"toctext\">Built-in Methods<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Length_Property\"><span class=\"toctext\">Length Property<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Boolean_Default\"><span class=\"toctext\">Boolean Default<\/span><\/a><\/li>\n    <\/ul>\n  <\/li>\n  <li class=\"toclevel-1\"><a href=\"#htmlString\"><span class=\"toctext\">htmlString<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Number\"><span class=\"toctext\">Number<\/span><\/a>\n    <ul>\n      <li class=\"toclevel-2\"><a href=\"#Boolean_Default_2\"><span class=\"toctext\">Boolean Default<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Math\"><span class=\"toctext\">Math<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Parsing_Numbers\"><span class=\"toctext\">Parsing Numbers<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Numbers_to_Strings\"><span class=\"toctext\">Numbers to Strings<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#NaN_and_Infinity\"><span class=\"toctext\">NaN and Infinity<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Integer\"><span class=\"toctext\">Integer<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Float\"><span class=\"toctext\">Float<\/span><\/a><\/li>\n    <\/ul>\n  <\/li>\n  <li class=\"toclevel-1\"><a href=\"#Boolean\"><span class=\"toctext\">Boolean<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Object\"><span class=\"toctext\">Object<\/span><\/a>\n    <ul>\n      <li class=\"toclevel-2\"><a href=\"#Dot_Notation\"><span class=\"toctext\">Dot Notation<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Array_Notation\"><span class=\"toctext\">Array Notation<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Iteration\"><span class=\"toctext\">Iteration<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Boolean_default_3\"><span class=\"toctext\">Boolean default<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Prototype\"><span class=\"toctext\">Prototype<\/span><\/a><\/li>\n    <\/ul>\n  <\/li>\n  <li class=\"toclevel-1\"><a href=\"#Array\"><span class=\"toctext\">Array<\/span><\/a>\n    <ul>\n      <li class=\"toclevel-2\"><a href=\"#Iteration_2\"><span class=\"toctext\">Iteration<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Boolean_Default_4\"><span class=\"toctext\">Boolean Default<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Array.3CType.3E_Notation\"><span class=\"toctext\">Array&lt;Type&gt; Notation<\/span><\/a><\/li>\n    <\/ul>\n  <\/li>\n  <li class=\"toclevel-1\"><a href=\"#ArrayLikeObject\"><span class=\"toctext\">Array-Like Object<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#PlainObject\"><span class=\"toctext\">PlainObject<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Date\"><span class=\"toctext\">Date<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Function\"><span class=\"toctext\">Function<\/span><\/a>\n    <ul>\n      <li class=\"toclevel-2\"><a href=\"#Arguments\"><span class=\"toctext\">Arguments<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Context.2C_Call_and_Apply\"><span class=\"toctext\">Context, Call and Apply<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Scope\"><span class=\"toctext\">Scope<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Closures\"><span class=\"toctext\">Closures<\/span><\/a><\/li>\n      <li class=\"toclevel-2\"><a href=\"#Proxy_Pattern\"><span class=\"toctext\">Proxy Pattern<\/span><\/a><\/li>\n    <\/ul>\n  <\/li>\n  <li class=\"toclevel-1\"><a href=\"#Error\"><span class=\"toctext\">Error<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Selector\"><span class=\"toctext\">Selector<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Event\"><span class=\"toctext\">Event<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Element\"><span class=\"toctext\">Element<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Text\"><span class=\"toctext\">Text<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#jQuery\"><span class=\"toctext\">jQuery<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#XMLHttpRequest\"><span class=\"toctext\">XMLHttpRequest<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#jqXHR\"><span class=\"toctext\">jqXHR<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Thenable\"><span class=\"toctext\">Thenable<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Deferred\"><span class=\"toctext\">Deferred Object<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Promise\"><span class=\"toctext\">Promise Object<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Callbacks\"><span class=\"toctext\">Callbacks Object<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#XMLDocument\"><span class=\"toctext\">XML Document<\/span><\/a><\/li>\n  <li class=\"toclevel-1\"><a href=\"#Assert\"><span class=\"toctext\">Qunit's Assert Object<\/span><\/a><\/li>\n<\/ol>\n\n<h2 id=\"Anything\">Anything<\/h2>\n<p>The <strong>Anything<\/strong> virtual type is used in jQuery documentation to indicate that any type can be used or should be expected.\n<\/p>\n\n<h2 id=\"String\">String<\/h2>\n<p>A string in JavaScript is an immutable primitive value that contains none, one or many characters.\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"I'm a String in JavaScript!\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">'So am I!'<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>The type of a string is \"string\".\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">typeof<\/span> <span class=\"hljs-string\">\"some string\"<\/span>; <span class=\"hljs-comment\">\/\/ \"string\"<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Quoting\">Quoting<\/h3>\n<p>A string can be defined using single or double quotes. You can nest single quotes inside of double quotes, and the other way around. To mix double quotes with double quotes (or single with single), the nested ones have to be escaped with a backslash.\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"You make 'me' sad.\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">'That\\'s \"cranking\" good fun!'<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"&lt;a href=\\\"home\\\"&gt;Home&lt;\/a&gt;\"<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Built-in_Methods\">Built-in Methods<\/h3>\n<p>A string in JavaScript has some built-in methods to manipulate the string, though the result is always a new string - or something else, eg. split returns an <a href=\"\/Types\/#Array\" title=\"Types\">array<\/a>.\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"hello\"<\/span>.charAt( <span class=\"hljs-number\">0<\/span> ) <span class=\"hljs-comment\">\/\/ \"h\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"hello\"<\/span>.toUpperCase() <span class=\"hljs-comment\">\/\/ \"HELLO\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"Hello\"<\/span>.toLowerCase() <span class=\"hljs-comment\">\/\/ \"hello\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"hello\"<\/span>.replace( <span class=\"hljs-regexp\">\/e|o\/g<\/span>, <span class=\"hljs-string\">\"x\"<\/span> ) <span class=\"hljs-comment\">\/\/ \"hxllx\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"1,2,3\"<\/span>.split( <span class=\"hljs-string\">\",\"<\/span> ) <span class=\"hljs-comment\">\/\/ [ \"1\", \"2\", \"3\" ]<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Length_Property\">Length Property<\/h3>\n<p>All strings have a length property.\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"Hello\"<\/span>.length <span class=\"hljs-comment\">\/\/ 5<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"\"<\/span>.length <span class=\"hljs-comment\">\/\/ 0<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Boolean_Default\">Boolean Default<\/h3>\n<p>An empty string defaults to false:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>!<span class=\"hljs-string\">\"\"<\/span> <span class=\"hljs-comment\">\/\/ true<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>!!<span class=\"hljs-string\">\"\"<\/span> <span class=\"hljs-comment\">\/\/ false<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>!<span class=\"hljs-string\">\"hello\"<\/span> <span class=\"hljs-comment\">\/\/ false<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>!<span class=\"hljs-string\">\"true\"<\/span> <span class=\"hljs-comment\">\/\/ false<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>!<span class=\"hljs-keyword\">new<\/span> <span class=\"hljs-built_in\">Boolean<\/span>( <span class=\"hljs-literal\">false<\/span> ) <span class=\"hljs-comment\">\/\/ false<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n\n<h2 id=\"htmlString\">htmlString<\/h2>\n<p>A string is designated <strong>htmlString<\/strong> in jQuery documentation when it is used to represent one or more DOM elements, typically to be created and inserted in the document. When passed as an argument of the <code>jQuery()<\/code> function, the string is identified as HTML if it starts with <code>&lt;tag ... &gt;<\/code>) and is parsed as such until the final <code>&gt;<\/code> character. Prior to jQuery 1.9, a string was considered to be HTML if it contained <code>&lt;tag ... &gt;<\/code> <em>anywhere within the string<\/em>.<\/p>\n<p>When a string is passed as an argument to a manipulation method such as <code>.append()<\/code>, it is always considered to be HTML since jQuery's other common interpretation of a string (CSS selectors) does not apply in those contexts.<\/p>\n<p>For explicit parsing of a string to HTML, the <code><a href=\"\/jQuery.parseHTML\/\">$.parseHTML()<\/a><\/code> method is available as of jQuery 1.8.<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n7\">7<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n8\">8<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n9\">9<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n10\">10<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n11\">11<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n12\">12<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n13\">13<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n14\">14<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-comment\">\/\/ Appends &lt;b&gt;hello&lt;\/b&gt;:<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-string\">\"&lt;b&gt;hello&lt;\/b&gt;\"<\/span> ).appendTo( <span class=\"hljs-string\">\"body\"<\/span> );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code> <\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-comment\">\/\/ Appends &lt;b&gt;hello&lt;\/b&gt;:<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-string\">\"&lt;b&gt;hello&lt;\/b&gt;bye\"<\/span> ).appendTo( <span class=\"hljs-string\">\"body\"<\/span> );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code> <\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-comment\">\/\/ Syntax error, unrecognized expression: bye&lt;b&gt;hello&lt;\/b&gt;<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-string\">\"bye&lt;b&gt;hello&lt;\/b&gt;\"<\/span> ).appendTo( <span class=\"hljs-string\">\"body\"<\/span> );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code> <\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-comment\">\/\/ Appends bye&lt;b&gt;hello&lt;\/b&gt;:<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>$( $.parseHTML( <span class=\"hljs-string\">\"bye&lt;b&gt;hello&lt;\/b&gt;\"<\/span> ) ).appendTo( <span class=\"hljs-string\">\"body\"<\/span> );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code> <\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-comment\">\/\/ Appends &lt;b&gt;hello&lt;\/b&gt;wait&lt;b&gt;bye&lt;\/b&gt;:<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-string\">\"&lt;b&gt;hello&lt;\/b&gt;wait&lt;b&gt;bye&lt;\/b&gt;\"<\/span> ).appendTo( <span class=\"hljs-string\">\"body\"<\/span> );<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h2 id=\"Number\">Number<\/h2>\n<p>Numbers in JavaScript are double-precision 64-bit format IEEE 754 values. They are immutable primitive values, just like <a href=\"#String\" title=\"\">strings<\/a>. All operators common in c-based languages are available to work with numbers (+, -, *, \/, %, =, +=, -=, *=, \/=, ++, --).\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-number\">12<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-number\">3.543<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>The type of a number is \"number\".\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">typeof<\/span> <span class=\"hljs-number\">12<\/span> <span class=\"hljs-comment\">\/\/ \"number\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">typeof<\/span> <span class=\"hljs-number\">3.543<\/span> <span class=\"hljs-comment\">\/\/ \"number\"<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Boolean_Default_2\">Boolean Default<\/h3>\n<p>If a number is zero, it defaults to false:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>!<span class=\"hljs-number\">0<\/span> <span class=\"hljs-comment\">\/\/ true<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>!!<span class=\"hljs-number\">0<\/span> <span class=\"hljs-comment\">\/\/ false<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>!<span class=\"hljs-number\">1<\/span> <span class=\"hljs-comment\">\/\/ false<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>!-<span class=\"hljs-number\">1<\/span> <span class=\"hljs-comment\">\/\/ false<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Due to the implementation of numbers as double-precision values, the following result is not an error:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-number\">0.1<\/span> + <span class=\"hljs-number\">0.2<\/span> <span class=\"hljs-comment\">\/\/ 0.30000000000000004<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Math\">Math<\/h3>\n<p>JavaScript provides utilities to work with numbers in the Math object:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">Math<\/span>.PI <span class=\"hljs-comment\">\/\/ 3.141592653589793<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">Math<\/span>.cos( <span class=\"hljs-built_in\">Math<\/span>.PI ) <span class=\"hljs-comment\">\/\/ -1<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Parsing_Numbers\">Parsing Numbers<\/h3>\n<p>parseInt and parseFloat help parsing strings into numbers. Both do some implicit conversion if the base isn't specified:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">parseInt<\/span>( <span class=\"hljs-string\">\"123\"<\/span> ) = <span class=\"hljs-number\">123<\/span> <span class=\"hljs-comment\">\/\/ (implicit decimal)<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">parseInt<\/span>( <span class=\"hljs-string\">\"010\"<\/span> ) = <span class=\"hljs-number\">8<\/span> <span class=\"hljs-comment\">\/\/ (implicit octal)<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">parseInt<\/span>( <span class=\"hljs-string\">\"0xCAFE\"<\/span> ) = <span class=\"hljs-number\">51966<\/span> <span class=\"hljs-comment\">\/\/ (implicit hexadecimal)<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">parseInt<\/span>( <span class=\"hljs-string\">\"010\"<\/span>, <span class=\"hljs-number\">10<\/span> ) = <span class=\"hljs-number\">10<\/span> <span class=\"hljs-comment\">\/\/ (explicit decimal)<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">parseInt<\/span>( <span class=\"hljs-string\">\"11\"<\/span>, <span class=\"hljs-number\">2<\/span> ) = <span class=\"hljs-number\">3<\/span> <span class=\"hljs-comment\">\/\/ (explicit binary)<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">parseFloat<\/span>( <span class=\"hljs-string\">\"10.10\"<\/span> ) = <span class=\"hljs-number\">10.1<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Numbers_to_Strings\">Numbers to Strings<\/h3>\n<p>When appending numbers to string, the result is always a string. The operator is the same, so be careful: If you want to add numbers and then append them to a string, put parentheses around the numbers:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"\"<\/span> + <span class=\"hljs-number\">1<\/span> + <span class=\"hljs-number\">2<\/span>; <span class=\"hljs-comment\">\/\/ \"12\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"\"<\/span> + ( <span class=\"hljs-number\">1<\/span> + <span class=\"hljs-number\">2<\/span> ); <span class=\"hljs-comment\">\/\/ \"3\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-string\">\"\"<\/span> + <span class=\"hljs-number\">0.0000001<\/span>; <span class=\"hljs-comment\">\/\/ \"1e-7\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">parseInt<\/span>( <span class=\"hljs-number\">0.0000001<\/span> ); <span class=\"hljs-comment\">\/\/ 1 (!)<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Or you use the String class provided by javascript, which try to parse a value as string:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">String<\/span>( <span class=\"hljs-number\">1<\/span> ) + <span class=\"hljs-built_in\">String<\/span>( <span class=\"hljs-number\">2<\/span> ); <span class=\"hljs-comment\">\/\/ \"12\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">String<\/span>( <span class=\"hljs-number\">1<\/span> + <span class=\"hljs-number\">2<\/span> ); <span class=\"hljs-comment\">\/\/ \"3\"<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"NaN_and_Infinity\">NaN and Infinity<\/h3>\n<p>Parsing something that isn't a number results in NaN. isNaN helps to detect those cases:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">parseInt<\/span>( <span class=\"hljs-string\">\"hello\"<\/span>, <span class=\"hljs-number\">10<\/span> ) <span class=\"hljs-comment\">\/\/ NaN<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">isNaN<\/span>( <span class=\"hljs-built_in\">parseInt<\/span>(<span class=\"hljs-string\">\"hello\"<\/span>, <span class=\"hljs-number\">10<\/span>) ) <span class=\"hljs-comment\">\/\/ true<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Division by zero results in Infinity:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-number\">1<\/span> \/ <span class=\"hljs-number\">0<\/span> <span class=\"hljs-comment\">\/\/ Infinity<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Both NaN and Infinity are of type \"number\":\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">typeof<\/span> <span class=\"hljs-literal\">NaN<\/span> <span class=\"hljs-comment\">\/\/ \"number\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">typeof<\/span> <span class=\"hljs-literal\">Infinity<\/span> <span class=\"hljs-comment\">\/\/ \"number\"<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Note that NaN compares in a strange way:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-literal\">NaN<\/span> === <span class=\"hljs-literal\">NaN<\/span> <span class=\"hljs-comment\">\/\/ false (!)<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>But:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-literal\">Infinity<\/span> === <span class=\"hljs-literal\">Infinity<\/span> <span class=\"hljs-comment\">\/\/ true<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Integer\">Integer<\/h3>\n<p>An integer is a plain Number type, but whenever explicitly mentioned, indicates that a non-floating-point number is expected.\n<\/p>\n<h3 id=\"Float\">Float<\/h3>\n<p>A float is a plain Number type, just as Integer, but whenever explicitly mentioned, indicates that a floating-point number is expected.\n<\/p>\n<h2 id=\"Boolean\">Boolean<\/h2>\n<p>A boolean in JavaScript can be either true or false:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">if<\/span> ( <span class=\"hljs-literal\">true<\/span> ) <span class=\"hljs-built_in\">console<\/span>.log( <span class=\"hljs-string\">\"always!\"<\/span> );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">if<\/span> ( <span class=\"hljs-literal\">false<\/span> ) <span class=\"hljs-built_in\">console<\/span>.log( <span class=\"hljs-string\">\"never!\"<\/span> );<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h2 id=\"Object\">Object<\/h2>\n<p>Everything in JavaScript is an object, though some are more objective (haha). The easiest way to create an object is the object literal:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> x = {};<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> y = {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">\"Pete\"<\/span>,<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-attr\">age<\/span>: <span class=\"hljs-number\">15<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>};<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>The type of an object is \"object\":\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">typeof<\/span> {} <span class=\"hljs-comment\">\/\/ \"object\"<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Dot_Notation\">Dot Notation<\/h3>\n<p>You can write and read properties of an object using the dot notation:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>y.name <span class=\"hljs-comment\">\/\/ \"Pete\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>y.age <span class=\"hljs-comment\">\/\/ 15<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x.name = y.name + <span class=\"hljs-string\">\" Pan\"<\/span> <span class=\"hljs-comment\">\/\/ \"Pete Pan\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x.age = y.age + <span class=\"hljs-number\">1<\/span> <span class=\"hljs-comment\">\/\/ 16<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Array_Notation\">Array Notation<\/h3>\n<p>Or you write and read properties using the array notation, which allows you to dynamically choose the property:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n7\">7<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> operations = {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-attr\">increase<\/span>: <span class=\"hljs-string\">\"++\"<\/span>,<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-attr\">decrease<\/span>: <span class=\"hljs-string\">\"--\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>};<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> operation = <span class=\"hljs-string\">\"increase\"<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>operations[ operation ] <span class=\"hljs-comment\">\/\/ \"++\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>operations[ <span class=\"hljs-string\">\"multiply\"<\/span> ] = <span class=\"hljs-string\">\"*\"<\/span>; <span class=\"hljs-comment\">\/\/ \"*\"<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Iteration\">Iteration<\/h3>\n<p>Iterating over objects is easy with the for-in-loop:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n7\">7<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> obj = {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">\"Pete\"<\/span>,<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-attr\">age<\/span>: <span class=\"hljs-number\">15<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>};<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">for<\/span>( key <span class=\"hljs-keyword\">in<\/span> obj ) {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  alert( <span class=\"hljs-string\">\"key is \"<\/span> + [ key ] + <span class=\"hljs-string\">\", value is \"<\/span> + obj[ key ] );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>}<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Note that for-in-loop can be spoiled by extending <code>Object.prototype<\/code> (see <a href=\"https:\/\/web.archive.org\/web\/20200416084623\/https:\/\/erik.eae.net\/archives\/2005\/06\/06\/22.13.54\/\" class=\"external text\" title=\"https:\/\/web.archive.org\/web\/20200416084623\/https:\/\/erik.eae.net\/archives\/2005\/06\/06\/22.13.54\/\">Object.prototype is verboten<\/a>) so take care when using other libraries.\n<\/p>\n<p>jQuery provides a generic <a href=\"\/jQuery.each\/\"><em>each<\/em> function<\/a> to iterate over properties of objects, as well as elements of arrays:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>jQuery.each( obj, <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"> key, value <\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-built_in\">console<\/span>.log( <span class=\"hljs-string\">\"key\"<\/span>, key, <span class=\"hljs-string\">\"value\"<\/span>, value );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>});<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>The drawback is that the callback is called in the context of each value and you therefore lose the context of your own object if applicable. More on this below at Functions.\n<\/p>\n\n<h3 id=\"Boolean_default_3\">Boolean default<\/h3>\n<p>An object, no matter if it has properties or not, never defaults to false:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>!{} <span class=\"hljs-comment\">\/\/ false<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>!!{} <span class=\"hljs-comment\">\/\/ true<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Prototype\">Prototype<\/h3>\n<p>All objects have a prototype property. Whenever the interpreter looks for a property, it also checks in the object's prototype if the property is not found on the object itself. jQuery uses the prototype extensively to add methods to jQuery instances. Internally, jQuery makes <code>jQuery.fn<\/code> an alias of <code>jQuery.prototype<\/code> so you can use either one (though plugin developers have standardized on <code>fn<\/code>).\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n7\">7<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n8\">8<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n9\">9<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n10\">10<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n11\">11<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n12\">12<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n13\">13<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n14\">14<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> form = $(<span class=\"hljs-string\">\"#myform\"<\/span>);<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">console<\/span>.log( form.clearForm ); <span class=\"hljs-comment\">\/\/ undefined<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code> <\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-comment\">\/\/ jQuery.fn === jQuery.prototype<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>jQuery.fn.clearForm = <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.find( <span class=\"hljs-string\">\":input\"<\/span> ).each(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>    <span class=\"hljs-built_in\">this<\/span>.value = <span class=\"hljs-string\">\"\"<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  }).end();<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>};<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code> <\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-comment\">\/\/ works for all instances of jQuery objects, because<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-comment\">\/\/ the new method was added to the prototype<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">console<\/span>.log( form.clearForm ); <span class=\"hljs-comment\">\/\/ function<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>form.clearForm();<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n\n<h2 id=\"Array\">Array<\/h2>\n<p>Arrays in JavaScript are mutable lists with a few built-in methods. You can define arrays using the array literal:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> x = [];<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> y = [ <span class=\"hljs-number\">1<\/span>, <span class=\"hljs-number\">2<\/span>, <span class=\"hljs-number\">3<\/span> ];<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>The type of an array is \"object\":\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">typeof<\/span> []; <span class=\"hljs-comment\">\/\/ \"object\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">typeof<\/span> [ <span class=\"hljs-number\">1<\/span>, <span class=\"hljs-number\">2<\/span>, <span class=\"hljs-number\">3<\/span> ]; <span class=\"hljs-comment\">\/\/ \"object\"<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Reading and writing elements to an array uses the array-notation:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>x[ <span class=\"hljs-number\">0<\/span> ] = <span class=\"hljs-number\">1<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>y[ <span class=\"hljs-number\">2<\/span> ] <span class=\"hljs-comment\">\/\/ 3<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Iteration_2\">Iteration<\/h3>\n<p>An array has a length property that is useful for iteration:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">for<\/span> ( <span class=\"hljs-keyword\">var<\/span> i = <span class=\"hljs-number\">0<\/span>; i &lt; a.length; i++ ) {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-comment\">\/\/ Do something with a[i]<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>}<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>When performance is critical, reading the length property only once can help to speed things up. This should be used only when a performance bottleneck was discovered:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">for<\/span> ( <span class=\"hljs-keyword\">var<\/span> i = <span class=\"hljs-number\">0<\/span>, j = a.length; i &lt; j; i++ ) {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-comment\">\/\/ Do something with a[i]<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>}<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Another variation defines a variable that is filled for each iteration, removing the array-notation from the loop-body. It does not work when the array contains 0 or empty strings!\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">for<\/span> ( <span class=\"hljs-keyword\">var<\/span> i = <span class=\"hljs-number\">0<\/span>, item; item = a[i]; i++ ) {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-comment\">\/\/ Do something with item<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>}<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>jQuery provides a generic <a href=\"\/jQuery.each\/\"><em>each<\/em> function<\/a> to iterate over element of arrays, as well as properties of objects:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> x = [ <span class=\"hljs-number\">1<\/span>, <span class=\"hljs-number\">2<\/span>, <span class=\"hljs-number\">3<\/span> ];<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>jQuery.each( x, <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"> index, value <\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-built_in\">console<\/span>.log( <span class=\"hljs-string\">\"index\"<\/span>, index, <span class=\"hljs-string\">\"value\"<\/span>, value );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>});<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>The drawback is that the callback is called in the context of each value and you therefore lose the context of your own object if applicable. More on this below at Functions.\n<\/p>\n<p>The length property can also be used to add elements to the end of an array. That is equivalent to using the push-method:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> x = [];<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x.push( <span class=\"hljs-number\">1<\/span> );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x[ x.length ] = <span class=\"hljs-number\">2<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x <span class=\"hljs-comment\">\/\/ [ 1, 2 ]<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>You'll see both variations a lot when looking through JavaScript library code.\n<\/p>\n<p>Other built-in methods are reverse, join, shift, unshift, pop, slice, splice and sort:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n7\">7<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n8\">8<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> x = [ <span class=\"hljs-number\">0<\/span>, <span class=\"hljs-number\">3<\/span>, <span class=\"hljs-number\">1<\/span>, <span class=\"hljs-number\">2<\/span> ];<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x.reverse()      <span class=\"hljs-comment\">\/\/ [ 2, 1, 3, 0 ]<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x.join(<span class=\"hljs-string\">\" \u2013 \"<\/span>)    <span class=\"hljs-comment\">\/\/ \"2 - 1 - 3 - 0\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x.pop()          <span class=\"hljs-comment\">\/\/ [ 2, 1, 3 ]<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x.unshift( -<span class=\"hljs-number\">1<\/span> )  <span class=\"hljs-comment\">\/\/ [ -1, 2, 1, 3 ]<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x.shift()        <span class=\"hljs-comment\">\/\/ [ 2, 1, 3 ]<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x.sort()         <span class=\"hljs-comment\">\/\/ [ 1, 2, 3 ]<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>x.splice( <span class=\"hljs-number\">1<\/span>, <span class=\"hljs-number\">2<\/span> ) <span class=\"hljs-comment\">\/\/ [ 2, 3 ]<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Note: .unshift() method does not return a length property in Internet Explorer.\n<\/p>\n<h3 id=\"Boolean_Default_4\">Boolean Default<\/h3>\n<p>An array, no matter if it has elements or not, never defaults to false:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>![] <span class=\"hljs-comment\">\/\/ false<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>!![] <span class=\"hljs-comment\">\/\/ true<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Array.3CType.3E_Notation\">Array&lt;Type&gt; Notation<\/h3>\n<p>In the jQuery API you'll often find the notation of Array&lt;Type&gt;:\n<\/p>\n<pre>dragPrevention    Array&lt;String&gt;\n<\/pre>\n<p>This indicates that the method doesn't only expect an array as the argument, but also specifies the expected type. The notation is borrowed from Java 5's generics notation (or C++ templates).\n<\/p>\n<h2 id=\"ArrayLikeObject\">Array-Like Object<\/h2>\n<p>Either a true JavaScript Array or a JavaScript Object that contains a nonnegative integer <code>length<\/code> property and index properties from <code>0<\/code> up to <code>length - 1<\/code>. This latter case includes array-like objects commonly encountered in web-based code such as the <code>arguments<\/code> object and the <code>NodeList<\/code> object returned by many DOM methods.<\/p>\n<p>When a jQuery API accepts either plain Objects or Array-Like objects, a plain Object with a numeric <code>length<\/code> property will trigger the Array-Like behavior.<\/p>\n<h2 id=\"PlainObject\">PlainObject<\/h2>\n<p>The PlainObject type is a JavaScript object containing zero or more key-value pairs. The plain object is, in other words, an <code>Object<\/code> object. It is designated \"plain\" in jQuery documentation to distinguish it from other kinds of JavaScript objects: for example, <code>null<\/code>, user-defined arrays, and host objects such as <code>document<\/code>, all of which have a <code>typeof<\/code> value of \"object.\" The <code><a href=\"\/jQuery.isPlainObject\/\">jQuery.isPlainObject()<\/a><\/code> method identifies whether the passed argument is a plain object or not, as demonstrated below:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n7\">7<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n8\">8<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n9\">9<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n10\">10<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n11\">11<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">var<\/span> a = [];<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">var<\/span> d = <span class=\"hljs-built_in\">document<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">var<\/span> o = {};<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code> <\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">typeof<\/span> a; <span class=\"hljs-comment\">\/\/ object<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">typeof<\/span> d; <span class=\"hljs-comment\">\/\/ object<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">typeof<\/span> o; <span class=\"hljs-comment\">\/\/ object<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code> <\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  jQuery.isPlainObject( a ); <span class=\"hljs-comment\">\/\/ false<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  jQuery.isPlainObject( d ); <span class=\"hljs-comment\">\/\/ false<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  jQuery.isPlainObject( o ); <span class=\"hljs-comment\">\/\/ true<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n\n<h2 id=\"Null\">Null<\/h2>\n<p>The <code>null<\/code> keyword is a JavaScript literal that is commonly used to express the absence of an intentional value.<\/p>\n\n<h2 id=\"Date\">Date<\/h2>\n<p>The Date type is a JavaScript object that represents a single moment in time. Date objects are instantiated using their constructor function, which by default creates an object that represents the current date and time.\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">new<\/span> <span class=\"hljs-built_in\">Date<\/span>();<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>To create a Date object for an alternative date and time, pass numeric arguments in the following order: year, month, day, hour, minute, second, millisecond \u2014 although note that the month is zero-based, whereas the other arguments are one-based. The following creates a Date object representing January 1st, 2014, at 8:15.\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">new<\/span> <span class=\"hljs-built_in\">Date<\/span>( <span class=\"hljs-number\">2014<\/span>, <span class=\"hljs-number\">0<\/span>, <span class=\"hljs-number\">1<\/span>, <span class=\"hljs-number\">8<\/span>, <span class=\"hljs-number\">15<\/span> );<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n\n<h2 id=\"Function\">Function<\/h2>\n<p>A function in JavaScript can be either named or anonymous. Any function can be assigned to a variable or passed to a method, but passing member functions this way can cause them to be called in the context of another object (i.e. with a different \"this\" object).\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">named<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{}<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> handler = <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{}<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>You see a lot of anonymous functions in jQuery code:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-built_in\">document<\/span> ).ready(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{});<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-string\">\"a)\"<\/span> ).on( <span class=\"hljs-string\">\"click\"<\/span>, <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{});<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>$.ajax({<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-attr\">url<\/span>: <span class=\"hljs-string\">\"someurl.php\"<\/span>,<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-attr\">success<\/span>: <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{}<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>});<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>The type of a function is \"function\".\n<\/p>\n<h3 id=\"Arguments\">Arguments<\/h3>\n<p>Inside a function a special variable \"arguments\" is always available. It's similar to an array in that it has a length property, but it lacks the built-in methods of an array. The elements of the pseudo-array are the argument of the function call.\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">log<\/span>(<span class=\"hljs-params\"> x <\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-built_in\">console<\/span>.log( <span class=\"hljs-keyword\">typeof<\/span> x, <span class=\"hljs-built_in\">arguments<\/span>.length );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>}<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>log(); <span class=\"hljs-comment\">\/\/ \"undefined\", 0<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>log( <span class=\"hljs-number\">1<\/span> ); <span class=\"hljs-comment\">\/\/ \"number\", 1<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>log( <span class=\"hljs-string\">\"1\"<\/span>, <span class=\"hljs-string\">\"2\"<\/span>, <span class=\"hljs-string\">\"3\"<\/span> ); <span class=\"hljs-comment\">\/\/ \"string\", 3<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>The arguments object also has a callee property, which refers to the function you're inside of. For instance:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> awesome = <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{ <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">arguments<\/span>.callee; }<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>awesome() === awesome <span class=\"hljs-comment\">\/\/ true<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Context.2C_Call_and_Apply\">Context, Call and Apply<\/h3>\n<p>In JavaScript, the variable \"this\" always refers to the current context. By default, \"this\" refers to the window object. Within a function this context can change, depending on how the function is called.\n<\/p>\n<p>All event handlers in jQuery are called with the handling element as the context.\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-built_in\">document<\/span> ).ready(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-comment\">\/\/ this refers to window.document<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>});<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-string\">\"a)\"<\/span> ).on( <span class=\"hljs-string\">\"click\"<\/span>, <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-comment\">\/\/ this refers to an anchor DOM element<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>});<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>You can specify the context for a function call using the function-built-in methods call and apply. The difference between them is how they pass arguments. Call passes all arguments through as arguments to the function, while apply accepts an array as the arguments.\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">scope<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-built_in\">console<\/span>.log( <span class=\"hljs-built_in\">this<\/span>, <span class=\"hljs-built_in\">arguments<\/span>.length );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>}<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>scope() <span class=\"hljs-comment\">\/\/ window, 0<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>scope.call( <span class=\"hljs-string\">\"foobar\"<\/span>, [ <span class=\"hljs-number\">1<\/span>, <span class=\"hljs-number\">2<\/span> ] ); <span class=\"hljs-comment\">\/\/ \"foobar\", 1<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>scope.apply( <span class=\"hljs-string\">\"foobar\"<\/span>, [ <span class=\"hljs-number\">1<\/span>, <span class=\"hljs-number\">2<\/span> ] ); <span class=\"hljs-comment\">\/\/ \"foobar\", 2<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h3 id=\"Scope\">Scope<\/h3>\n<p>In JavaScript, all variables defined inside a function are only visible inside that function scope. Consider the following example:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n7\">7<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n8\">8<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-comment\">\/\/ global<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> x = <span class=\"hljs-number\">0<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-comment\">\/\/ private<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">var<\/span> x = <span class=\"hljs-number\">1<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-built_in\">console<\/span>.log( x ); <span class=\"hljs-comment\">\/\/ 1<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>})();<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">console<\/span>.log( x ); <span class=\"hljs-comment\">\/\/ 0<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>It defines a variable <i>x<\/i> in the global scope, then defines an anonymous function and executes it immediately (the additional parentheses are required for immediate execution). Inside the function another variable <i>x<\/i> is defined with a different value. It is only visible within that function and doesn't overwrite the global variable.\n<\/p>\n<h3 id=\"Closures\">Closures<\/h3>\n<p>Closures are created whenever a variable that is defined outside the current scope is accessed from within some inner scope. In the following example, the variable <i>counter<\/i> is visible within the create, increment, and print functions, but not outside of them.\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n7\">7<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n8\">8<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n9\">9<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n10\">10<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n11\">11<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n12\">12<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n13\">13<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n14\">14<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">create<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">var<\/span> counter = <span class=\"hljs-number\">0<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">return<\/span> {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>    <span class=\"hljs-attr\">increment<\/span>: <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>      counter++;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>    },<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>    <span class=\"hljs-attr\">print<\/span>: <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>      <span class=\"hljs-built_in\">console<\/span>.log( counter );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>    }<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  }<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>}<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> c = create();<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>c.increment();<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>c.print(); <span class=\"hljs-comment\">\/\/ 1<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>The pattern allows you to create objects with methods that operate on data that isn't visible to the outside\u2014the very basis of object-oriented programming.\n<\/p>\n<h3 id=\"Proxy_Pattern\">Proxy Pattern<\/h3>\n<p>Combining the above knowledge gives you as a JavaScript developer quite a lot of power. One way to combine that is to implement a proxy pattern in JavaScript, enabling the basics of aspect-oriented programming (AOP):\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n6\">6<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n7\">7<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n8\">8<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>(<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-comment\">\/\/ log all calls to setArray<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">var<\/span> proxied = jQuery.fn.setArray;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  jQuery.fn.setArray = <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>    <span class=\"hljs-built_in\">console<\/span>.log( <span class=\"hljs-built_in\">this<\/span>, <span class=\"hljs-built_in\">arguments<\/span> );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>    <span class=\"hljs-keyword\">return<\/span> proxied.apply( <span class=\"hljs-built_in\">this<\/span>, <span class=\"hljs-built_in\">arguments<\/span> );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  };<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>})();<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>The above wraps its code in a function to hide the \"proxied\"-variable. It saves jQuery's setArray-method in a closure and overwrites it. The proxy then logs all calls to the method and delegates the call to the original. Using apply(this, arguments) guarantees that the caller won't be able to notice the difference between the original and the proxied method.\n<\/p>\n<h2 id=\"Callback\">Callback<\/h2>\n<p>A callback is a plain JavaScript function passed to some method as an argument or option. Some callbacks are just events, called to give the user a chance to react when a certain state is triggered. jQuery's event system uses such callbacks everywhere:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-string\">\"body\"<\/span> ).on( <span class=\"hljs-string\">\"click\"<\/span>, <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"> event <\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-built_in\">console<\/span>.log( <span class=\"hljs-string\">\"clicked: \"<\/span> + event.target );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>});<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Most callbacks provide arguments and a context. In the event-handler example, the callback is called with one argument, an Event. The context is set to the handling element, in the above example, document.body.\n<\/p>\n<p>Some callbacks are required to return something, others make that return value optional. To prevent a form submission, a submit event handler can return false:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-string\">\"#myform\"<\/span> ).on( <span class=\"hljs-string\">\"submit\"<\/span>, <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-literal\">false<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>} );<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Instead of always returning false, the callback could check fields of the form for validity, and return false only when the form is invalid.\n<\/p>\n<h2 id=\"Error\">Error<\/h2>\n<p>An instance of an Error object is thrown as an exception when a runtime error occurs. Error can also be used as base to define user custom exception classes. In JavaScript an error can be thrown as shown below:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">throw<\/span> <span class=\"hljs-keyword\">new<\/span> <span class=\"hljs-built_in\">Error<\/span>( <span class=\"hljs-string\">\"The argument provided is incorrect\"<\/span> );<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>An error can also be thrown by the engine under some circumstances. For example, when trying to access a property of <code>null<\/code>:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> obj = <span class=\"hljs-literal\">null<\/span>;<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-built_in\">console<\/span>.log( obj.foo() );<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h2 id=\"Selector\">Selector<\/h2>\n<p>A selector is used in jQuery to select DOM elements from a DOM document. That document is, in most cases, the DOM document present in all browsers, but can also be an XML document received via Ajax.\n<\/p>\n<p>The selectors are a composition of CSS and custom additions. All selectors available in jQuery are documented on the <a href=\"\/category\/selectors\/\" title=\"Selectors\">Selectors API page<\/a>.\n<\/p>\n<p>There are lot of plugins that leverage jQuery's selectors in other ways. The validation plugin accepts a selector to specify a dependency, whether an input is required or not:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>emailrules: {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-attr\">required<\/span>: <span class=\"hljs-string\">\"#email:filled\"<\/span><\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>}<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>This would make a checkbox with name \"emailrules\" required only if the user entered an email address in the email field, selected via its id, filtered via a custom selector \":filled\" that the validation plugin provides.\n<\/p>\n<p>If Selector is specified as the type of an argument, it accepts everything that the jQuery constructor accepts, eg. Strings, Elements, Lists of Elements.\n<\/p>\n<h2 id=\"Event\">Event<\/h2>\n<p>jQuery's event system normalizes the event object according to W3C standards. The event object is guaranteed to be passed to the event handler (no checks for window.event required). It normalizes the target, relatedTarget, which, metaKey and pageX\/Y properties and provides both stopPropagation() and preventDefault() methods.\n<\/p>\n<p>Those properties are all documented, and accompanied by examples, on the <a href=\"\/category\/events\/event-object\/\" title=\"Events\">Event object<\/a> page.\n<\/p>\n<p>The standard events in the Document Object Model are: <code>blur<\/code>, <code>focus<\/code>, <code>load<\/code>, <code>resize<\/code>, <code>scroll<\/code>, <code>unload<\/code>, <code>beforeunload<\/code>, <code>click<\/code>, <code>dblclick<\/code>, <code>mousedown<\/code>, <code>mouseup<\/code>, <code>mousemove<\/code>, <code>mouseover<\/code>, <code>mouseout<\/code>, <code>mouseenter<\/code>, <code>mouseleave<\/code>, <code>change<\/code>, <code>select<\/code>, <code>submit<\/code>, <code>keydown<\/code>, <code>keypress,<\/code> and <code>keyup<\/code>. Since the DOM event names have predefined meanings for some elements, using them for other purposes is not recommended. jQuery's event model can trigger an event by any name on an element, and it is propagated up the DOM tree to which that element belongs, if any.\n<\/p>\n<h2 id=\"Element\">Element<\/h2>\n<p>An element in the Document Object Model (DOM) can have attributes, text, and children. It provides methods to traverse the parent and children and to get access to its attributes. Due to inconsistencies in DOM API specifications and implementations, however, those methods can be a challenge to use. jQuery provides a \"wrapper\" around those elements to help interacting with the DOM. But sometimes you will be working directly with DOM elements, or see methods that (also) accept DOM elements as arguments.\n<\/p>\n<p>Whenever you call jQuery's <code>.each()<\/code> method or one of its event methods on a jQuery collection, the context of the callback function \u2014 <code>this<\/code> \u2014 is set to a DOM element.\n<\/p>\n<p>Some properties of DOM elements are quite consistent among browsers. Consider this example of a simple onblur validation:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n2\">2<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n3\">3<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n4\">4<\/div>\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n5\">5<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-string\">\"input[type='text']\"<\/span> ).on( <span class=\"hljs-string\">\"blur\"<\/span>, <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  <span class=\"hljs-keyword\">if<\/span>( !<span class=\"hljs-built_in\">this<\/span>.value ) {<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>    alert( <span class=\"hljs-string\">\"Please enter some text!\"<\/span> );<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>  }<\/code><\/div><\/div><div class=\"container\"><div class=\"line\"><code>});<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>You could replace <code>this.value<\/code> with <code>$(this).val()<\/code> to access the value of the text input via jQuery, but in that case you wouldn't gain anything.\n<\/p>\n<h2 id=\"Text\">Text<\/h2>\n<p>Text is a node of the Document Object Model (DOM) that represents the textual content of an <a href=\"#Element\">element<\/a> or an attribute. Consider the following code:\n<\/p>\n<div class=\"syntaxhighlighter xml\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span> <span class=\"hljs-attr\">id<\/span>=<span class=\"hljs-string\">\"target\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">b<\/span>&gt;<\/span>Hello<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">b<\/span>&gt;<\/span> world<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">p<\/span>&gt;<\/span><\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>If you retrieve the children of the paragraph of the example as follows:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code><span class=\"hljs-keyword\">var<\/span> children = <span class=\"hljs-built_in\">document<\/span>.getElementById( <span class=\"hljs-string\">\"target\"<\/span> ).childNodes;<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>you obtain two children. The first one is the <a href=\"#Element\">element<\/a> representing the <code>b<\/code> tag. The second child is a text node containing the string \" world\".\n<\/p>\n<h2 id=\"jQuery\">jQuery<\/h2>\n<p>A jQuery object contains a collection of Document Object Model (DOM) elements that have been created from an HTML string or selected from a document. Since jQuery methods often use CSS selectors to match elements from a document, the set of elements in a jQuery object is often called a set of \"matched elements\" or \"selected elements\".\n<\/p>\n<p>The jQuery object itself behaves much like an array; it has a <code>length<\/code> property and the elements in the object can be accessed by their numeric indices <code>[0]<\/code> to <code>[length-1]<\/code>. Note that a jQuery object is not actually a Javascript Array object, so it does not have all the methods of a true Array object such as <code>join()<\/code>.\n<\/p>\n<p>Most frequently, you will use the jQuery() function to create a jQuery object. <code>jQuery()<\/code> can also be accessed by its familiar single-character alias of <code>$()<\/code>, unless you have called <code>jQuery.noConflict()<\/code> to disable this option. Many jQuery methods return the jQuery object itself, so that method calls can be chained:\n<\/p>\n<p>In API calls that return <code>jQuery<\/code>, the value returned will be the original jQuery object unless otherwise documented by that API. API methods such as <code>.filter()<\/code> or <code>.not()<\/code> modify their incoming set and thus return a new jQuery object.\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-string\">\"p\"<\/span> ).css( <span class=\"hljs-string\">\"color\"<\/span>, <span class=\"hljs-string\">\"red\"<\/span> ).find( <span class=\"hljs-string\">\".special\"<\/span> ).css( <span class=\"hljs-string\">\"color\"<\/span>, <span class=\"hljs-string\">\"green\"<\/span> );<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<p>Whenever you use a \"destructive\" jQuery method that potentially changes the set of elements in the jQuery object, such as <code>.filter()<\/code> or <code>.find()<\/code>, that method actually returns a new jQuery object with the resulting elements. To return to the previous jQuery object, you use the <code>.end()<\/code> method.\n<\/p>\n<p>A jQuery object may be empty, containing no DOM elements. You can create an empty jQuery object with <code>$()<\/code> (that is, passing no arguments at all). A jQuery object may also be empty if a selector doesn't select any elements, or if a chained method filters out all the elements. It is not an error; any further methods called on that jQuery object simply have no effect since they have no elements to act upon. So, in this example if there are no bad entries on the page then no elements will be colored red:\n<\/p>\n<div class=\"syntaxhighlighter javascript\">\n\t<table>\n\t\t<tbody>\n\t\t\t<tr>\n\t\t\t\t\n\t\t\t\t<td class=\"gutter\">\n\t\t\t\t\t\n\t\t\t\t\t\t<div class=\"line n1\">1<\/div>\n\t\t\t\t\t\n\t\t\t\t<\/td>\n\t\t\t\t\n\t\t\t\t<td class=\"code\">\n\t\t\t\t\t<pre><div class=\"container\"><div class=\"line\"><code>$( <span class=\"hljs-string\">\".badEntry\"<\/span> ).css({ <span class=\"hljs-attr\">color<\/span>: <span class=\"hljs-string\">\"red\"<\/span> });<\/code><\/div><\/div><\/pre>\n\t\t\t\t<\/td>\n\t\t\t<\/tr>\n\t\t<\/tbody>\n\t<\/table>\n<\/div>\n\n<h2 id=\"XMLHttpRequest\">XMLHttpRequest<\/h2>\n<p>Some of jQuery's Ajax functions return the native XMLHttpRequest (XHR) object, or pass it as an argument to success\/error\/complete handlers, so that you can do additional processing or monitoring on the request. Note that Ajax functions only return or pass an XHR object when an XHR object is actually used in the request. For example, JSONP requests and cross-domain GET requests use a script element rather than an XHR object.\n<\/p>\n<p>Although the XHR object is a standard, there are variations in its behavior on different browsers. Refer to the WHATWG site and Mozilla Developer Network for more information:\n<\/p>\n<ul><li> <a href=\"https:\/\/xhr.spec.whatwg.org\/\" class=\"external text\" title=\"https:\/\/xhr.spec.whatwg.org\/\">WHATWG living standard<\/a>\n<\/li><li> <a href=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/API\/XMLHttpRequest\" class=\"external text\" title=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/API\/XMLHttpRequest\">Mozilla Developer Network<\/a>\n<\/li><\/ul>\n<h2 id=\"jqXHR\">jqXHR<\/h2>\n<p>As of jQuery 1.5, the <a href=\"\/jQuery.ajax\/\">$.ajax()<\/a> method returns the jqXHR object, which is a superset of the XMLHTTPRequest object. For more information, see the <a href=\"\/jQuery.ajax\/#jqXHR\">jqXHR section of the $.ajax entry<\/a>\n<\/p>\n<h2 id=\"Thenable\">Thenable<\/h2>\n<p>Any object that has a <code>then<\/code> method.<\/p>\n<h2 id=\"Deferred\"> Deferred Object<\/h2>\n<p>As of jQuery 1.5, the <a href=\"\/category\/deferred-object\/\">Deferred<\/a> object provides a way to register multiple callbacks into self-managed callback queues, invoke callback queues as appropriate, and relay the success or failure state of any synchronous or asynchronous function.\n<\/p>\n<h2 id=\"Promise\"> Promise Object<\/h2>\n<p>This object provides a subset of the methods of the <a href=\"\/category\/deferred-object\/\">Deferred<\/a> object (<a href=\"\/deferred.then\/\"><code>then<\/code><\/a>, <a href=\"\/deferred.done\/\"><code>done<\/code><\/a>, <a href=\"\/deferred.fail\/\"><code>fail<\/code><\/a>, <a href=\"\/deferred.always\/\"><code>always<\/code><\/a>, <a href=\"\/deferred.pipe\/\"><code>pipe<\/code><\/a>, <a href=\"\/deferred.progress\/\"><code>progress<\/code><\/a>, <a href=\"\/deferred.state\/\"><code>state<\/code><\/a> and <a href=\"\/deferred.promise\/\"><code>promise<\/code><\/a>) to prevent users from changing the state of the Deferred.\n<\/p>\n<h2 id=\"Callbacks\">Callbacks Object<\/h2>\n<p>A multi-purpose object that provides a powerful way to manage callback lists. It supports adding, removing, firing, and disabling callbacks. The Callbacks object is created and returned by the <code>$.Callbacks<\/code> function and subsequently returned by most of that function's methods. <\/p>\n<h2 id=\"Document\">Document<\/h2>\n<p>A document object created by the browser's DOM parser, usually from a string representing HTML or XML.<\/p>\n<h2 id=\"XMLDocument\">XML Document<\/h2>\n<p>A document object created by the browser's XML DOM parser, usually from a string representing XML. XML documents have different semantics than HTML documents, but most of the traversing and manipulation methods provided by jQuery will work with them.<\/p>\n<h2 id=\"Assert\">Assert<\/h2>\n<p>A reference to or instance of the object holding all of QUnit's assertions. See the <a href=\"https:\/\/api.qunitjs.com\/config\/QUnit.assert\">API documentation for <code>QUnit.assert<\/code><\/a> for details.<\/p>","protected":false},"excerpt":{"rendered":"<p>This page documents data types appearing in jQuery function signatures, whether defined by JavaScript itself or further restricted by jQuery. Unless explicitly stated otherwise, jQuery functions require primitive values where applicable, and do not accept their Object-wrapped forms. If you want to study these concepts in depth, take a look at MDN. You should be &hellip; <a href=\"https:\/\/api.jquery.com\/Types\/\">Continue reading <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":2,"featured_media":0,"parent":0,"menu_order":0,"comment_status":"closed","ping_status":"closed","template":"","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-6","page","type-page","status-publish","hentry"],"_links":{"self":[{"href":"https:\/\/api.jquery.com\/wp-json\/wp\/v2\/pages\/6","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/api.jquery.com\/wp-json\/wp\/v2\/pages"}],"about":[{"href":"https:\/\/api.jquery.com\/wp-json\/wp\/v2\/types\/page"}],"author":[{"embeddable":true,"href":"https:\/\/api.jquery.com\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/api.jquery.com\/wp-json\/wp\/v2\/comments?post=6"}],"version-history":[{"count":2,"href":"https:\/\/api.jquery.com\/wp-json\/wp\/v2\/pages\/6\/revisions"}],"predecessor-version":[{"id":710,"href":"https:\/\/api.jquery.com\/wp-json\/wp\/v2\/pages\/6\/revisions\/710"}],"wp:attachment":[{"href":"https:\/\/api.jquery.com\/wp-json\/wp\/v2\/media?parent=6"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/api.jquery.com\/wp-json\/wp\/v2\/categories?post=6"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/api.jquery.com\/wp-json\/wp\/v2\/tags?post=6"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}