Build your Web Development career with Wrox Programmer’s Reference PROGRAMMER TO PROGRAMMER TM JavaScriptJavaScript Cliff Wootton e-book includes this complete reference and 2000+ extra entries JavaScript Programmer's Reference Cliff Wootton Wrox Press Ltd. JavaScript Programmer's Reference © 2001 Wrox Press All rights reserved. No part of this book may be reproduced, stored in a retrieval system or transmitted in any form or by any means, without the prior written permission of the publisher, except in the case of brief quotations embodied in critical articles or reviews. The author and publisher have made every effort in the preparation of this book to ensure the accuracy of the information. However, the information contained in this book is sold without warranty, either express or implied. Neither the authors, Wrox Press nor its dealers or distributors will be held liable for any damages caused or alleged to be caused either directly or indirectly by this book. Published by Wrox Press Ltd, Arden House, 1102 Warwick Road, Acocks Green, Birmingham, B27 6BH, UK Printed in the United States ISBN 1-861004-59-1 Trademark Acknowledgements Wrox has endeavored to provide trademark information about all the companies and products mentioned in this book by the appropriate use of capitals. However, Wrox cannot guarantee the accuracy of this information. Credits Author Technical Reviewers Cliff Wootton Alex Abacus Jonny Axelsson Category Manager Chong Chang Dave Galloway Andrew Van Heusen Martin Honnen Technical Editors Ron Hornbaker Timothy Briggs Kenneth Lo Howard Davies Jim Macintosh Phillip Jackson Jon Stephens Amanda Kay Peter Torr Simon Mackie Chris Ullman Chris Mills Paul Vudmaska Peter Morgan Paul Wilton Project Manager Figures Chandima Nethisinghe Shabnam Hussain Production Coordinator Cover Tom Bartlett Shelley Frazier Additional Layout Proofreaders Simon Hardware Ian Allen Pippa Wonson Christopher Smith Agnes Wiggers e-Book Production Tom Bartlett Index Andrew Criddle Production Manager Simon Hardware About the Author Cliff Wootton lives in the south of England and works on multimedia systems and content management software for large data driven web sites. Currently he is developing interactive TV systems for BBC News Online in London (http://www.bbc.co.uk/news) and previously worked for other commercial broadcasters on their web sites. Before that he spent several years developing geophysical software and drawing maps with computers for oil companies. Cliff is married with three daughters and a growing collection of bass guitars. Acknowledgements It's hard to believe I've actually reached the stage of writing the introductory pages to this book. It's been a long process and I don't think I would have reached this point without the help of Tim Briggs at Wrox, who very gently urged me onwards and gave me encouragement when I needed it. Tim's contribution to this project was vital to its success because he developed the process which converted my DOCBOOK output into something the Wrox editors could turn into a book. Tim also prepared the CD-ROM content from the same XML files; truly amazing! Thanks also to all the other folks at Wrox who have helped, organised, checked and collated my material to present it in the form you now see it. Grateful thanks to my reviewers, who in a very short time provided me with some useful guidance and support; in particular Jon Stephens and Martin Honnen, who also provided some amazingly clever example code fragments for use as examples. There are many other people who contributed without realising it. In particular Nick Cohen (formerly of the BBC and now at Turner Broadcasting) who provided some helpful insights into TV set-top-box workings. Also Matt Karas and Emyr Tomos (both ex-BBC, now at Talkcast) who threw down the gauntlet of several interesting challenges for me to implement on the BBC News Online web site. I also wouldn't be sitting here if it weren't for Bruce Morris at Carlton Online. It was through the happy chance of an article I wrote for Bruce's Web Developer's Journal (WDJ) web site that led to Wrox contacting me and the BBC inviting me to do some JavaScript work. What an amazing thing the web is. Most importantly I dedicate this book to my family. To my wife, Julie and my daughters Hannah, Lydia and Ruth who kept me going with cups of coffee, hugs and the occasional giggle when they saw the photograph of me for the front cover. Introduction The JavaScript language is constantly developing, and continues to increase in popularity. Its evolution into a general purpose scripting language from what started life purely for scripting web browsers, is a great success story. You can now find JavaScript interpreters in many different environments and there are sure to be other new and interesting uses for the language in the future, especially now that embeddable interpreters are available. In this book, we have attempted to snapshot the browsers that exist currently, which need to be supported by web sites, and collate that information together in a form that has broad scope and is deep enough to be useful on a day-to-day basis. As the language is growing all the time, this is likely to be an ongoing task. Who is This Book For? The book is aimed at people who already have some knowledge of JavaScript and need a companion volume to their daily work. It is primarily aimed at the experienced practitioner, and so does not attempt to be a tutorial for the beginner. For a tutorial book, we suggest Paul Wilton's Beginning JavaScript (Wrox Press, ISBN 1-861004-06-0). Typical uses of the book include times when you: ❑ Need to check out the specific details of a particular language construct or object property ❑ Know what you want to do, but want to know how JavaScript helps you achieve that ❑ Want information on cross-browser compatibility issues for your script ❑ Have encountered a problem in your script and need help to debug it One important motivation I had for writing this book was to reduce the amount of material I have to carry around when I'm working on projects in my clients' offices. My library now contains several shelves devoted purely to JavaScript, and in researching this book, I ended up with many megabytes of material. There have been many fine books written about JavaScript but I simply cannot carry them around on the train, even with a large rucksack! So, I set out to try and distil enough useful information into one book and organize it so that the information is easy to find. I've also put in material on issues that I've encountered in discussions with other programmers. JavaScript Programmer's Reference 2 The Structure of the Book To make it easy to navigate through the topics, titles describe the topic content and the topic type and are organized alphabetically. Where a topic might be referred to using several headings, a brief entry in the cross-reference at the end of the book shows the main topic for that subject. I used a great deal of software automation to manage the book content and the whole thing was built in a database and exported as an XML file set using the DocBook DTD. There are now in excess of 3500 individual topics in this work. That is more than twice as many as we have room for in the printed book, so we’ve had to put a useful subset of the reference into the printed book, and the complete set of material onto the CD-ROM, which is available both in PDF and HTML formats. Some additional reference information that is not strictly part of the JavaScript language, but that you may find useful, is also included, such as country codes and MIME types. Where we discuss an object all the important properties, methods, events, and any supporting material are broken out into their own topics, and these detailed entries are included on the CD. Where objects inherit properties and methods, they are listed in the object coverage, but to avoid duplication the information about the inherited properties is described as a member of the super-class. This slightly detracts from the lexical referencing but it saves space. In some cases these inherited properties/methods are deemed important enough to merit a cross-referencing entry of their own. This allows us to indicate availability of features at a very fine level of detail. Within each topic we can also discuss bugs, gotchas, and areas of difficulty in a focused way. Language syntax is illustrated by way of example code fragments that show how to access an object, method, or property. More extensive examples are given where necessary. Because of the scoping rules, properties are available without the need for the window object to be specified as a prefix. Thus navigator as a topic is available under the window.navigator topic as well. Once you have found an entry topic, you can then use the cross-referencing listings to locate other related material. The book content was developed inside a database system, which provided tools to relate topics. The benefit is a rich source of cross-referencing links between topics. The cross-reference in the printed book is complete; that is, it also includes entries found only on the CD. The italicized cross- references in the printed book can also be found in the printed book. We will now look at some of the 'features' of JavaScript programming, as an introduction to what topics in the book will address. Differences between Browsers For some time, the most popular browsers have been Netscape Navigator 4.7 and Microsoft Internet Explorer 5.0 (MSIE). Other, newer browsers make a point of being standards compliant and so if your script conforms to the standards for core JavaScript as laid down by ECMA and the W3C DOM specifications, it should function correctly. However, the dominant browsers have for a long time been competing with one another to add new features. Architecturally, this means their browsers have each gone in a completely different direction. The penalty has been that support for various language features has been implemented in each browser in ways that makes it difficult to use in a portable way. Indeed, to make use of some features requires twice the work, since the same code has to be written in two different ways and called after detecting which browser is being used. Introduction 3 Because of the proliferation of browser versions and platforms, features are generally referred to as being available in the revision in which they were first introduced. As the Netscape browser is available on so many different platforms, to test for compliance across all platforms would require a test suite of a dozen machines and 30 or more different installations of browser applications. Indeed, when building such a test suite just prior to starting on this book, I found more than a dozen distinctly different browser versions just for the Macintosh platform and many more than that for Windows. Similarly, MSIE comes in a bewildering variety of versions and platform variants. In addition, the JScript interpreter is a replaceable component that can be upgraded without changing the containing browser. Browsers and Standards There is still much that is ambiguous or not yet defined in the standards and the browser manufacturers continue to add new features in competition with one another. Even though they are standards compliant at a functional level, there are still significant differences if you 'look under the hood'. We have included coverage of the following standards: ❑ ECMAScript core language up to edition 3 of the standard ❑ DOM coverage to level 1 ❑ Some DOM coverage of level 2 where implemented in Netscape 6 ❑ Discussion of the features being added at DOM level 3 JavaScript implementations we cover include: ❑ Netscape 3.0, 4.0, 4.05, 6.0 (the final release came out as we went to press) ❑ MSIE version 3.0, 4.0, 5.0, 5.5 ❑ Opera 3, 4, 5 ❑ Netscape Enterprise Server By implication that means we cover JavaScript versions up to 1.5 and JScript up to 5.5. The coverage of Netscape 6.0 is based on it supporting the W3C DOM standards and several bugs in the currently released version prevented the verification of some functionality although that may be platform dependent. There are also some new and unexpected features. We concentrate our discussions on the peculiarities of Netscape and MSIE because the other browsers that support JavaScript attempt to provide a fault-free standards-based implementation. Since this is a sub-set of the functionality of Netscape and MSIE, other platforms should be adequately covered. Features and Versions There are now a wide variety of sources of information about JavaScript and they don't all agree. In particular there is some uncertainty over which release of JavaScript introduces certain features. The source material was assimilated by examining the standards documents and by inspecting objects with fragments of JavaScript. Then, the availability of features was checked against several alternative reference works. Occasionally, when a consistency error showed up, it was necessary to go back to the browser and test for the availability of a property or method. JavaScript Programmer's Reference 4 Where there is some room for doubt, we have documented the release at which the feature became useful. This is because in earlier releases it may have had a serious flaw or been significantly revised later to make it work properly. Any implementation prior to that may be unreliable. So where we may appear to disagree with other commentators our coverage is based on whether it is practical to use a particular feature at a certain release. Some browser features are available at an earlier release on some platforms than others are. We take the Windows 32-bit release as our baseline although significant testing was also done on the Macintosh versions, which disappointingly lagged somewhat in performance and feature availability. Both platforms exhibited instabilities and crash-prone behavior but in quite different areas of the language. As there are so many variants of the browsers, the availability matrix for objects and their member properties/methods is huge and requires a large amount of work to test on all the available combinations. So far, no single reference source has proven to be error free and whilst the information here has been examined and cross-checked it is still likely that there are errors. If, in your work, you disagree with the information provided here, please send feedback (see the end of the Introduction for how to do this). Core JavaScript At first glance, the JavaScript environment appears to be built around a small core of objects and it is easy to fall into the trap of assuming the language is small and compact. That is certainly true if you are only considering core JavaScript functionality. The core language is defined by ECMA and both Netscape and MSIE both claim to be ECMA compliant. They may well be, but you cannot write much useful JavaScript for deployment in a web page by confining yourself only to the functionality of the ECMA standard. It is at that point that the two browsers begin to diverge. DOM Support Likewise, both browsers (MSIE 5 upwards and Netscape 6) claim to be DOM compliant. Browser support for the DOM is slowly converging but if you need to do any esoteric code development that involves DOM traversal and class names, they are still somewhat different. MSIE implements a DOM model that is structurally right, but the class names of the objects that comprise that model are certainly not correct and do not conform to the DOM standard. Netscape 6 implements a DOM compliant model that does use the correct class names. Another slight difference is that MSIE implements distinctly different classes for some objects whereas Netscape Navigator instantiates the same class for several purposes. These differences don't cause much grief to you when you are constructing simple scripts and web page enhancements but can be quite a problem if you need to manipulate the DOM structure and operate on objects by means of their class names. This difference did not become apparent until I used inspection scripts to examine internal document structures. There are also areas where DOM specifies objects in a way that the browsers can implement ambiguously. For example, DOM describes documents as being a generic document class with an HTML document as a sub-class. Browsers simply provide a single document class with no access to the two separate class types. Introduction 5 Object Classes You might also assume that there is a small and finite set of different object types. However if you inspect the constructor properties and examine the function names, you will find the opposite, there are a large number of object types. For example, the applets property that returns a list of applets in a document will give you an AppletArray object and not a Collection object in Netscape. Trying to work out class names on MSIE is a bit more problematic and it tends to provide generic Collection objects instead. By building fragments of JavaScript to inspect objects, you can determine these class names and learn a lot about how the browser maintains the internal model of the page. The topics are constructed around a browser-centric model. The objects are defined based on their instantiation by an HTML tag in a web browser window. MSIE creates a distinct object class for each tag. Netscape does a similar trick, but not so convincingly in earlier versions. At version 6, the objects are DOM compliant and named differently to those in MSIE and earlier Netscape browsers. Netcsape 6 is so different as to be a new browser with little similarity to the earlier versions of Netscape. There is an emerging standards-based model that frames the object hierarchy much more logically and, while it is still evolving, it may become a more robust way of describing the catalog of available classes. For now, though, the web and browser dominate use of JavaScript, so this seems like the more appropriate model. Document Objects Another area of debate is the document object. Typically, the previous documentation describes access to it as if there is only one document object. This is true within the context of a single script within a page. However, it is not necessarily true of a window in a web browser. A window may contain many frames or layers. Each one will have its own private document object. If you are writing scripts that operate across multiple frames or windows, you may refer to several document objects, so the syntax examples are designed to accommodate the different ways in which objects can be accessed. The Future JavaScript is becoming available in an ever-wider variety of applications. It is used in: ❑ PDF forms for validation ❑ For modifying the behavior of the GUI in developer tools ❑ Embedded interpreters in cell phones and television set-top boxes There was not space enough or time to cover these extensively. They are also changing continually and will not be stable enough to document for a while yet. What Do I Need to Use This Book? All that is needed to use this book is a text editor and a JavaScript-enabled browser, such as Microsoft Internet Explorer or Netscape Navigator. To use the CD you will need a browser to read the HTML files and a copy of Adobe Acrobat Reader/Adobe Acrobat eBook Reader to read the PDF files, which are freely available from www.adobe.com. To make navigation easier, the PDF files contain interactive bookmarks, thumbnails, and hyperlinks in the entries. All of the code examples given in the book are available on the CD, and are also available to download from our web site, www.wrox.com. [...]... object, Anchor object A – A object (Object/HTML) Property JavaScript JScript N IE Opera DOM HTML Notes accessKey dataFld dataSrc hash host hostname href Methods mimeType nameProp pathname port protocol protocolLong rel search tabIndex target 1. 5 + - 3.0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 1. 0 + 3.0 + 1. 0 + 6.0 + - 4.0 + 3.02 + 3.02 + 3.02 + 3.02 + 3.02 +... Cross-references: ECMA 262 edition 2 – section – 11 .6 .1 ECMA 262 edition 2 – section – 11 .13 ECMA 262 edition 3 – section – 11 .6 .1 Wrox Instant JavaScript, ISBN 1- 8 610 01- 27-4 – page – 37 19 JavaScript Programmer's Reference Add then assign (+=) (Operator/assignment) Add two numeric operands and assign the result to the first See concatenation for Strings Availability: ECMAScript edition – 2 JavaScript. .. - - - ReadOnly rel 1. 5 + 3.0 + 6.0 + 4.0 + - 1+ - - rev 1. 5 + 3.0 + 6.0 + 4.0 + - 1+ - - Table continued on following page 28 A – Anchor() (Constructor) Property JavaScript JScript N IE Opera DOM HTML Notes search 1. 2 + 3.0 + 4.0 + 4.0 + shape 1. 5 + 5.0 + 6.0 + 5.0 + - - - Warning - 1+ - - tabIndex 1. 5 + 3.0 + 6.0 + target 1. 2 + 3.0 + 4.0 + 4.0 + - 1+ - - 4.0 + - 1+ - Warning text 1. 2 + - 4.0 + - -... type 1. 5 + 3.0 + 6.0 + 4.0 + - 1+ - - urn - x 1. 2 + 3.0 + - 4.0 + - - - - - 4.0 + - - - - Warning, ReadOnly y 1. 2 + - 4.0 + - - - - Warning, ReadOnly Method JavaScript JScript N IE Opera DOM HTML Notes blur() 1. 5 + 3.0 + 6.0 + 4.0 + - 1+ - - focus() 1. 5 + 3.0 + 6.0 + 4.0 + - 1+ - - Event name JavaScript JScript N IE Opera DOM HTML Notes onClick 1. 2+ 3.0 + 4.0 + 4.0 + 3.0 + - 4.0 + Warning onMouseDown 1. 2... onMouseUp, onSelectStart See also: style.speak, Element object Event name JavaScript JScript N IE Opera DOM HTML Notes onClick onDblClick onDragStart onFilterChange onHelp onKeyDown onKeyPress onKeyUp onMouseDown onMouseMove onMouseOut onMouseOver onMouseUp onSelectStart 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + - 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0... Window.scrollTo() Property JavaScript JScript N IE Opera DOM HTML Notes accessKey 1. 5 + 3.0 + 6.0 + 4.0 + - 1+ - Warning charset 1. 5 + 5.0 + 6.0 + 5.0 + - 1+ - - coords 1. 5 + 5.0 + 6.0 + 5.0 + - 1+ - - dataFld - 3.0 + - 4.0 + - - - - dataSrc - 3.0 + - 4.0 + - - - - hash 1. 2 + 3.0 + 4.0 + 4.0 + - - - Warning host 1. 2 + 3.0 + 4.0 + 4.0 + - - - Warning hostname 1. 2 + 3.0 + 4.0 + 4.0 + - - - Warning href 1. 2 + 3.0 +... onMouseOver onMouseUp 10 The ID value of an Element object onClick, onDblClick, onHelp, onKeyDown, onKeyPress, onKeyUp, onMouseDown, onMouseMove, onMouseOut, onMouseOver, onMouseUp 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + 1. 5 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 3.0 + 6.0 + 6.0 + 6.0 + 6.0 + 6.0 + 6.0 + 6.0 + 6.0 + 6.0 + 6.0 + 4.0 + 4.0 + 4.0 + 4.0 + 4.0 + 4.0 + 4.0 +... function(…) Cross-references: ECMA 262 edition 2 – section – 10 .1. 6 ECMA 262 edition 3 – section – 10 .1. 6 Active Server Pages (Product) A Microsoft web server product This is a server-side programming framework that supports JavaScript More accurately, it supports JScript, which is Microsoft's flavor of JavaScript For more information, see ASP 3.0 Programmer's Reference, ISBN 1- 8 610 03-23-4 from Wrox... Precedence, Subtract then assign (-=) A – Adding JavaScript to HTML (Advice) Cross-references: ECMA 262 edition 2 – section – 11 .13 ECMA 262 edition 3 – section – 11 .13 Adding JavaScript to HTML (Advice) The most popular use of JavaScript is in web pages Adding it is quite simple To add JavaScript to a web page, you can use the following techniques: ❑ The HTML tag containing the script source text... numeric valuesmyVar1 = 10 0;myVar2 = 10 00; // After this myVar1 contains 11 00, myVar2 is unchanged myVar1 += myVar2; See also: 20 Add (+), Additive operator, Assign value (=), Assignment expression, Assignment operator, Associativity, Concatenate then assign (+=), Increment value (++), LValue, Operator Precedence, Subtract then assign (-=) A – Adding JavaScript to HTML (Advice) Cross-references: ECMA . - hostname - 1. 0 + - 3.02 + - - - - href - 1. 0 + - 3.02 + - 1 + - - Methods - 1. 0 + - 3.02 + - - - - mimeType - 1. 0 + - 3.02 + - - - - nameProp - 1. 0 + - 3.02 + - - - - pathname - 1. 0 + - 3.02. (Object/HTML) 9 Property JavaScript JScript N IE Opera DOM HTML Notes accessKey - 3.0 + - 4.0 + - 1 + - - dataFld - 1. 0 + - 3.02 + - - - - dataSrc - 1. 0 + - 3.02 + - - - - hash - 1. 0 + - 3.02 + - - - - host - 1. 0. Wrox Programmer’s Reference PROGRAMMER TO PROGRAMMER TM JavaScriptJavaScript Cliff Wootton e-book includes this complete reference and 2000+ extra entries JavaScript Programmer's Reference Cliff