<p> OBJECT-ORIENTED PROGRAMMING</p><p>Overview</p><p>This chapter discusses object-oriented programming. You will learn how to create objects, instantiate objects, and use properties, methods, and event handlers associated with those objects. Then you will learn to create Web pages that interface with the objects. </p><p>Object Oriented Programming</p><p>Object-oriented programming allows programmers to access objects, properties, methods, and functions of an object without having to know about how the objects are created. </p><p>Object-oriented programming creates applications that are easily maintained and that work well with other applications. </p><p>Consider the following code section:</p><p>Lampbanner.htm <html> <head> <title>Custom Banner </title> </head> <body> <h1>Lamps for sale</h1></p><p><script language=JavaScript> function Lamp(txtAd){ this.bannerAd = txtAd; this.show = display; } function display(){ document.writeln(this.bannerAd); } var ad = "Sale Today<br>"; theLamp = new Lamp(ad); theLamp.show(); </script> </body> </html></p><p>View Lampbanner.htm</p><p>Object-Oriented Programming 1 Explanation of Code</p><p>Creating an object named Lamp using the keyword function. Function Lamp(txtAd) The lamp object is being passed one argument, txtAd. </p><p>This is a property inside the function. The txtAd variable is this.bannerAd = txtAd; assigned to the bannerAd property. this.show = display; This is creating a method called show</p><p>Creating a function called display, display receives no Function display(){ arguments</p><p>The var keyword is used to declare a variable in JavaScript. var ad = “Sale today! This line is declaring a variable named ad and assigning the <br>”; text message, “Sale today!<br>” to that variable. </p><p>This line creates a new Lamp object using the keyword new and names the theLamp = new Lamp(ad); object theLamp. It also passes the variable ad that is declared above to the Lamp object</p><p>This line is calling the show method of the new object. Notice the method is theLamp.show(); referred to using the name of the new object, theLamp, and the name of the method, show. </p><p>Object-Oriented Programming 2 Modify the above file with the value of the Ad variable, as shown below. The variable ad is used to change the value of txtAd argument of the Lamp object. This does not change the property of the object, only the value of the object.</p><p>Lampbanner2.htm</p><p><html><head> <title>Custom Banner</title> <script language = "javascript"> function Lamp(txtAd) { this.bannerAd = txtAd; this.show = display; } function display(){ document.writeln(this.bannerAd); } </script> <body> <h1>Lamps for Sale</h1> <script> var ad = "All lamps marked 50% off regular price!<br>" theLamp = new Lamp(ad) theLamp.show() </script> </body></html></p><p>View Lampbanner2.htm</p><p>Object-Oriented Programming 3 Object Definition (Creation of a Custom Object) Creation of a custom object consists of two steps: </p><p> The first task is to create the object definition. The object definition is the code that contains the methods and properties of the object</p><p> The second task is to create a new instance of the object. For the lamp example:</p><p>Step 1: Create the object definition by</p><p> function Lamp(txtAd){ this.bannerAd = txtAd; this.show = display; }</p><p>Step 2: Create a new instance of the object. </p><p> theLamp = new Lamp(ad);</p><p>Both steps are needed so you can call any of the methods that were defined in the object definition. </p><p>Note, the object definition is created by using the reserve word function. A function is a named grouping of one or more programming statements. </p><p>Object-Oriented Programming 4 Object Properties</p><p>Object properties are identified by the name of the object followed by a period, followed by the name of the property. </p><p>ObjectName.propertyName = value</p><p>Example: theLamp.bannerAd = “Sale Today!”</p><p>Until the instance of an object is created (in step 2 above), one cannot refer to the object by its name. But, one can refer to the object with the keyword “this”. </p><p> theLamp.bannerAd</p><p> theLamp Object name</p><p> bannerAd Property name</p><p> this.bannerAd this Object name</p><p> bannerAd Property name</p><p>Object-Oriented Programming 5 Object Methods</p><p>Objects may have methods. A method is a function that is called from an instance (a copy) of an object. For example, a method could be used to manipulate the properties of the object. </p><p>To add a method to an object, name the method and then assign the method to a function. The syntax for naming a method is: objectName.methodName = function name</p><p>Example:</p><p> theLamp.show = display; function display (){ document.writeln (“Hello world”); }</p><p>Some methods simply perform their actions when they are called, while other methods require more information before they can be processed. </p><p>A method can accept any number of required and optional arguments. </p><p> theLamp.show(ad)</p><p> theLamp Object name</p><p> show Method name</p><p>(…) Arguments</p><p>Object-Oriented Programming 6 Object Instantiation</p><p>The creation or defining an object does not mean that one can access it directly. One needs to create an instance of the object, then only it can be accessed.</p><p>Instantiation is the process of declaring and initializing an object. For example:</p><p>1. Specify a new name for the object.</p><p> a. TheLamp</p><p>2. Assign the new object to the object definition created earlier, using the new keyword.</p><p> a. new Lamp(ad);</p><p>The total instantiation process looks like this:</p><p> theLamp = new Lamp(ad);</p><p>If we want to instantiate another object, we can do that with a new name.</p><p> aLamp = new Lamp(newad); /* newad is a new variable</p><p>Now we have theLamp and aLamp, two instances of the Lamp object. </p><p>The methods of the object can be called by using the name of the instance. For example:</p><p> theLamp.show(); aLamp.show();</p><p>Object-Oriented Programming 7 Object Encapsulation</p><p>Encapsulation means that the properties and methods of an object are maintained within the object. Creating new objects does not change any of the properties and methods. </p><p>That is, the object is encapsulated from any change of property values, so the same object can be used again and again.</p><p>In the following example, two instances of the Lamp object, theLamp and theLamp2, are created. Both instances use the same method show(), but the property of the object, bannerAd, is assigned a different value by changing the value of the Ad variable. </p><p>Lampbanner3.htm <html><head> <title>Custom Banner</title> <script language = "javascript"> //Define object function Lamp(txtAd) { this.bannerAd = txtAd; this.show = display; } function display(){ document.writeln(this.bannerAd); } </script> <body> <h1>Lamps for Sale</h1> //Define a variable and a new instance of the object <script> var ad = "All lamps marked 50% off regular price!<br>" theLamp = new Lamp(ad) theLamp.show() </script> //Refefine the variable and a different instance of the Lamp object <script language = "javascript"> var ad = "25% Off all lamps!<br>" ; theLamp2 = new Lamp(ad); theLamp2.show(); </script> </body></html></p><p>View lampbanner3.htm</p><p>Object-Oriented Programming 8 Object Inheritance</p><p>All new objects created from the same object definition will maintain the same characteristics as the original object. This characteristic of objects is known as object inheritance. </p><p>You are not required to access all the properties and methods of the original object, but they are available, if they are needed. </p><p>Object-Oriented Programming 9 Adding Properties and Methods to an Instance of an Object</p><p>Although an instance of an object inherit all methods and properties of the object, but one can define additional methods and properties to the object instance.</p><p>In the example below, a new property lampColor is added to the instance theLamp2 of the Lamp object and assigned a value “red”. </p><p>Lampbanner4.htm <html><head> <title>Custom Banner</title> <script language = "javascript"> function Lamp(txtAd) { this.bannerAd = txtAd; this.show = display; } function display(){ document.writeln(this.bannerAd); } </script> <body> <h1>Lamps for Sale</h1> <script> var ad = "All lamps marked 50% off regular price!<br>" theLamp = new Lamp(ad) theLamp.show() </script> <script language = "javascript"> var ad = "25% Off all lamps!<br>" ; theLamp2 = new Lamp(ad); theLamp2.show(); </script> <script language = "javascript"> theLamp2.lampColor = "Red"; document.write(theLamp2.lampColor); </script> </body></html> </p><p>View lampbanner4.htm</p><p>Object-Oriented Programming 10 Using Built-In Objects</p><p>Browser software contains built-in objects termed as the Document Object Model (DOM). Using client-side scripting, programmers can access all of the objects, properties, and methods within the Document Object Model (DOM). </p><p>Not all browsers meet the current DOM standards. Netscape Navigator and Microsoft Internet Explorer do have built in DOMs, Quick but not all properties and methods are supported across browsers. Fact: The best way ensure your scripts will work is to preview the Web pages in all Web browsers in question. </p><p>All of the objects within the DOM have a position within the DOM hierarchy. The window object has the topmost hierarchy. The window object has many child objects and so on the Navigator and document objects.</p><p>Window</p><p>Navigator Location History Frame</p><p>Plugin Document Mime Type</p><p>Image [] Form [] Link []</p><p>Hidden Text Anchor []</p><p>FileUpload Textarea Layer []</p><p>Radio Reset Area []</p><p>Select Submit Applet []</p><p>Button Options [ ] Plugin []</p><p>Object-Oriented Programming 11 The document object contains its own set of child objects. The document object contains a form collection (a set). That is, there can be multiple form objects within one document object. The form collection contain other objects such as Text, Checkbox, and radio. Each form on a document is identified by its name. Each object on a form is first identified by the form name, and then by the object name within the form.</p><p>Each object and collection in the DOM contains its own set of properties, methods, and events.</p><p>Properties</p><p>Some properties can have values assigned to, and some are read-only properties. For example, the name property of an object can be assigned a value.</p><p>If the object is within the current window, you do not need to identify the name of the current window. For example, to retrieve a value of a text box named lastName, use the value property of the text box: document.form2.lastName.value = txtName or document.form2.lastName = txtName, /*value is default property where txtName is the value typed by the user on the text box.</p><p>Object-Oriented Programming 12 Methods</p><p>Objects within the DOM have built-in methods that can be called form scripts. For example, to close a window using the close method, you could use window.close().</p><p>Argument can be passed to the method. For example, as we have seen before</p><p>Document.write (“Welcome to UHCL”)</p><p>Events</p><p>Users interact with the Web page by performing actions called events, such as clicking, scrolling, and entering information. </p><p>The command statements that respond to an event are called the event handler.</p><p>For example, when a user clicks an object, an event called onClick is generated for that object. </p><p>Object-Oriented Programming 13 The following is a list of events and their event handlers:</p><p>Event Applies to Occurs when Event handler Change text fields, textareas, select User changes value of element onChange lists</p><p>Click buttons, radio buttons, User clicks form element or link onClick checkboxes, submit buttons, reset buttons, links</p><p>DragDrop windows User drops an object onto the browser onDragDrop window, such as dropping a file on the browser window</p><p>Error images, windows The loading of a document or image onError causes an error</p><p>KeyDown documents, images, links, text User depresses a key onKeyDown areas</p><p>KeyPress documents, images, links, text User presses or holds down a key onKeyPress areas</p><p>KeyUp documents, images, links, text User releases a key onKeyUp areas</p><p>Load document body User loads the page in the Navigator onLoad</p><p>MouseDown documents, buttons, links User depresses a mouse button onMouseDow n MouseMove nothing by default User moves the cursor onMouseMove</p><p>MouseOut areas, links User moves cursor out of a client-side onMouseOut image map or link</p><p>MouseOver links User moves cursor over a link onMouseOver</p><p>MouseUp documents, buttons, links User releases a mouse button onMouseUp</p><p>Move windows User or script moves a window onMove</p><p>Reset forms User resets a form (clicks a Reset onReset button)</p><p>Resize windows User or script resizes a window onResize</p><p>Select text fields, textareas User selects form element's input field onSelect</p><p>Submit forms User submits a form onSubmit</p><p>Unload document body User exits the page onUnload</p><p>Object-Oriented Programming 14 An Example of Event Handler The following code will catch the click event using three different ways. Note, the document uses three forms, a button object in each form that has properties name and value.</p><p>The first method uses the onClick event handler for the button object. The second method uses a function callUs. The third method uses onClick event of the button object (a subroutine in VB).</p><p><html><head> <title>Status Test</title> </head></p><p><body> <h1>Call Customer Support</h1></p><p><form name="form1"> <input type = "button" name = "btnCall1" value = "Click Here for Help" onClick = window.alert("1-800-555-5555");> </form></p><p><form name="form2"> <input type = "button" name = "btnCall2" value = "Click Here for Help" onClick = "callUs()";> </form></p><p><script language="javascript"> function callUs(){ window.alert("1-800-555-5555") } </script></p><p><form name="form3"> <input type = "button" name = "btnCall3" value = "Click Here for Help"> </form></p><p><script language="vbscript"> sub btnCall3_onClick() window.alert("1-800-555-5555") end sub </script></p><p></body></html></p><p>View Customer.htm</p><p>Object-Oriented Programming 15 The Window Object</p><p>The window object represents the browser window, the physical space that holds the HTML document. The properties and methods associated with it are handled through the window object. </p><p>Explanation Property Syntax self window.self Reference to the current window.</p><p> name window.rightwindow Reference to a specific window that can be called by name. default window.defaultstatus = Allows you to set a default message in the status “print this” status bar. status window.status = “print Allows you to change the message in the this” status bar.</p><p>Opening and Closing Windows</p><p>The open window method allows you to open a new browser window on the fly. For example:</p><p> window.open(“new.html”, “newWindow”, “height=200, width=200, status=no, toolbar=no, menusbar=no, location=no”)</p><p> window.open Opens a new window “new.html” The new URL that will be opened in the new window “newWindow” The name of the new window “height= 200, These are the Windows options starting with height and width width=200 Turning off the status bar, a value of 1 or yes would turn it status=no, back on toolbar=no, Turning off the toolbar, a value of 1 or yes would turn it back menusbar=no, on location=no” Turning off the menusbar, a value of 1 or yes would turn it back on Turning off the location bar, a value of 1 or yes would turn it back on</p><p>To close a window, pass the name of the window that is to be closed to the window method. To close the current window use:window.close();</p><p>View WindowOpen1.htm View WindowOpen2.htm</p><p>View WindowCreate.htm</p><p>Object-Oriented Programming 16 The Document Object</p><p>The document object is a child object of the window object. The document object allows direct access to the current Web page. </p><p>While the window object represents the actual browser window, the document object represents the actual Web page within the window. </p><p>Document Object Properties</p><p>Property Description alinkColor The color of the active hyperlinks on the Web page. Default is red. An active hyperlink is clicked but not yet visited background Identifies a background image to use bgColor The background color. If you have an image in the background, then this property will override the image. cookie The document’s cookie. defaultClientScript The default client scripting language - - usually JavaScript defaultServerScript The default server-side scripting language - - usually VBScript domain The domain name of the Web page that provided the Web page fgColor The foreground color, used for text and headings lastModified The date the Web page was last modified or changed linkColor The color of the hyperlinks on the Web page. Default is blue. referrer The URL of the referring page text The default text color title The text string that will be displayed in the caption bar url The URL of the current page vlinkColor The color of the visited hyperlinks on the Web page. Default is purple. </p><p>The cookie property allows one to store and read cookies that are associated with the document. A cookie consists of a cookie name and a value. The syntax to write a cookie:</p><p>Document.cookie = “cookie name = value”; Examples: Document.cookie = “userID = Rob123”;</p><p>Document.cookie = “userID = Rob123”; expires = Monday, 01- Jan-02 12:00:00 EST”;</p><p>To read a cookie into a variable named readCookie:</p><p>ReadCookie = document.cookie;</p><p>Object-Oriented Programming 17 Document Object Methods</p><p>The document object methods are used before, such as write and writeln. The syntax is:</p><p> document.write (“string”);</p><p>Example:</p><p> document.write (“Today is “ + Date());</p><p>Method Description captureEvent Only available in Netscape Navigator, is used to capture events that need to be handled. write Allows you to write text, HTML tags, expressions, and variables to your page. writeln Same as Write, but it adds a carriage return to the end of the line.</p><p>Document Object Event Handlers</p><p>Like window object, the document object responds with document handlers Thus when a user clicks on page, the onClick event is triggered.</p><p>Event Handler Description onClick Action performed when the user clicks a button onDblClick Action performed when the user clicks a button twice onKeyDown Action performed when the user presses a key onKeyPress Action performed while the user holds a key onKeyUp Action performed when the user releases a key onMouseDown Action performed when the user presses the mouse button onMouseUp Action performed when the user releases the mouse button </p><p>Object-Oriented Programming 18 The Form Object (Collection)</p><p>The form object is one of the most commonly used objects in the Web programming. The document object is the parent to the form object. </p><p>There can be multiple forms in a document. Each form can be assigned a unique name. </p><p>Each form typically contains multiple child objects or sometimes called elements. These are input, select, password, reset, checkbox, radio, and so on.</p><p>Form Properties</p><p>The forms collection has several properties. The syntax to retrieve a form property in a document:</p><p> document.[formName].property</p><p>The syntax to retrieve the property of an element within the form:</p><p> document.[formName].[elementName].property</p><p>Object-Oriented Programming 19 Form Methods There are two methods of form object: submit and reset.</p><p>Methods Description submit Submits the form without requiring the user to click the Submit button reset Submits the form without requiring the user to click the Reset button</p><p>The Form Child Objects</p><p>There are many child objects to a form such as the input, select, button, and image. These objects are used within a form, of a document, to collect information, display image, select values, and so on. </p><p>Object-Oriented Programming 20 The Input Object</p><p>The input object is used to create a text box and other form elements. When the type property of input is set to text, a text box is created, and can be used to retrieve data from the user, or display information. </p><p>A textbox must be declared in the HTML section before it can be manipulated by the script code. </p><p>The properties of the textbox:</p><p> value, defaultvalue, form, name, and type.</p><p>There are three methods to the input object. They are: </p><p> blur, focus, and select. </p><p>The focus method makes the text box active. </p><p>The select method makes the text box active and highlights the text in the box, which allows the user to change it.</p><p>Object-Oriented Programming 21 Example of text boxes:</p><p><html><head> <title>Form Properties</title> </head> <body> <form name = "login" id = "login" method = "post"> <h3>Login Form</h3> <font face = "Verdana">Username <input type = "text" name = "username" size = "20"><br> Password <input type = "text" name = "password" size = "20"><br> <input type = "submit" value = "Submit" name = "btnSubmit"> </form> </body></html></p><p>View formLogin</p><p>Object-Oriented Programming 22 The Select Object</p><p>The select object is used to create a list box or of drop down box in a form. A list box displays all items in the list. A drop-down box does the same thing but it hides the list.</p><p>Example of a drop-down list:</p><p><html><head> <title>Select List</title> </head> <body> </p><p><form name = "form1"> <select size = "1" name = "product"> <option value = "Pencils">Pencils</option> <option value = "Pens">Pens</option> <option value = "Paper">Paper</option> </select> </form> </body></html> </p><p>View selectList.htm</p><p>Object-Oriented Programming 23 DISCUSSION TOPICS</p><p> Discuss why most programming languages are going to object- oriented programming. Discuss the importance of encapsulation to object-oriented programming. Discuss the Document Object Model and select real life situations where programmers might use some of the objects in the model. Search the Web for instances of the DOM being used and discuss the techniques behind the uses.</p><p>KEY TERMS</p><p> Array – a collection of objects. Concatenation – a process of combining text, HTML tags, expressions, and variables within the same string. Constructor function – a special type of function that can create new objects. Document Object Model (DOM) – objects that are built-in browser software. Encapsulation – the inner workings of the object, such as its methods and properties, are maintained within the object. Event handler - the command statements that respond to an event. Function – a named grouping of one or more programming statements. Inheritance – new objects maintain the same characteristics as the original object. Instantiate – process of declaring a new instance of an object. Method – contains one or more programming statements, if defined within an object it can be reused in many Web pages. Object – a set of related methods and properties that are compartmentalized. Object definition – is the code that contains the methods and properties of the object. Object-oriented programming – allows you to use objects that can be accessed by other programs, including Web pages.</p><p>Object-Oriented Programming 24 Quiz:</p><p>1. What is the programming philosophy that allows you to access objects, properties, methods, and functions of an object without having to know about how the objects are created? 2. What is the keyword to declare a variable in JavaScript? 3. What is the keyword to create a new instance of an object? 4. What is the name of the characteristic that all new objects will maintain the same characteristics of the original object? 5. What is a collection of objects, such as forms[], known as? 6. What is the Hierarchical collection of objects that are built in the browser software called? 7. What is the highest level of the DOM called? 8. What are the user interactions with a Web page called? 9. What are the command statements that respond to user events called? 10.What is the highest level of the DOM? 11.How do you refer to the current browser window? 12.How do you print text to the status bar at the bottom of the window? 13.Can you open a browser window without all the graphical user interface components such as the toolbars? 14.What property of the navigator object identifies the name of the client’s browser application? 15.Which object provides information about the URL of the current document? 16.Can you send the user back or forward more than one page at a time? 17.Which object represents the actual Web page within the window? 18.What is the property called to change the color of the background of a Web page? 19.What is the difference between the methods document.write() and document.writeln()? 20.What is the code to reference the fifth form on a Web page? </p><p>Object-Oriented Programming 25</p>
Details
-
File Typepdf
-
Upload Time-
-
Content LanguagesEnglish
-
Upload UserAnonymous/Not logged-in
-
File Pages25 Page
-
File Size-