slides courtesy of Eric Roberts

Slides:



Advertisements
Similar presentations
Chapter 2—Programming by Example The Art and Science of An Introduction to Computer Science ERIC S. ROBERTS Java Programming by Example C H A P T E R 2.
Advertisements

Chapter 2 Programming by Example. A Holistic Perspective Three sections separated by blank lines. Program comment File: FileName.java
Classes and Objects Java programs are written as collections of classes, which serve as templates for individual objects. Each object is an instance of.
HTML and Web Page Design Presented by Frank H. Osborne, Ph. D. © 2005 ID 2950 Technology and the Young Child.
Chapter Day 5. © 2007 Pearson Addison-Wesley. All rights reserved2-2 Agenda Day 5 Questions from last Class?? Problem set 1 Posted  Introduction on developing.
1 Applets Chapter 1 To understand:  why applets are used to extend the capabilities of Web pages  how an applet is executed and know about the restrictions.
Developing a Basic Web Page with HTML
Chapter 2 Introduction to HTML5 Internet & World Wide Web How to Program, 5/e Copyright © Pearson, Inc All Rights Reserved.
1 Lesson 1 Quick HTML Know-How HTML and JavaScript BASICS, 4 th Edition Barksdale / Turner.
Computer Science 101 HTML. World Wide Web Invented by Tim Berners-Lee at CERN, the European Laboratory for Particle Physics in Geneva, Switzerland (roughly.
The WWW and HTML CMPT 281. Outline Hypertext The Internet The World-Wide-Web How the WWW works Web pages Markup HTML.
Creating a Basic Web Page
Chapter 16 The World Wide Web Chapter Goals Compare and contrast the Internet and the World Wide Web Describe general Web processing Describe several.
Introduction to HTML 1 Basharat Mahmood, Department of Computer Science, CIIT, Islamabad, Pakistan.
HTML: Hyptertext Markup Language Doman’s Sections.
How the Web Works Building a Website – Lesson 1. How People Access the Web Browsers People access websites using software called a web browser. To view.
CNIT 132 – Week 4 Cascading Style Sheets. Introducing Cascading Style Sheets Style sheets are files or forms that describe the layout and appearance of.
Introduction into JavaScript Java 1 JavaScript JavaScript programs run from within an HTML document The statements that make up a program in an HTML.
HTML Basics. HTML Coding HTML Hypertext markup language The code used to create web pages.
1 Introduction to Graphics b The last one or two sections of each chapter of the textbook focus on graphical issues b Most computer programs have graphical.
Simple Java Eric Roberts CS 106A January 11, 2016.
Simple Java Eric Roberts CS 106A January 11, 2010.
Department of Computer Science, Florida State University CGS 3066: Web Programming and Design Spring
Five-Minute Review 1.What steps do we distinguish in solving a problem by computer? 2.What are essential properties of an algorithm? 3.What is a definition.
Web Design Principles 5 th Edition Chapter 3 Writing HTML for the Modern Web.
HTML 5 (Part 1) – Start from SCRATCH. HTML 5 – Start from SCRATCH.
HTML Structure & syntax
Getting Started with HTML
Jerry Cain and Eric Roberts
Getting Started With HTML
Intro to HTML CS 1150 Spring 2017.
Working with Cascading Style Sheets
Multidimensional Arrays
Web Architecture & HTML
Tonga Institute of Higher Education IT 141: Information Systems
HTML5 Basics.
Project 1 Introduction to HTML.
Five-Minute Review What steps do we distinguish in solving a problem by computer? What are essential properties of an algorithm? What is a definition of.
Intro to HTML CS 1150 Fall 2016.
Lecturer (Dept. of Computer Science)
Essential Tags Web Design – Sec 3-3
Strings and Graphics Jerry Cain CS 106J April 12, 2017.
Review.
Web Languages What Is a Web Page?
CIIT-Human Computer Interaction-CSC456-Fall-2015-Mr
Project 1 Introduction to HTML.
Introduction to XHTML.
slides courtesy of Eric Roberts
Web Languages What Is a Web Page?
CS 106A, Lecture 12 More Graphics
TOPICS Chrome Dev Tools Process for Building a Static Website
The Canvas.
Chapter 2—Programming by Example
Tonga Institute of Higher Education IT 141: Information Systems
SSEA Computer Science: Track A
Tutorial Developing a Basic Web Page
Interactive Graphics Jerry Cain and Ryan Eberhardt CS 106AJ
Tonga Institute of Higher Education IT 141: Information Systems
slides courtesy of Eric Roberts
Multidimensional Arrays
Teaching slides Chapter 6.
Introduction to Web Application Design
Understand basic HTML and CSS terminology, concepts, and basic operations. Objective 3.01.
Document Structure & HTML
Introduction to World Wide Web
CIS 133 mashup Javascript, jQuery and XML
HyperText Markup Language
Handout-14 Applets and Graphics
Chapter 2—Programming by Example
slides courtesy of Eric Roberts
Presentation transcript:

slides courtesy of Eric Roberts JavaScript Programs Jerry Cain CS 106AJ October 3, 2018 slides courtesy of Eric Roberts

Once upon a time . . .

The World Wide Web One of the strengths of JavaScript is its integration with the World Wide Web, which was invented by Tim Berners-Lee at the CERN laboratory in Switzerland in 1989. In honor of his contributions to the web, Berners-Lee received the Turing Award in 2016. Named after computer scientist Alan Turing, the Turing Award is the highest honor in the computing field. Tim Berners-Lee (1955–) The ideas behind the the World Wide Web have a long history that begins before the computing age. Contributors to the idea of a world-wide interconnected repository of data include the Belgian bibliographer Paul Otlet, the MIT-based engineer and scientist Vannevar Bush, and computer visionary Ted Nelson.

JavaScript Programs

The "Hello World" Program In Monday’s class, you learned how to execute JavaScript functions in the console window. Today, your goal is to learn how to create and execute a complete JavaScript program. In 1978, Brian Kernighan and Turing Award winner Dennis Ritchie wrote the reference manual for the C programming language, one of the forerunners of JavaScript. On the first page of their book, the authors suggest that the first step in learning any language is to write a simple program that prints the words "hello, world" on the display. That advice remains sound today. 1.1 Getting Started The only way to learn a new programming language is to write programs in it. The first program to write is the same for all languages: Print the words hello, world This is the big hurdle; to leap over it you have to be able to create the program text somewhere, compile it, load it, run it, and find out where your output went. With these mechanical details mastered, everything else is comparatively easy. In C, the program to print “hello, world” is #include <stdio.h> main() { printf("hello, world"); }

HelloWorld in JavaScript The code for the HelloWorld program in JavaScript is similar to the C version from 1978 and looks like this: function HelloWorld () { console.log("hello, world"); } The HelloWorld function asks JavaScript to display the string "hello, world" on the console log. So far, so good. From here, you need to do the following things: Learn how to store this function in a file. Understand how to get JavaScript to execute the function. Figure out where the output goes. These steps are different in JavaScript than they are in most languages because JavaScript relies on a web-based model.

The Web’s Client-Server Model client browser web server O http://cs106aj.stanford.edu index.html 1. The user starts a web browser. 2. The user requests a web page. 3. The browser sends a network request for the page. 4. The server sends back a text file containing the HTML. 5. The browser interprets the HTML and renders the page image.

The Three Central Web Technologies Modern web pages depend on three technological tools: HTML (Hypertext Markup Language), CSS (Cascading Style Sheets), and JavaScript. These tools are used to control different aspects of the page: HTML is used to specify content and structure. CSS is used to control appearance and formatting. JavaScript is used to animate the page. You will have a chance to learn even more about HTML and CSS later in the quarter. For now, all you need to know is how to write a simple index.html file that will read and execute your JavaScript code.

The Structure of an HTML File An HTML file consists of the text to be displayed on the page, interspersed with various commands enclosed in angle brackets, which are known as tags. HTML tags usually occur in pairs. The opening tag begins with the name of the tag. The corresponding closing tag has the same name preceded by a slash. The effect of the tag applies to everything between the opening and closing tag. The only HTML tags you will need to use for most of the course appear in the template on the next page, which describes the structure of the HTML index file, which is conventionally called index.html.

Standard index.html Pattern The following components of index.html are standardized: Every file begins with a <!DOCTYPE html> tag The entire content is enclosed in <html> and </html> tags. The file begins with a <head> section that specifies the title and JavaScript files to load. The file includes a <body> section that specifies the page. <!DOCTYPE html> <html> <head> <title>title of the page</title> One or more script tags to load JavaScript code. </head> <body onload="function()"> Contents of the page, if any. </body> </html>

Creating the JavaScript Program File The first step in running a JavaScript program is creating a file that contains the definitions of the functions, along with comments that give human readers a better understanding of what the program does. Here, for example, is the complete HelloWorld.js file: /* * File: HelloWorld.js * ------------------- * This program displays "hello, world" on the console. It * is inspired by the first program in Brian Kernighan and * Dennis Ritchie's classic book, The C Programming Language. */ function HelloWorld() { console.log("hello, world"); }

Creating the HTML File (Version 1) A simple HTML file that loads the HelloWorld.js program looks like this: <!DOCTYPE html> <html> <head> <title>Hello World</title> <script type="text/javascript" src="HelloWorld.js"></script> </head> <body onload="HelloWorld()"></body> </html> This file asks the browser to load the file HelloWorld.js and then call the function HelloWorld once the page is loaded. The problem with this strategy is that it is hard "to find out where your output went" as Kernighan and Ritchie advise.

Creating the HTML File (Version 2) The output from the console log appears in different places in different browsers and usually requires the user to take some explicit action before it is visible. To make the console log easier to find, we have provided a library called JSConsole.js that redirects the console log to a much more visible area of the web page. <!DOCTYPE html> <html> <head> <title>Hello World</title> <script type="text/javascript" src="JSConsole.js"></script> <script type="text/javascript" src="HelloWorld.js"></script> </head> <body onload="HelloWorld()"></body> </html>

Simple Graphics In addition to JSConsole.js, CS 106AJ also supports a library called JSGraphics.js that makes it easy to write graphical programs. The structure of the index.html file for graphics programs is similar to the one used for HelloWorld. The BlueRectangle program introduced later uses the following index.html: <!DOCTYPE html> <html> <head> <title>Blue Rectangle</title> <script type="text/javascript" src="JSGraphics.js"></script> <script type="text/javascript" src="BlueRectangle.js"></script> </head> <body onload="BlueRectangle()"></body> </html>

The Graphics Model The JSGraphics.js library uses a graphics model based on the metaphor of a collage. A collage is similar to a child’s felt board that serves as a backdrop for colored shapes that stick to the felt surface. As an example, the following diagram illustrates the process of adding a blue rectangle and a red oval to a felt board: Note that newer objects can obscure those added earlier. This layering arrangement is called the stacking order.

The BlueRectangle Program function BlueRectangle() { let gw = GWindow(500, 200); let rect = GRect(150, 50, 200, 100); rect.setColor("Blue"); rect.setFilled(true); gw.add(rect); } rect function BlueRectangle() { let gw = GWindow(500, 200); let rect = GRect(150, 50, 200, 100); rect.setColor("Blue"); rect.setFilled(true); gw.add(rect); } rect BlueRectangle

The JavaScript Coordinate System BlueRectangle (0, 0) (150, 50) 200 pixels 100 pixels pixels Positions and distances on the screen are measured in terms of pixels, which are the small dots that cover the screen. Unlike traditional mathematics, JavaScript defines the origin of the coordinate system to be in the upper left corner. Values for the y coordinate increase as you move downward.

Systems of Classification In the mid-18th century, the Scandinavian botanist Carl Linnaeus revolutionized the study of biology by developing a new system for classifying plants and animals in a way that revealed their structural relationships and paved the way for Darwin’s theory of evolution a century later. Linnaeus’s contribution was to recognize that organisms fit into a hierarchy in which the placement of individual species reflects their anatomical similarities. Carl Linnaeus (1707–1778)

Biological Class Hierarchy Living Things Living Things Animals Arthropoda Insecta Hymenoptera Formicidae Iridomyrmex purpureus Plants Fungi Animals Kingdom Annelida Brachiopoda Mollusca Chordata Arthropoda Phylum Crustacea Arachnida Insecta Order Class Every red ant is also an animal, an arthropod, and an insect, as well as the other superclasses in the chain. Classification of the red ant Iridomyrmex purpureus Family Genus Species

Drawn after you, you pattern of all those. Instances vs. Patterns Drawn after you, you pattern of all those. —William Shakespeare, Sonnet 98 In thinking about any classification scheme—biological or otherwise—it is important to draw a distinction between a class and specific instances of that class. In the most recent example, the designation Iridomyrmex purpureus is not itself an ant, but rather a class of ant. There can be (and usually are) many ants, each of which is an individual of that class. Each of these fire ants is an instance of a particular class of ants. Each instance is of the species purpureus, the genus Iridomyrmex, the family Formicidae (which makes it an ant), and so on. Thus, each ant is not only an ant, but also an insect, an arthropod, and an animal.

The GObject Hierarchy The classes that represent graphical objects form a hierarchy, part of which looks like this: GObject GRect GOval GLine The GObject class represents the collection of all graphical objects. The three subclasses shown in this diagram correspond to particular types of objects: rectangles, ovals, and lines. Any GRect, GOval, or GLine is also a GObject.

Creating a GWindow Object The first step in writing a graphical program is to create a window using the following function declaration, where width and height indicate the size of the window: let gw = GWindow(width, height); gw.add(object) Adds an object to the window. gw.remove(object) Removes the object from the window. gw.add(object, x, y) Adds an object to the window after first moving it to (x, y). gw.getWidth() Returns the width of the graphics window in pixels. gw.getHeight() Returns the height of the graphics window in pixels. The following operations apply to a GWindow object:

Operations on the GObject Class The following operations apply to all GObjects: object.getX() Returns the x coordinate of this object. object.getY() Returns the y coordinate of this object. object.getWidth() Returns the width of this object. object.getHeight() Returns the height of this object. object.setColor(color) Sets the color of the object to the specified color. All coordinates and distances are measured in pixels. Each color is a string, such as "Red" or "White". The names of the standard colors are defined in Figure 4-5 on page 125.

Drawing Geometrical Objects Functions to create geometrical objects: GRect( x, y, width, height) Creates a rectangle whose upper left corner is at (x, y) of the specified size. GOval( x, y, width, height) Creates an oval that fits inside the rectangle with the same dimensions. GLine( x0, y0, x1, y1) Creates a line extending from (x0, y0) to (x1, y1). Methods shared by the GRect and GOval classes: object.setFilled( fill) If fill is true, fills in the interior of the object; if false, shows only the outline. object.setFillColor( color) Sets the color used to fill the interior, which can be different from the border.

The GRectPlusGOval Program function GRectPlusGOval() { let gw = GWindow(500, 200); let rect = GRect(150, 50, 200, 100); rect.setFilled(true); rect.setColor("Blue"); gw.add(rect); let oval = GOval(150, 50, 200, 100); oval.setFilled(true); oval.setColor("Red"); gw.add(oval); } oval rect function GRectPlusGOval() { let gw = GWindow(500, 200); let rect = GRect(150, 50, 200, 100); rect.setFilled(true); rect.setColor("Blue"); gw.add(rect); let oval = GOval(150, 50, 200, 100); oval.setFilled(true); oval.setColor("Red"); gw.add(oval); } rect oval GRectPlusGOval

The DrawDiagonals Program /* Constants */ const GWINDOW_WIDTH = 500; const GWINDOW_HEIGHT = 200; function DrawDiagonals() { let gw = GWindow(GWINDOW_WIDTH, GWINDOW_HEIGHT); gw.add(GLine(0, 0, GWINDOW_WIDTH, GWINDOW_HEIGHT)); gw.add(GLine(0, GWINDOW_HEIGHT, GWINDOW_WIDTH, 0)); } /* Constants */ const GWINDOW_WIDTH = 500; const GWINDOW_HEIGHT = 200; function DrawDiagonals() { let gw = GWindow(GWINDOW_WIDTH, GWINDOW_HEIGHT); gw.add(GLine(0, 0, GWINDOW_WIDTH, GWINDOW_HEIGHT)); gw.add(GLine(0, GWINDOW_HEIGHT, GWINDOW_WIDTH, 0)); } DrawDiagonals

The End