CNIT 133 Interactive Web Pags – JavaScript and AJAX

Slides:



Advertisements
Similar presentations
Tutorial 5 Windows and Frames Section A - Working with Windows.
Advertisements

WEB DESIGN TABLES, PAGE LAYOUT AND FORMS. Page Layout Page Layout is an important part of web design Why do you think your page layout is important?
1 CSC 551: Web Programming Spring 2004 client-side programming with JavaScript  scripts vs. programs  JavaScript vs. JScript vs. VBScript  common tasks.
The Web Warrior Guide to Web Design Technologies
XP 1 Designing a Web Site with Frames Using Frames to Display Multiple Web Pages Tutorial 5.
JavaScript Forms Form Validation Cookies CGI Programs.
Chapter 16 Dynamic HTML and Animation The Web Warrior Guide to Web Design Technologies.
Javascript Document Object Model. How to use JavaScript  JavaScript can be embedded into your html pages in a couple of ways  in elements in both and.
Tutorial 8 Designing a Web Site with Frames. XP Objectives Explore the uses of frames in a Web site Create a frameset consisting of rows and columns of.
JavaScript, Third Edition
Create a Web Site with Frames
XP Tutorial 5New Perspectives on HTML, XHTML, and DHTML, Comprehensive 1 Designing a Web Site with Frames Using Frames to Display Multiple Web Pages Tutorial.
Introduction to scripting
CST JavaScript Validating Form Data with JavaScript.
Javascript and the Web Whys and Hows of Javascript.
CNIT 133 Interactive Web Pags – JavaScript and AJAX Event and Event Handling.
JavaScript - Document Object Model. Bhawna Mallick 2 Unit Plan What is DOM and its use? Hierarchy of DOM objects. Reflection of these objects in an HTML.
Chapter 5 Java Script And Forms JavaScript, Third Edition.
Chapter 6: Forms JavaScript - Introductory. Previewing the Product Registration Form.
XHTML Introductory1 Forms Chapter 7. XHTML Introductory2 Objectives In this chapter, you will: Study elements Learn about input fields Use the element.
Unobtrusive JavaScript
Chapter 8 OBJECT-ORIENTED TECHNOLOGIES AND DSS DESIGN Decision Support Systems For Business Intelligence.
CNIT 133 Interactive Web Pags – JavaScript and AJAX JavaScript Environment.
UFCEWT-20-3 Advanced Topics in Web Development Lecture 4 : JavaScript, Browsers & the HTML DOM-API.
CSS Class 7 Add JavaScript to your page Add event handlers Validate a form Open a new window Hide and show elements Swap images Debug JavaScript.
Tutorial 8 Designing a Web Site with Frames. XP Objectives Explore the uses of frames in a Web site Create a frameset consisting of rows and columns of.
JavaScript, Fourth Edition
Introduction to JavaScript 41 Introduction to Programming the WWW I CMSC Winter 2004 Lecture 17.
JavaScript, Fourth Edition Chapter 5 Validating Form Data with JavaScript.
Week 11 Creating Framed Layouts Objectives Understand the benefits and drawbacks of frames Understand and use frame syntax Customize frame characteristics.
Tutorial 5 Windows and Frames Section B - Working with Frames and Other Objects Go to Other Objects.
Chapter 5: Windows and Frames
Navigator, Windows and Frames
XP Tutorial 6 New Perspectives on JavaScript, Comprehensive1 Working with Windows and Frames Enhancing a Web Site with Interactive Windows.
Tutorial 8 Designing a Web Site with Frames. 2New Perspectives on HTML, XHTML, and XML, Comprehensive, 3rd Edition Objectives Explore the uses of frames.
CNIT 133 Interactive Web Pags – JavaScript and AJAX Window Object.
JS Basics 1 Lecture JavaScript - Basics. JS Basics 2 What is JavaScript JavaScript is a “simple”, interpreted, programming language with elementary object-
Dr. Qusai Abuein1 Internet & WWW How to program Chap.(6) JavaScript:Introduction to Scripting.
JavaScript Scripting language What is Scripting ? A scripting language, script language, or extension language is a programming language.
Internet & World Wide Web How to Program, 5/e. © by Pearson Education, Inc. All Rights Reserved.
Chapter 2: Variables, Functions, Objects, and Events JavaScript - Introductory.
JavaScript, Fourth Edition Chapter 4 Manipulating the Browser Object Model.
1 CSC160 Chapter 7: Events and Event Handlers. 2 Outline Event and event handlers onClick event handler onMouseOver event handler onMouseOut event handler.
Project 5: Using Pop-Up Windows Essentials for Design JavaScript Level One Michael Brooks.
Working with the Window Object JavaScript considers the browser window an object, which it calls the window object.
JavaScript and Ajax (JavaScript window object) Week 6 Web site:
JavaScript and Ajax (JavaScript Environment) Week 6 Web site:
XP New Perspectives on Macromedia Dreamweaver MX 2004 Tutorial 5 1 Adding Shared Site Elements.
Web Programming Java Script-Introduction. What is Javascript? JavaScript is a scripting language using for the Web. JavaScript is a programming language.
Chapter 5 Validating Form Data with JavaScript
JavaScript and HTML Simple Event Handling 11-May-18.
In this session, you will learn to:
Applied Component I Unit II Introduction of java-script
Using DHTML to Enhance Web Pages
CIIT-Human Computer Interaction-CSC456-Fall-2015-Mr
Chapter 6 JavaScript: Introduction to Scripting
Project 9 Creating Pop-up Windows, Adding Scrolling Messages, and Validating Forms.
Web Development & Design Foundations with HTML5 7th Edition
JavaScript and HTML Simple Event Handling 19-Sep-18.
WEB PROGRAMMING JavaScript.
Integrating JavaScript and HTML
Events Comp 205 Fall 2017.
Tutorial 8 Designing a Web Site with Frames
Introduction to JavaScript
Introduction to Programming and JavaScript
JavaScript and Ajax (JavaScript Events)
CNIT 133 Interactive Web Pags – JavaScript and AJAX
JavaScript and HTML Simple Event Handling 26-Aug-19.
JavaScript: BOM and DOM CS Programming Languages for Web Applications
JavaScript and HTML Simple Event Handling 4-Oct-19.
Presentation transcript:

CNIT 133 Interactive Web Pags – JavaScript and AJAX Window Object

Agenda My Web Site: http://fog.ccsf.edu/~hyip (download syllabus, class notes). The window object. The document object. The location object. The history object. The navigator object. The onerror property/handler. Window Methods.

Window and Document Objects

The Window Object (Global Object) - Properties Window Properties document: document object Location: location object history: history object (array). history.back(), history.forward(), history.go() navigator: navigator object (Browser information) self: Refers to the current window. Equivalent to window opener: Refers to the window from which a particular window was opened close: Boolean value, window has been closed or not defaultStatus: set or return default text in status bar name: set or return name of window

The Window Object (Global Object) - Methods Window Methods alert() back() blur() clearInterval() clearTimeout() close() confirm() focus()

The Window Object (Global Object)- Methods forward() home() open() print() prompt() setInterval() setTimeout() stop()

The Window Object – Properties sample <html> <head><title>Window Object properties</title> </head> <body> <h1>Window Object properties</h1> <script language="JavaScript" type="text/javascript"> document.write("closed (boolean - window has been closed or not): ", closed, "<br>"); document.write("defaultStatus (set or return default text in statusbar): ", defaultStatus, "<br>"); document.write("name (set or return name of window): ", name, "<br>"); </script> </body> </html>

The Document Object - Properties Document object collection: images[] forms[] elements[] (button, checkbox, hidden, password, radio, reset, select, submit, text, textarea) links[] anchors[] Document object properties: lastModified title URL location (deprecated since Netscape 6, use URL instead)

The Document Object - Methods close() getElementById() getElementsByName() getElementsByTagname() open() write() writeln()

The Document Object - Properties sample <html> <head><title>document Object properties</title> </head> <body> <h1>document Object properties</h1> <script language="JavaScript" type="text/javascript"> document.write("domain (return domain name): ", document.domain, "<br>"); document.write("lastModified (return last modified date): ", document.lastModified, "<br>"); document.write("referrer (return the URL of the document that loaded the current document): ", document.referrer, "<br>"); document.write("title (set or return the title of the document): ", document.title, "<br>"); document.write("URL (return the full URL of the document): ", document.URL, "<br>"); document.write("location (deprecated, use document.URL): ", document.location, "<br>"); </script> </body> </html>

The Location Object The location property of a window (or frame) is a reference to a Location object; it represents the URL of the document currently being displayed in that window. The href property of the Location object is a string that contains the complete text of the URL. The toString() method of the Location object returns the value of the href property, so you can use location.toString() in place of location.href: location.href location.toString() /* this 2 statements are the same */

Loading New Documents Although the location property of a window refers to a Location object, you can assign a string value to the property. When you do this, the browser interprets the string as a URL and attempt to load and display the document at the URL: /* if the browser does not support the document.getElementById function, redirect to a static page. */ if (!document.getElementById) { location = "staticpage.html"; } Historically, assigning a URL to the location property of a window has been the supported technique for loading new pages.

The Location Object The Location object have two methods with related purposes: The reload() method reloads the currently displayed page from the web server; The replace() method loads and displays a URL that you specify. When you call this method, the specified URL replaces the current one in the browser’s history list rather than creating a new entry in that history list. Therefore, the Back button does not take the user back to the original document. Finally, the location property of the Window object refers to a Location object. The deprecated location property of the Document object is simply a read-only string (deprecated since Netscape 6, use document.URL instead). document.location is a synonym for document.URL In most cases, document.location/document.URL is the same as location.href. When there is a server redirect, however, document.location/document.URL contains the URL as loaded, and location.href contains the URL as originally requested.

The Location Object sample <html> <head><title>location Object properties</title> </head> <body> <h1>location Object properties</h1> <script language="JavaScript" type="text/javascript"> document.write("host (return hostname and port of a URL): ", location.host, "<br>"); document.write("hostname (return the hostname of a URL): ", location.hostname, "<br>"); document.write("href (return the entire URL): ", location.href, "<br>"); document.write("pathname (return path name of a URL): ", location.pathname, "<br>"); document.write("port (return the port number the server uses for a URL): ", location.port, "<br>"); document.write("protocol (return the protocol): ", location.protocol, "<br>"); document.write("search (return the query portion of a URL): ", location.search, "<br>") </script> </body> </html>

The History Object The history property of the Window object refers to the History object for the window. For security and privacy reasons, the array elements of the History object are never actually accessible to scripts. Although its array elements are inaccessible, the History object supports three methods: The back() and forward() methods move backward or forward in a window’s (or frame’s) browsing history, replacing the currently displayed document with a previously viewed one. The go() method, takes an integer argument and can skip any number of pages forward (for positive arguments) or backward (for negative arguments) in the history list. history.back() history.forward() history.go(+2) history.go(-3)

The History Object sample <html> <head><title>history Object properties</title> </head> <body> <h1>history Object properties</h1> <script language="JavaScript" type="text/javascript"> document.write("length (return the number of URLs in the history list): ", history.length, "<br>"); document.write("History has three methods - back(), forward(), and go()"); </script> </body> </html>

Obtaining Window, Screen, and Browser Information The navigator property of a Window object refers to a Navigator object that contains information about the web browser as a whole. In the past, the Navigator object was commonly used by scripts to determine if they were running in Internet Explorer or Netscape. This browser-sniffing approach is replaced by a capability-testing approach: if (window.addEventListener) { // addEventListener() method supports by Netscape/Mozilla/Firefox } else if (window.attachEvent) { // attachEvent() method supports by IE else { // old browsers

The Navigator Object Browser sniffing is sometimes still valuable, however, one such case is when you need to work around a specific bug that exists in a specific version of a specific browser. The Navigator object lets you do this. The Navigator object has five properties that provide version information about the browser that is running: appName; appVersion; userAgent; appCodeName; platform. The following lines of JavaScript code display each Navigator object property in a dialog box: var browser = "BROWSER INFORMATION: \n"; for (var propname in navigator) { browser += propname + ": " + navigator[propname] + "\n"; } alert(browser);

The Navigator Object Client sniffer (http://www.mozilla.org/docs/web-developer/sniffer/browser_type.html) /* this module defines an object named “browser” that is easier to use than the “navigator” object */ var browser = { version: parseInt(navigator.appVersion), isNetscape: navigator.appName.indexOf("Netscape") != -1, isMicrosoft: navigator.appName.indexOf("Microsoft") != -1 }; This is one of the reasons that browser sniffing has become less useful and is being superseded by capability testing.

The Navigator Object sample <html> <head><title>navigator Object properties</title> </head> <body> <h1>navigator Object properties</h1> <script language="JavaScript" type="text/javascript"> document.write("appCodeName (return the code name of browser): ", navigator.appCodeName, "<br>"); document.write("appName (return the name of the browser): ", navigator.appName, "<br>"); document.write("appVersion (return the version information of the browser): ", navigator.appVersion, "<br>"); document.write("cookieEnabled (determine whether cookies are enabled in the browser): ", navigator.cookieEnabled, "<br>"); document.write("platform (return which platform browser is compiled): ", navigator.platform, "<br>"); document.write("userAgent (return the user-agent header sent by the browser to the server): ", navigator.userAgent, "<br>"); document.write("<br><br>"); document.write("javaEnabled() (method-Specifies whether or not the browser has java enabled): ", navigator.javaEnabled(), "<br>"); </script> </body> </html>

Window Methods (Opening and Manipulating Windows) The Window object defines several methods allow you to open and close windows, control window position and size, request and relinquish keyboard focus, and scroll the contents of a window.

Opening Windows – Window Method open() You can open a new web browser window with the open() method of the Window object. window.open() takes four optional arguments and returns a Window object that represents the newly opened window: window.oprn("URL", "winname", "featureslist", booleanvalue); URL: URL of the document to display in the new window. If omitted or null or empty string, the window will be empty Winname: the name of the window Featureslist: list of features that specify the window size and GUI decorations. Booleanvalue: specifies whether the URL specified as the first argument should replace the current entry in the window’s browsing history (true) or create a new entry in the window’s browsing history (false), which is the default behavior var w = window.open("smallwin.html", "smallwin", "width=400,height=350,status=yes,resizable=yes"); The return value of the open() method is the Window object that represents the newly created window. The opener property of a window refers to the window from which it was opened. If the window was created by the user, the opener property is null.

Closing Windows – Window Method close() The close() method closes the current window. If you create a Window object w, you can close it with: w.close(); JavaScript code running within that window itself can close it with: window.close(); Note: the explicit use of the window identifier to distinguish the close() method of the Window object from the close() method of the Document object (document.close( )).

Keyboard Focus and Visibility – Window Method focus() and blur() Calling focus( ) requests that the system give keyboard focus to the window Calling blur( ) relinquishes keyboard focus Note: the focus( ) method ensures that the window is visible by moving it to the top of the stacking order.

Simple Dialog Boxes – Window Methods alert() confirm() prompt() The Window object provides three methods for displaying simple dialog boxes to the user. alert( ) displays a message to the user and waits for the user to dismiss the dialog (use for debugging) confirm( ) asks the user to click an OK or Cancel button to confirm or cancel an operation prompt( ) asks the user to enter a string

Error Handling – onerror property/handler The onerror property of a Window object is special. If you assign a function to this property, the function is invoked whenever a JavaScript error occurs in that window: the function you assign becomes an error handler for the window. Three arguments are passed to an error handler when a JavaScript error occurs: The first argument is a message describing the error The second argument is a string that contains the URL of the document containing the JavaScript code that caused the error The third argument is the line number within the document where the error occurred If the onerror handler returns true, it tells the browser that the handler has handled the error and that no further action is necessary.

Error Handling – onerror property/handler Define an error handler that handles all errors silently: // don’t bother the user with error messages window.onerror = function() { return true; } Display error message: <html> <head><title>window onerror property</title> <script language="JavaScript" type="text/javascript"> /* comment out the following code to see the original error message. */ window.onerror = function (message, url, linenum) { alert("There is an error!!"); alert("Error Message: " + message + "\n URL: " + url + "\n Line Number: " + linenum); return true; } </script> </head> <body> <h1>Window onerror property/onerror event handler</h1> document.write("No error"); document.write("With error here“ </body> </html>

Window Synonyms Property/synonym Description self Refers to the current window. Equivalent to window window The window object has a window property, which identifies the current window being referenced Opener Refers to the window from which a particular window was opened

Targeting Windows sample <html> <head><title>Window target</title> </head> <body> <a href="somepage.html" target="???">Some page</a> </body> </html>

Targeting Windows Target Name Description _self default. If no target is specified. The file listed in the href attribute loads into the window it was requested from. _blank Loads the file listed in the href attribute into a new, unnamed broswer window. _parent Loads the file designated in the href attribute file into the parent frame or window. _top Loads the file specified in the href attribute into the entire current window, above all framesets. WindowName/FrameName Loads the file into the window or frame with the specified target name. if no window/frame exists with that name, it opens a new window and assigns it that name. you cannot see the window name. the window is simply known by that name in memory

Window Methods Method Description alert(text) Displays an alert dialog box containing the text specified and an OK button. back() Equivalent to the visitor pressing the Back button. blur() Removes focus from the window. clearInterval(intervalID) Clears an interval. clearTimeout(timeoutID) Clears a timeout.

Window Methods Method Description close() Closes the window. If you call close alone, JS assumes that you mean the current window and closes it. The close method only closes windows you’ve opened using the open method. In an event handler, you must specify windowObjectName.close() instead of simply using close(). In an event handler, without specifying a window object name is equivalent to document.close(). confirm(text) Displays a confirm dialog box containing the text specified and options for the user to choose OK or CANCEL.

Window Methods Method Description focus() Gives focus to a window. forward() Equivalent to the visitor pressing the Forward button. home() Equivalent to the visitor pressing the Home button. open(url, name [, windowFeatures]) Opens a window, loads the document at the specified URL, and gives the window the provided target name and listed features. print() Print the contents of a window or frame. prompt(request, defaultInput) Displays a prompt dialog box with the specified request for input from the user. If defaultInput is not supplied, undefined appears in the dialog box (not very pretty).

Window Methods Method Description setInterval(‘expression”, msec) setInterval(function, msec) Evaluates an expression or calls a function repeatedly, every so many milliseconds (msec). The calls continue to fire until the interval is canceled using the clearInterval method, or closing the browser. setTimeout(“expression”, msec) setTimeout(function, msec) Evaluates an expression or calls a function after a specified amount of time. It does not act repeatedly. setTimeout does not stall the script, the script continues execution immediately after the call, which simply schedules some future event. stop() Stops the current document download. Equivalent to the visitor pressing the STOP button.

Opening a pop-up Window – Window Method open() [windowObjectName=] [window.] open("URL", "targetName" [, "features"]) windowObjectName: specifies the name of the window object variable. It is used to call methods on the window and access the window properties. URL: specifies the URL of the file to open in the new window. If you want to write to the new window dynamically, do not specify a URL, just provide empty quotes (""). targetName: name to be used in the target attribute of an <a> tag. It can only be alphanumeric or underscore. features: comma-separated list (without spaces) of any of the following options and values.

Opening a pop-up Window Option/Values Description toolbar[=yes|no] | [=1|0] Toolbar with buttons such as Back and Forward. locationbar[=yes|no] | [=1|0] Location bar where a URL can be entered. directories[=yes|no] | [=1|0] Standard browser directory buttons. The browser determines which directory buttons appear. statusbar[=yes|no] | [=1|0] Status bar at the bottom of the window where messages, download status, and link URLs typically display. menubar[=yes|no] | [=1|0] Browser menu bar with items such as File, Edit, View and Help scrollbars[=yes|no] | [=1|0] When set to yes, provides scrollbars if the content is too large for the window.

Opening a pop-up Window Option/Values Description resizable[=yes|no] | [=1|0] Determines whether the user is allowed to resize the window or not. innerWidth=pixels the width of the window’s content area in pixels. innerHeight=pixels The height of the window’s content area in pixels. outerWidth=pixels The horizontal dimension of the window’s outside boundary, in pixels. outerHeight=pixels The vertical dimension of the window’s outside boundary, in pixels. left=pixels The position of the top left corner of the window measured in pixels from the left side of the screen.

Opening a pop-up Window Option/Values Description top=pixels The position of the top left corner of the window measured in pixels from the top of the screen. titlebar[=yes|no] | [1|0] The title bar across the top of the browser window, which displays a document’s title. myWin = window.open(“test.html”,“TestWin”,“height=100,width=100,status”); myWin = window.open(“test.html”,“TestWin”,“height=100,width=100,status=yes”); myMap = window.open(“map.html”, “MapWin”, “width=150,height=150, toolbar,status”);

Closing a pop-up Window – Window Method close() Call the close method with the window’s name To close myMap: myMap.close();

Opening and Closing a Pop-up Window sample <html> <head><title>Open and close pop-up window</title> <script language="JavaScript"> var map = null; function showMap() { var features = "width=620, height=650"; features += ", left=50, top=50,status"; map = window.open("map.html", "MapWin", features); map.focus(); } function closeMap() { if (map != null) { map.close(); map = null; </script> </head> <body> <h1>Contact us (CCSF)</h1> <p>50 Phelan Avenue<br/> San Francisco, CA 94112<br/> (415) 239-3000</p> <p><a href="javascript: void(0)" onclick="showMap()">View Map</a> | <a href="http://www.ccsf.edu/Offices/Office_of_Instruction/Access_Guide/" target="MapWin">View Driving Directions</a> | <a href="javascript: void(0)" onclick = "closeMap()">Close Map</a></p> </body> </html>

map.html <html> <head><title>Map file</title> <body> <div align="center"> <h2>Map to CCSF</h2> <img src="ccsf_map.bmp" border="0" alt="CCSF_MAP" width="400" height="400"> <form> <input type="button" value="Print" onclick="window.print()"> <input type="button" value="Return" onclick="opener.focus()"> <input type="button" value="Close" onclick="self.close()"> </form> </div> </body> </html>

Pop-up News <html> <head><title>Popup News</title> <script language="JavaScript"> function showNews() { news = window.open("http://www.cnn.com", "NewsWin", "width=200, height=220"); var newsTimer = setTimeout("news.close()", "20000"); } </script> </head> <body onload="showNews()"> <h2>Popup News</h2> </body> </html>

Window Methods (Timers) The core JavaScript language does not provide ability to schedule code to be executed at some point in the future, but client-side JavaScript does provide it in the form of the global functions setTimeout(), clearTimeout(), setInterval(), and clearInterval(). The setTimeout() method of the Window object schedules a function to run after a specified number of miliseconds elapses. It returns an opaque value that can be passed to clearTimeout() to cancel the execution of the scheduled function. The setInterval() invokes the specified function repeatedly at intervals of the specified number of miliseconds. It returns an opaque value that can be passed to clearInterval() to cancel any future invocations of the scheduled function.

Writing to Window dynamically sample <html> <head><title>dynamic window text</title> <script language="JavaScript" type="text/javascript"> function dynWrite() { var topDoc = "<html><head><title>Dynamic text</title></head>"; topDoc += "<body bgcolor='yellow' text='black'>"; var endDoc = "</body></html>"; var features = "width='200',height='200'"; var newWin = window.open("", "DynWin", features); newWin.document.write(topDoc, "<h2>Dynamically write text</h2>"); newWin.document.write("Quote of the day: Please turn in your homework. Thanks."); newWin.document.write("<div align='center'>", "<input type='button' value='close' onClick='self.close()'></div>"); newWin.document.write(endDoc); } </script> </head> <body onLoad="dynWrite()"> <h1>Home page of some web site</h1> </body> </html>