javascript-introduction and overview

Upload: arya-chinnu

Post on 07-Mar-2016

221 views

Category:

Documents


0 download

DESCRIPTION

introduction to javascript a guide line to javascripting progrms

TRANSCRIPT

JavaScript Basics

Based on jQuery Fundamentals by Rebecca Murphey http://github.com/rmurphey/jqfundamentals

Creative Commons Attribution-Share Alike 3.0 USContents

1 JavaScript Basics. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .3

Overview . . . . . . . . . . . . ..4

Syntax Basics . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4

Operators . . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4

Basic Operators . . . . . . .. . . . . .. . . . . . . . . . . . . . . . . . . . . . . .4

Operations on Numbers & Strings . . .. . . . . . . . . . . . . . . . . . . . . . . .5

Logical Operators . . . . . .. . . . . .. . . . . . . . . . . . . . . . . . . . . . . .5

Note . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .5

Comparison Operators . . .. . . . . . .. . . . . . . . . . . . . . . . . . . . . . .6

Conditional Code . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .6

Note . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .6

Truthy and Falsy Things . .. . . . . . .. . . . . . . . . . . . . . . . . . . . . . .7

Conditional Variable Assignment with The Ternary Operator . . . . . . . . . . . .7

Switch Statements . . . . . .. . . . . .. . . . . . . . . . . . . . . . . . . . . . . .7

Loops . . . . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .8

The for loop . . . . . . . . .. . . . . . .. . . . . . . . . . . . . . . . . . . . . . .8

The while loop . . . . . . .. . . . . . .. . . . . . . . . . . . . . . . . . . . . . .9

The do-while loop . . . . .. . . . . . .. . . . . . . . . . . . . . . . . . . . . . .9

Breaking and continuing . .. . . . . . .. . . . . . . . . . . . . . . . . . . . . . .10

Reserved Words . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .10

Arrays . . . . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .11

Objects . . . . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .11

Functions . . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .12

Using Functions . . . . . . .. . . . . . .. . . . . . . . . . . . . . . . . . . . . . .12

Self-Executing Anonymous Functions . .. . . . . . . . . . . . . . . . . . . . . . .13

Functions as Arguments . .. . . . . . .. . . . . . . . . . . . . . . . . . . . . . .13

Testing Type . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .13

The this keyword . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .14

Note . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .15

Scope . . . . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .16

Closures . . . . . . . . . . . . . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .17

2

1 JavaScript Basics

Home Smooth CoffeeScriptFormats Markdown

HYPERLINK "js-intro.pdf" PDF

HYPERLINK "js-intro.html" HTML3

1 JavaScript Basics

Overview

JavaScript is a rich and expressive language in its own right. This section covers the basic concepts of JavaScript, as well as some frequent pitfalls for people who have not used JavaScript before. While it will be of particular value to people with no programming experience, even people who have used other programming languages may benefit from learning about some of the peculiarities of JavaScript.

If youre interested in learning more about the JavaScript language, I highly recommend JavaScript: The Good Parts by Douglas Crockford.

Syntax Basics

Understanding statements, variable naming, whitespace, and other basic JavaScript syntax.

A simple variable declaration

varfoo = helloworld ;

Whitespace has no meaning outside of quotation marks

varfoo = helloworld ;

Parentheses indicate precedence

2*3+5;//ret urns11;m u l t i p l i c a t i o n hap pensfirst

2*(3+5);//ret urns16;a d d i t i o n hap pens first

Tabs enhance readability, but have no special meaning

varfoo = f u n c t i o n () { con sole . log ( hello );

};

Operators

Basic Operators

Basic operators allow you to manipulate values.

Concatenation

var foo = hello ; var bar = world ;

con sole . log ( foo + + bar ); // helloworld

Multiplication and division

2 * 3;

2 / 3;

Incrementing and decrementing

vari=1;

varj=++ i ;//pre - i n c r e m e n t :jequals2;iequals2

vark=i ++;//post - i n c r e m e n t :kequals2;iequals3

4

1 JavaScript Basics

Operations on Numbers & Strings

In JavaScript, numbers and strings will occasionally behave in ways you might not expect.

Addition vs. concatenation

var foo = 1; var bar = 2 ;

con sole . log ( foo + bar );// 12. uh oh

Forcing a string to act as a number

var foo = 1; var bar = 2 ;

// coerce the string to a number con sole . log ( foo + Number ( bar ));

The Number constructor, when called as a function (like above) will have the effect of casting its argument into a number. You could also use the unary plus operator, which does the same thing:

Forcing a string to act as a number (using the unary-plus operator)

con sole . log ( foo + + bar );

Logical Operators

Logical operators allow you to evaluate a series of operands using AND and OR operations.

Logical AND and OR operators

var foo = 1; var bar = 0; var baz = 2;

foo || bar ; // ret urns 1 , which is true bar || foo ; // ret urns 1 , which is true

foo && bar ; // ret urns 0 , which is false foo && baz ; // ret urns 2 , which is true baz && foo ; // ret urns 1 , which is true

Though it may not be clear from the example, the || operator returns the value of the first truthy operand, or, in cases where neither operand is truthy, itll return the last of both operands. The && operator returns the value of the first false operand, or the value of the last operand if both operands are truthy.

Be sure to consult the section called Truthy and Falsy Things for more details on which values evaluate to true and which evaluate to false.

Note

Youll sometimes see developers use these logical operators for flow control instead of using if state-ments. For example:

//dos o m e t h i n g with fooif foo is truthy

foo&&d o S o m e t h i n g ( foo );

// setbar to baz if baz istruthy ;

otherwise , set it to the return value of c r e a t e B a r ()varbar = baz ||c r e a t e B a r ();

5

1 JavaScript Basics

This style is quite elegant and pleasantly terse; that said, it can be really hard to read, especially for beginners. I bring it up here so youll recognize it in code you read, but I dont recommend using it until youre extremely comfortable with what it means and how you can expect it to behave.

Comparison Operators

Comparison operators allow you to test whether values are equivalent or whether values are identical.

Comparison operators

var foo = 1; var bar = 0; var baz = 1 ; var bim = 2;

foo == bar ; // ret urns false foo != bar ; // ret urns true

foo == baz ;//ret urnstrue ; ca r eful !

foo===baz ;//re turnsfalse

foo!==baz ;//re turnstrue

foo===pa r s e I n t ( baz );//re turnstrue

foo > bim ; bim > baz ; foo