JavaScript - PowerPoint PPT Presentation

1 / 31
About This Presentation
Title:

JavaScript

Description:

var course = new Course('CIT597', 'Dr. Dave'); 19. Array literals ... var colors = new Array(3) ... This is similar to Java's for(type var : collection) loop ... – PowerPoint PPT presentation

Number of Views:22
Avg rating:3.0/5.0
Slides: 32
Provided by: DavidMa5
Category:
Tags: javascript | var

less

Transcript and Presenter's Notes

Title: JavaScript


1
JavaScript
  • Language Fundamentals

2
About JavaScript
  • JavaScript is not Java, or even related to Java
  • The original name for JavaScript was LiveScript
  • The name was changed when Java became popular
  • Now that Microsoft no longer likes Java, its name
    for their JavaScript dialect is Active Script
  • Statements in JavaScript resemble statements in
    Java, because both languages borrowed heavily
    from the C language
  • JavaScript should be fairly easy for Java
    programmers to learn
  • However, JavaScript is a complete, full-featured,
    complex language
  • JavaScript is seldom used to write complete
    programs
  • Instead, small bits of JavaScript are used to add
    functionality to HTML pages
  • JavaScript is often used in conjunction with HTML
    forms
  • JavaScript is reasonably platform-independent

3
Using JavaScript in a browser
  • JavaScript code is included within ltscriptgt tags
  • ltscript type"text/javascript"gt
    document.write("lth1gtHello World!lt/h1gt")
    lt/scriptgt
  • Notes
  • The type attribute is to allow you to use other
    scripting languages (but JavaScript is the
    default)
  • This simple code does the same thing as just
    putting lth1gtHello World!lt/h1gt in the same place
    in the HTML document
  • The semicolon at the end of the JavaScript
    statement is optional
  • The end of line marks the end of the statement,
    if the line can be interpreted as a complete
    statement
  • You can use semicolons to separate statements on
    the same line
  • Its probably a good idea to keep using semicolons

4
JavaScript isnt always available
  • Some old browsers do not recognize script tags
  • These browsers will ignore the script tags but
    will display the included JavaScript
  • To get old browsers to ignore the whole thing,
    use ltscript type"text/javascript"gt
    lt!-- document.write("Hello World!")
    //--gt lt/scriptgt
  • The lt!-- introduces an HTML comment
  • To get JavaScript to ignore the HTML close
    comment, --gt, the // starts a JavaScript comment,
    which extends to the end of the line
  • Some users turn off JavaScript
  • Use the ltnoscriptgtmessagelt/noscriptgt to display a
    message in place of whatever the JavaScript would
    put there

5
Example
  • John Smith's email ltscript languagejavascriptgt
    lt!-- var name "smithj" var host1
    "seas.up" var host2 "enn.edu" var addr
    document.write("lta hrefmai" "lto"
    name "64" host1 host2
    "?subjectCIT597" "gt" "John Smith"
    "lt/agt") //--gtlt/scriptgtltnoscriptgtsmithj at
    seaslt/noscriptgt

6
Where to put JavaScript
  • JavaScript can be put in the ltheadgt or in the
    ltbodygt of an HTML document
  • JavaScript functions should be defined in the
    ltheadgt
  • This ensures that the function is loaded before
    it is needed
  • JavaScript in the ltbodygt will be executed as the
    page loads
  • JavaScript functions can be put in a separate .js
    file
  • ltscript src"myJavaScriptFile.js"gtlt/scriptgt
  • Put this in the ltheadgt
  • An external .js file lets you use the same
    JavaScript on multiple HTML pages
  • The external .js file cannot itself contain a
    ltscriptgt tag
  • JavaScript can be put in an HTML form object,
    such as a button
  • This JavaScript will be executed when the form
    object is used

7
Primitive data types
  • JavaScript has three primitive types number,
    string, and boolean, and two special values, null
    and undefined
  • Everything else is an object
  • Numbers are always stored as floating-point
    values
  • Hexadecimal numbers begin with 0x
  • Some platforms treat 0123 as octal, others treat
    it as decimal
  • Since you cant be sure, avoid octal altogether!
  • Strings may be enclosed in single quotes or
    double quotes
  • Strings can contains \n (newline), \" (double
    quote), etc.
  • Booleans are either true or false
  • 0, "0", empty strings, undefined, null, and NaN
    are false , other values are true

8
Variables
  • Variables can be declared with a var statement
  • var pi 3.1416, x, y, name "Dr. Dave"
  • Variables names must begin with a letter or
    underscore
  • Variable names are case-sensitive
  • Variables are untyped (they can hold values of
    any type)
  • There are only two scopes local and global
  • Variables declared within a function are local to
    that function (accessible only within that
    function)
  • Variables declared outside a function are global
    (accessible from anywhere on the page)
  • Variables can also be declared implicitly, simply
    by assigning a value to them
  • Implicitly declared variables are always global

9
Operators, I
  • Because most JavaScript syntax is borrowed from C
    (and is therefore just like Java), well go
    through it quickly
  • Arithmetic operators (all numbers are
    floating-point) - /
    --
  • Comparison operators lt lt !
    gt gt
  • Logical operators ! (
    and are short-circuit operators)
  • Bitwise operators
    ltlt gtgt gtgtgt
  • Assignment operators - /
    ltlt gtgt gtgtgt

10
Operators, II
  • String operator
  • The conditional operator condition ?
    value_if_true value_if_false
  • Special equality tests
  • and ! try to convert their operands to the
    same type before performing the test
  • Not in C or Java and ! consider their
    operands unequal if they are of different types
  • Additional operators (to be discussed) new
    typeof void delete

11
Comments
  • Comments are as in C or Java
  • Between // and the end of the line
  • Between / and /
  • Javas javadoc comments, / ... /, are treated
    just the same as / ... / comments they have no
    special meaning in JavaScript

12
Statements, I
  • Most JavaScript statements are also borrowed from
    C
  • Assignment greeting "Hello, " name
  • Compound statement statement ...
    statement
  • If statements if (condition) statement
    if (condition) statement else statement
  • Familiar loop statements while (condition)
    statement do statement while (condition)
    for (initialization condition increment)
    statement

13
Statements, II
  • The switch statement switch (expression)
    case label statement
    break case label statement
    break ... default
    statement
  • Other familiar statements
  • break
  • continue
  • The empty statement, as in or

14
JavaScript is not Java
  • By now you should have realized that you already
    know a great deal of JavaScript
  • So far we have talked about things that are the
    same as in Java
  • JavaScript has some features that resemble
    features in Java
  • JavaScript has Objects and primitive data types
  • JavaScript has qualified names for example,
    document.write("Hello World")
  • JavaScript has Events and event handlers
  • Exception handling in JavaScript is almost the
    same as in Java
  • JavaScript has some features unlike anything in
    Java
  • Variable names are untyped the type of a
    variable depends on the value it is currently
    holding
  • Objects and arrays are defined in quite a
    different way
  • JavaScript has with statements and a new kind of
    for statement

15
Exception handling, I
  • Exception handling in JavaScript is almost the
    same as in Java
  • throw expression creates and throws an exception
  • The expression is the value of the exception, and
    can be of any type (often, it's a literal String)
  • try statements to try catch (e) //
    Notice no type declaration for e exception
    handling statements finally //
    optional, as usual code that is always
    executed
  • With this form, there is only one catch clause

16
Exception handling, II
  • try statements to try catch (e if test1)
    exception handling for the case that test1
    is true catch (e if test2) exception
    handling for when test1 is false and test2 is
    true catch (e) exception handling for
    when both test1and test2 are false finally
    // optional, as usual code that is always
    executed
  • Typically, the test would be something like
    e "InvalidNameExceptionbut it could be any
    kind of test

17
Object literals
  • In Java, classes describe objects, and all
    objects of that class have exactly the same
    fields and methods
  • JavaScript objects are more flexible than Java
    objects
  • JavaScript has object literals, written with this
    syntax
  • name1 value1 , ... , nameN valueN
  • Example (from Netscapes documentation)
  • car myCar "Saturn", 7 "Mazda",
    getCar CarTypes("Honda"), special Sales
  • The fields are myCar, getCar, 7 (this is a legal
    field name) , and special
  • "Saturn" and "Mazda" are Strings
  • CarTypes is a function call
  • Sales is a variable that was defined earlier
  • Example use document.write("I own a "
    car.myCar)

18
Three ways to create an object
  • You can use an object literal
  • var course number "CIT597", teacher "Dr.
    Dave"
  • You can use new to create a blank object, and
    add fields to it later
  • var course new Object()course.number
    "CIT597"course.teacher "Dr. Dave"
  • You can write and use a constructor
  • function Course(n, t) // functions should be
    defined in ltheadgt this.number n //
    keyword "this" is required, not optional
    this.teacher t
  • var course new Course("CIT597", "Dr. Dave")

19
Array literals
  • JavaScript has array literals, written with
    brackets and commas
  • Example color "red", "yellow", "green",
    "blue"
  • Arrays are zero-based color0 is "red"
  • If you put two commas in a row, the array has an
    empty element in that location
  • Example color "red", , , "green", "blue"
  • color has 5 elements
  • However, a single comma at the end is ignored
  • Example color "red", , , "green", "blue,
    still has 5 elements

20
Four ways to create an array
  • You can use an array literal var colors
    "red", "green", "blue"
  • You can use new Array() to create an empty array
  • var colors new Array()
  • You can add elements to the array
    latercolors0 "red" colors2 "blue"
    colors1"green"
  • You can use new Array(n) with a single numeric
    argument to create an array of that size
  • var colors new Array(3)
  • You can use new Array() with two or more
    arguments to create an array containing those
    values
  • var colors new Array("red","green", "blue")

21
The length of an array
  • If myArray is an array, its length is given by
    myArray.length
  • Array length can be changed by assignment beyond
    the current length
  • Example var myArray new Array(5) myArray10
    3
  • Arrays are sparse, that is, space is only
    allocated for elements that have been assigned a
    value
  • Example myArray50000 3 is perfectly OK
  • But indices must be between 0 and 232-1
  • As in C and Java, there are no two-dimensional
    arrays but you can have an array of arrays
    myArray53

22
Arrays and objects
  • Arrays are objects
  • car myCar "Saturn", 7 "Mazda"
  • car7 is the same as car.7
  • car.myCar is the same as car"myCar"
  • If you know the name of a property, you can use
    dot notation car.myCar
  • If you dont know the name of a property, but you
    have it in a variable (or can compute it), you
    must use array notation car"my" "Car"

23
Array functions
  • If myArray is an array,
  • myArray.sort() sorts the array alphabetically
  • myArray.sort(function(a, b) return a - b )
    sorts numerically
  • myArray.reverse() reverses the array elements
  • myArray.push() adds any number of new elements
    to the end of the array, and increases the
    arrays length
  • myArray.pop() removes and returns the last
    element of the array, and decrements the arrays
    length
  • myArray.toString() returns a string containing
    the values of the array elements, separated by
    commas (but not enclosed in brackets)

24
The forin loop
  • This is similar to Javas for(type var
    collection) loop
  • You can loop through the properties of an object
    withfor (variable in object) statement
  • Example for (var prop in course)
    document.write(prop " "
    courseprop)
  • Possible output teacher Dr. Dave
    number CIT597
  • The properties are accessed in an undefined order
  • If you add or delete properties of the object
    within the loop, it is undefined whether the loop
    will visit those properties
  • Arrays are objects applied to an array, forin
    will visit the properties 0, 1, 2,
  • Notice that course"teacher" is equivalent to
    course.teacher
  • You must use brackets if the property name is in
    a variable

25
More about the for...in loop
  • The for...in loop does not loop through all
    properties of an object
  • Built-in methods, and many built-in properties,
    are flagged as nonenumerable
  • All built-in properties of functions are
    nonenumerable
  • There are lots of little surprises like this in
    JavaScript ?

26
The with statement
  • with (object) statement uses the object as the
    default prefix for variables in the statement
  • If the accessed field doesnt exist, the prefix
    isnt used
  • For example, the following are equivalent
  • with (document.myForm) result.value
    compute(myInput.value)
  • document.myForm.result.value
    compute(document.myForm.myInput.value)
  • The with statement is useful when you are doing a
    lot of manipulation on the same object
  • The with statement can be confusing, and should
    be used with care

27
Functions
  • Functions should be defined in the ltheadgt of an
    HTML page, to ensure that they are loaded first
  • The syntax for defining a function isfunction
    name(arg1, , argN) statements
  • The function may contain return value
    statements
  • Any variables declared within the function are
    local to it
  • The syntax for calling a function is just
    name(arg1, , argN)
  • Simple parameters are passed by value, objects
    are passed by reference

28
Regular expressions
  • A regular expression can be written in either of
    two ways
  • Within slashes, such as re /abc/
  • With a constructor, such as re new
    RegExp("abc")
  • Regular expressions are almost the same as in
    Perl or Java (only a few unusual features are
    missing)
  • string.match(regexp) searches string for an
    occurrence of regexp
  • It returns null if nothing is found
  • If regexp has the g (global search) flag set,
    match returns an array of matched substrings
  • If g is not set, match returns an array whose 0th
    element is the matched text, extra elements are
    the parenthesized subexpressions, and the index
    property is the start position of the matched
    substring

29
Warnings
  • JavaScript is a big, complex language
  • Weve only scratched the surface
  • Its easy to get started in JavaScript, but if
    you need to use it heavily, plan to invest time
    in learning it well
  • Write and test your programs a little bit at a
    time
  • JavaScript is not totally platform independent
  • Expect different browsers to behave differently
  • Write and test your programs a little bit at a
    time
  • Browsers arent designed to report errors
  • Dont expect to get any helpful error messages
  • Write and test your programs a little bit at a
    time

30
Evaluation (i.e., Daves opinion)
  • JavaScript, like Java, is in the C family of
    languages
  • JavaScript has lots of convenience features
  • Global variables
  • Not having to declare variables at all
  • Untyped variables
  • Easy modification of objects
  • JavaScript is designed for programming in the
    small, not for large programs
  • Many features, such as global variables, are bad
    news for large programs
  • My experience is that JavaScript is very nice if
    you use it for the purposes that its designers
    expected, but very ugly if you try to use it in
    non-routine ways

31
The End
Write a Comment
User Comments (0)
About PowerShow.com