Chapter 9 - JavaScript: Control Structures II

Slides:



Advertisements
Similar presentations
 2001 Prentice Hall, Inc. All rights reserved. 1 Chapter 7 - JavaScript: Introduction to Scripting Outline 7.1 Introduction 7.2 Simple Program: Printing.
Advertisements

1 JavaScript: Control Structures II. 2 whileCounter.html 1 2
Session 5 JavaScript/JScript: Control Structures II Matakuliah: M0114/Web Based Programming Tahun: 2005 Versi: 5.
Page 1 of 26 Javascript/Jscript Ch 7,8,9,10 Vadim Parizher Computer Science Department California State University, Northridge Spring 2003 Slides from.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Chapter 4 – C Program Control Outline 4.1Introduction.
Switch structure Switch structure selects one from several alternatives depending on the value of the controlling expression. The controlling expression.
Outline IS400: Development of Business Applications on the Internet Fall 2004 Instructor: Dr. Boris Jukic JavaScript: Control Structures: continued.
Control Structures Control structures control the flow of program execution. 3 types of control structures: sequence, selection.
 2008 Pearson Education, Inc. All rights reserved JavaScript: Control Statements II.
 2001 Prentice Hall, Inc. All rights reserved. 1 Chapter 8 - JavaScript: Control Structures I Outline 8.1 Introduction 8.2 Algorithms 8.3 Pseudocode 8.4.
 2001 Prentice Hall, Inc. All rights reserved. 1 Chapter 7 - JavaScript: Introduction to Scripting Outline 7.1 Introduction 7.2 Simple Program: Printing.
 2001 Prentice Hall, Inc. All rights reserved. 1 Chapter 10 - JavaScript: Functions Outline 10.1 Introduction 10.2 Program Modules in JavaScript 10.3.
Chapter 4: Decision Making with Control Structures and Statements JavaScript - Introductory.
 2004 Prentice Hall, Inc. All rights reserved. Chapter 9 - JavaScript: Control Statements II Outline 9.1 Introduction 9.2 Essentials of Counter-Controlled.
 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 5 – Control Structures: Part 2 Outline 5.1 Introduction 5.2 Essentials of Counter-Controlled.
 2002 Prentice Hall. All rights reserved. 1 Chapter 5 – Control Structures: Part 2 Outline 5.1Introduction 5.2 Essentials of Counter-Controlled Repetition.
 2001 Prentice Hall, Inc. All rights reserved. 1 Chapter 18 - WMLScript: Control Structures II Outline 18.1 Introduction 18.2 Essentials of Counter-Controlled.
JavaScript: Control Structures September 27, 2005 Slides modified from Internet & World Wide Web: How to Program (3rd) edition. By Deitel, Deitel,
Chapter 3 Functions, Events, and Control Structures JavaScript, Third Edition.
 2001 Prentice Hall, Inc. All rights reserved. 1 Chapter 8 - JavaScript: Control Structures I Outline 8.1 Introduction 8.2 Algorithms 8.3 Pseudocode 8.4.
1 JavaScript: Control Structures. 2 Control Structures Flowcharting JavaScript’s sequence structure.
JavaScript: Control Structures September 27, 2005 Slides modified from Internet & World Wide Web: How to Program (3rd) edition. By Deitel, Deitel,
JavaScript, Fourth Edition
 2000 Deitel & Associates, Inc. All rights reserved. Chapter 10 - JavaScript/JScript: Control Structures II Outline 10.1Introduction 10.2Essentials of.
 2001 Prentice Hall, Inc. All rights reserved. 1 Chapter 5 – Control Structures: Part 2 Outline 5.1 Introduction 5.2 Essentials of Counter-Controlled.
 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 5 – Control Structures: Part 2 Outline 5.1 Introduction 5.2 Essentials of Counter-Controlled.
 2008 Pearson Education, Inc. All rights reserved JavaScript: Control Statements II.
Chapter 7 - JavaScript: Introduction to Scripting Outline 7.1 Introduction 7.2 Simple Program: Printing a Line of Text in a Web Page 7.3 Another JavaScript.
5.1 Introduction Problem Solving –Requires understanding of: Building blocks Program-construction principles BZUPAGES.COM.
 2002 Prentice Hall. All rights reserved. 1 Chapter 5 – Control Structures: Part 2 Outline 5.1Introduction 5.2 Essentials of Counter-Controlled Repetition.
CSCI/CMPE 4341 Topic: Programming in Python Chapter 4: Control Structures (Part 2) Xiang Lian The University of Texas – Pan American Edinburg, TX
 2001 Prentice Hall, Inc. All rights reserved. 1 Chapter 9 - JavaScript: Control Structures II Outline 9.1 Introduction 9.2 Essentials of Counter-Controlled.
C Program Control September 15, OBJECTIVES The essentials of counter-controlled repetition. To use the for and do...while repetition statements.
JavaScript: Control Structures I Outline 1 Introduction 2 Algorithms 3 Pseudocode 4 Control Structures 5 if Selection Structure 6 if/else Selection Structure.
 2001 Prentice Hall, Inc. All rights reserved. Outline 1 JavaScript.
Chapter 14 - JavaScript/JScript: Control Structures I
Chapter 9 - JavaScript: Control Statements II
Chapter 4 – C Program Control
JavaScript: Control Structures I
Chapter 5- Control Structures: Part 2
Chapter 5 - Control Structures: Part 2
Control Statements: Part 2
Chapter 13 - JavaScript/JScript: Introduction to Scripting
Control Structures: Part 2
Chapter 4 - Program Control
Chapter 15 - JavaScript/JScript: Control Structures II
Ch 7: JavaScript Control Statements I.
Chapter 6: Conditional Statements and Loops
JavaScript: Control Statements.
JavaScript: Control Statements I
Chapter 5 – Control Structures: Part 2
JavaScript: Control Statements II
JavaScript: Control Statements (II)
JavaScript: Arrays.
Chapter 11 - JavaScript: Arrays
Chapter 8 - JavaScript: Control Structures I
Chapter 13 - Dynamic HTML: Object Model and Collections
Chapter 8 JavaScript: Control Statements, Part 2
JavaScript: Functions
Chapter 4 - Program Control
CSCI 3328 Object Oriented Programming in C# Chapter 5: C# Control Statement – Part II – Exercises UTPA – Fall 2012 This set of slides is revised from.
Chapter 3 – Control Structures
Chapter 6 Control Statements: Part 2
Chapter 7 - JavaScript: Introduction to Scripting
Chapter 5 – Control Structures: Part 2
Chapter 4 - Program Control
Chapter 8 - JavaScript: Control Structures I
Chapter 10 - JavaScript: Functions
Chapter 5 – Control Structures: Part 2
Chapter 8 JavaScript: Control Statements, Part 2
Presentation transcript:

Chapter 9 - JavaScript: Control Structures II Outline 9.1 Introduction 9.2 Essentials of Counter-Controlled Repetition 9.3 for Repetition Structure 9.4 Examples Using the for Structure 9.5 switch Multiple-Selection Structure 9.6 do/while Repetition Structure 9.7 break and continue Statements 9.8 Labeled break and continue Statements 9.9 Logical Operators 9.10 Summary of Structured Programming

1 <?xml version = "1.0"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 4 5 <!-- Fig. 9.1: WhileCounter.html --> 6 <!-- Counter-Controlled Repetition --> 7 8 <html xmlns = "http://www.w3.org/1999/xhtml"> 9 <head> 10 <title>Counter-Controlled Repetition</title> 11 12 <script type = "text/javascript"> 13 <!-- 14 var counter = 1; // initialization 15 16 while ( counter <= 7 ) { // repetition condition 17 document.writeln( "<p style = \"font-size: " + 18 counter + "ex\">XHTML font size " + counter + 19 "ex</p>" ); 20 ++counter; // increment 21 } 22 // --> 23 </script> 24 25 </head><body></body> 26 </html> whileCounter.html The while loop will continue until the value of counter is greater than 7. Increment the counter.

Program Output

ForCounter.html Initialization Repetition condition Incrementing 1 <?xml version = "1.0"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 4 5 <!-- Fig. 9.2: ForCounter.html --> 6 <!-- Counter-Controlled Repetition with for structure --> 7 8 <html xmlns = "http://www.w3.org/1999/xhtml"> 9 <head> 10 <title>Counter-Controlled Repetition</title> 11 12 <script type = "text/javascript"> 13 <!-- 14 // Initialization, repetition condition and 15 // incrementing are all included in the for 16 // structure header. 17 for ( var counter = 1; counter <= 7; ++counter ) 18 document.writeln( "<p style = \"font-size: " + 19 counter + "ex\">XHTML font size " + counter + 20 "ex</p>" ); 21 // --> 22 </script> 23 24 </head><body></body> 25 </html> ForCounter.html Initialization Repetition condition Incrementing

Program Output

9.3 For Repetition Structure keyword Control variable name Final value of control variable for which the condition is true for ( var counter = 1 ; counter <= 7 ; ++counter ) Initial value of control variable Increment of control variable Loop-continuation condition Fig. 9.3 Components of a typical for structure header.

9.4 Examples Using the for Structure Establish initial value of control variable. var counter = 1 document.writeln( true "<p style=\"font-size: " counter <= 7 ++counter + counter + Increment "ex\">XHTML font size " + the control false counter + "ex</p>" ); variable. Body of loop Determine if final value (this may be many statements) of control variable has been reached. Fig. 9.4 Flowcharting a typical for repetition structure.

Sum.html Program Output 1 <?xml version = "1.0"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 4 5 <!-- Fig. 9.5: Sum.html --> 6 <!-- Using the for repetition structure --> 7 8 <html xmlns = "http://www.w3.org/1999/xhtml"> 9 <head> 10 <title>Sum the Even Integers from 2 to 100</title> 11 12 <script type = "text/javascript"> 13 <!-- 14 var sum = 0; 15 16 for ( var number = 2; number <= 100; number += 2 ) 17 sum += number; 18 19 document.writeln( "The sum of the even integers " + 20 "from 2 to 100 is " + sum ); 21 // --> 22 </script> 23 24 </head><body></body> 25 </html> Sum.html Program Output The for loop will continue until the value of number is greater than 100. Initialization. Repetition condition. Incrementing.

Interest.html Opening table element. 1 <?xml version = "1.0"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 4 5 <!-- Fig. 9.6: interest.html --> 6 <!-- Using the for repetition structure --> 7 8 <html xmlns = "http://www.w3.org/1999/xhtml"> 9 <head> 10 <title>Calculating Compound Interest</title> 11 12 <script type = "text/javascript"> 13 <!-- 14 var amount, principal = 1000.0, rate = .05; 15 16 document.writeln( 17 "<table border = \"1\" width = \"100%\">" ); 18 document.writeln( 19 "<caption>Calculating Compound Interest</caption>" ); 20 document.writeln( 21 "<thead><tr><th align = \"left\">Year</th>" ); 22 document.writeln( 23 "<th align = \"left\">Amount on deposit</th>" ); 24 document.writeln( "</tr></thead>" ); 25 26 for ( var year = 1; year <= 10; ++year ) { 27 amount = principal * Math.pow( 1.0 + rate, year ); 28 document.writeln( "<tbody><tr><td>" + year + 29 "</td><td>" + Math.round( amount * 100 ) / 100 + 30 "</td></tr>" ); 31 } 32 33 document.writeln( "</tbody></table>" ); 34 // --> 35 </script> Interest.html Opening table element. Each iteration of the for loop creates a table row listing the year of the loan and the amount.

Interest.html Program Output 36 37 </head><body></body> 38 </html> Interest.html Program Output

1 <?xml version = "1.0"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 4 5 <!-- Fig. 9.7: SwitchTest.html --> 6 <!-- Using the switch structure --> 7 8 <html xmlns = "http://www.w3.org/1999/xhtml"> 9 <head> 10 <title>Switching between XHTML List Formats</title> 11 12 <script type = "text/javascript"> 13 <!-- 14 var choice, // user’s choice 15 startTag, // starting list item tag 16 endTag, // ending list item tag 17 validInput = true, // indicates if input is valid 18 listType; // list type as a string 19 20 choice = window.prompt( "Select a list style:\n" + 21 "1 (bullet), 2 (numbered), 3 (lettered)", "1" ); 22 23 switch ( choice ) { 24 case "1": 25 startTag = "<ul>"; 26 endTag = "</ul>"; 27 listType = "<h1>Bullet List</h1>"; 28 break; 29 case "2": 30 startTag = "<ol>"; 31 endTag = "</ol>"; 32 listType = "<h1>Ordered List: Numbered</h1>"; 33 break; SwitchTest.html Variable choice is given the value input by the user in the prompt dialog. The value of choice is evaluated against each of the values of the case labels. The break statement causes program control to proceed with the first statement after the switch structure.

If none of the cases match, variable validInput is set to false. 35 startTag = "<ol type = \"A\">"; 36 endTag = "</ol>"; 37 listType = "<h1>Ordered List: Lettered</h1>"; 38 break; 39 default: 40 validInput = false; 41 } 42 43 if ( validInput == true ) { 44 document.writeln( listType + startTag ); 45 46 for ( var i = 1; i <= 3; ++i ) 47 document.writeln( "<li>List item " + i + "</li>" ); 48 49 document.writeln( endTag ); 50 } 51 else 52 document.writeln( "Invalid choice: " + choice ); 53 // --> 54 </script> 55 56 </head> 57 <body> 58 <p>Click Refresh (or Reload) to run the script again</p> 59 </body> 60 </html> SwitchTest.html If none of the cases match, variable validInput is set to false. If the user input a valid value, the list is created. Otherwise, the message “Invalid choice” is displayed in the browser.

Program Output

Program Output

9.5 switch Multiple-Selection Structure Fig. 9.8 switch multiple-selection structure.

The loop stops when the value of counter is greater than 6. 1 <?xml version = "1.0"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 4 5 <!-- Fig. 9.9: DoWhileTest.html --> 6 <!-- Using the do/while structure --> 7 8 <html xmlns = "http://www.w3.org/1999/xhtml"> 9 <head> 10 <title>Using the do/while Repetition Structure</title> 11 12 <script type = "text/javascript"> 13 <!-- 14 var counter = 1; 15 16 do { 17 document.writeln( "<h" + counter + ">This is " + 18 "an h" + counter + " level head" + "</h" + 19 counter + ">" ); 20 21 ++counter; 22 } while ( counter <= 6 ); 23 // --> 24 </script> 25 26 </head><body></body> 27 </html> DoWhileTest.html Each iteration of the do/while loop writes a line of text with a header element to the XHTML document. The loop stops when the value of counter is greater than 6.

Program Output

9.6 do/while Repetition Structure action(s) true condition false Fig. 9.10 Flowcharting the do/while repetition structure.

1 <?xml version = "1.0"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 4 5 <!-- Fig. 9.11: BreakTest.html --> 6 <!-- Using the break statement --> 7 8 <html xmlns = "http://www.w3.org/1999/xhtml"> 9 <head> 10 <title> 11 Using the break Statement in a for Structure 12 </title> 13 14 <script type = "text/javascript"> 15 <!-- 16 for ( var count = 1; count <= 10; ++count ) { 17 if ( count == 5 ) 18 break; // break loop only if count == 5 19 20 document.writeln( "Count is: " + count + "<br />" ); 21 } 22 23 document.writeln( 24 "Broke out of loop at count = " + count ); 25 // --> 26 </script> 27 28 </head><body></body> 29 </html> BreakTest.html When the value of variable count equals 5, the break statement causes program control to proceed to the first line outside the for loop.

Program Output

1 <?xml version = "1.0"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 4 5 <!-- Fig. 9.12: ContinueTest.html --> 6 <!-- Using the break statement --> 7 8 <html xmlns = "http://www.w3.org/1999/xhtml"> 9 <head> 10 <title> 11 Using the continue Statement in a for Structure 12 </title> 13 14 <script type = "text/javascript"> 15 <!-- 16 for ( var count = 1; count <= 10; ++count ) { 17 if ( count == 5 ) 18 continue; // skip remaining code in loop 19 // only if count == 5 20 21 document.writeln( "Count is: " + count + "<br />" ); 22 } 23 24 document.writeln( "Used continue to skip printing 5" ); 25 // --> 26 </script> 27 28 </head><body></body> 29 </html> ContinueTest.html When the value of variable count equals 5, the continue statement causes program control to proceed to the next iteration of the for loop.

Program Output

stop is the label for the break statement. 1 <?xml version = "1.0"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 4 5 <!-- Fig. 9.13: BreakLabelTest.html --> 6 <!-- Using the break statement with a Label --> 7 8 <html xmlns = "http://www.w3.org/1999/xhtml"> 9 <head> 10 <title>Using the break Statement with a Label</title> 11 12 <script type = "text/javascript"> 13 <!-- 14 stop: { // labeled compound statement 15 for ( var row = 1; row <= 10; ++row ) { 16 for ( var column = 1; column <= 5 ; ++column ) { 17 18 if ( row == 5 ) 19 break stop; // jump to end of stop block 20 21 document.write( "* " ); 22 } 23 24 document.writeln( "<br />" ); 25 } 26 27 // the following line is skipped 28 document.writeln( "This line should not print" ); 29 } 30 BreakLabelTest.html stop is the label for the break statement. When the break statement is encountered, program control proceeds to the first line outside the stop block and not just the for loop where the statement is found.

BreakLabelTest.html Program Output 31 document.writeln( "End of script" ); 32 // --> 33 </script> 34 35 </head><body></body> 36 </html> BreakLabelTest.html Program Output

nextRow is the label for the continue statement. 1 <?xml version = "1.0"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 4 5 <!-- Fig. 9.14: ContinueLabelTest.html --> 6 <!-- Using the continue statement --> 7 8 <html xmlns = "http://www.w3.org/1999/xhtml"> 9 <head> 10 <title>Using the continue Statement with a Label</title> 11 12 <script type = "text/javascript"> 13 <!-- 14 nextRow: // target label of continue statement 15 for ( var row = 1; row <= 5; ++row ) { 16 document.writeln( "<br />" ); 17 18 for ( var column = 1; column <= 10; ++column ) { 19 20 if ( column > row ) 21 continue nextRow; // next iteration of 22 // labeled loop 23 24 document.write( "* " ); 25 } 26 } 27 // --> 28 </script> 29 30 </head><body></body> 31 </html> ContinueLabelTest.html nextRow is the label for the continue statement. If the value of variable column is greater than the value of variable row, the continue statement causes the next interation of the loop. If the continue statement is performed, method write does not print the string “* “ in the XHTML document.

Program Output

9.9 Logical Operators

1 <?xml version = "1.0"?> 2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 3 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 4 5 <!-- Fig. 9.18: LogicalOperators.html --> 6 <!-- Demonstrating Logical Operators --> 7 8 <html xmlns = "http://www.w3.org/1999/xhtml"> 9 <head> 10 <title>Demonstrating the Logical Operators</title> 11 12 <script type = "text/javascript"> 13 <!-- 14 document.writeln( 15 "<table border = \"1\" width = \"100%\">" ); 16 17 document.writeln( 18 "<caption>Demonstrating Logical " + 19 "Operators</caption" ); 20 21 document.writeln( 22 "<tr><td width = \"25%\">Logical AND (&&)</td>" + 23 "<td>false && false: " + ( false && false ) + 24 "<br />false && true: " + ( false && true ) + 25 "<br />true && false: " + ( true && false ) + 26 "<br />true && true: " + ( true && true ) + 27 "</td>" ); 28 29 document.writeln( 30 "<tr><td width = \"25%\">Logical OR (||)</td>" + 31 "<td>false || false: " + ( false || false ) + 32 "<br />false || true: " + ( false || true ) + 33 "<br />true || false: " + ( true || false ) + 34 "<br />true || true: " + ( true || true ) + 35 "</td>" ); LogicalOperators.html Each expression will evaluate to true or false using the rules of logical AND. Each expression will evaluate to true or false using the rules of logical OR.

LogicalOperators.html Program Output 36 37 document.writeln( 38 "<tr><td width = \"25%\">Logical NOT (!)</td>" + 39 "<td>!false: " + ( !false ) + 40 "<br />!true: " + ( !true ) + "</td>" ); 41 42 document.writeln( "</table>" ); 43 // --> 44 </script> 45 46 </head><body></body> 47 </html> LogicalOperators.html Program Output These expressions demonstrate the use of logical NOT.

9.10 Summary of Structured Programming

9.10 Summary of Structured Programming Fig. 9.20 JavaScript’s single-entry/single-exit sequence, selection and repetition structures.

9.10 Summary of Structured Programming

9.10 Summary of Structured Programming Fig. 9.22 Simplest flowchart.

9.10 Summary of Structured Programming Rule 2 Rule 2 Rule 2 . . . Fig. 9.23 Repeatedly applying rule 2 of Fig. 9.21 to the simplest flowchart.

Rule 3 Rule 3 Rule 3 Fig. 9.24 Applying rule 3 of Fig. 9.21 to the simplest flowchart

9.10 Summary of Structured Programming Fig. 9.25 Stacked, nested and overlapped building blocks.

9.10 Summary of Structured Programming Fig. 9.26 Unstructured flowchart.