Client-Side JavaScript
by K. Yue, revised October 1, 2000
copyright 2000

Introduction

Example:

<body bgcolor="&{favorite_color();}">
...
<input type="text" name="lname"
       value="&{defaults.lname);}">

Example:

<form name="MyForm" ...>
<input type="TEXT" name="MyText">
...
</form>

We can refer to the text object as document.MyForm.MyText.

Examples:

document.bgColor           //   the background color of the document.
document.cookie            //   allows for reading, creating, modifying
                           //   and deleting cookie of the current
                           //   document.
document.myform.action     //   the read/write string that specify the
                           //   action of the form myform.
document.myform.submit()   //   submit the form myform.
navigator.appName          //   the name of the browser.
navigator.appVersion       //   the version of the browser.
document.f1.t1.value       //   the read/write string of text element
                           //   t1 of form f1.
setTimeout(s, 1000)        //   a method of Window to execute the
                           //   JavaScript string s after 1000 ms.
location.replace(url)      //   a method of location to load and displace
                           //   a new document at url, without generating
                           //   a session history.
history.back()             //   go backward to a previously visited URL.
document.write(s)          //   write (append) the string s to the
                           //   current document; mainly used while the
                           //   document is still parsed or for the
                           //   generation of contents of other window.
open(url, winName)         //   open a window using the URL url with the
                           //   name winName.

Cookies

Example: Cookie handling: (from Flanagan) cookies.html

<SCRIPT LANGUAGE="JavaScript1.1">

// The constructor function. Creates a cookie object for the specified
// document, with a specified name.
// attributes.
// Arguments:
// document: the Document object that the cookie is stored for. Required.
// name: a string that specifies a name for the cookie. Required.
// hours: an optional number that specifies the number of hours from now
// that the cookie should expire.
// path: an optional string that specifies the cookie path attribute.
// domain: an optional string that specifies the cookie domain attribute.
// secure: an optional boolean value. If true, requests a secure cookie.
//
function Cookie(document, name, hours, path, domain, secure)
{
// All the predefined properties of this object begin with '$'
// to distinguish them from other properties which are the values to
// be stored in the cookie.
this.$document = document;
this.$name = name;
if (hours)
this.$expiration = new Date((new Date()).getTime() + hours*3600000);
else this.$expiration = null;
if (path) this.$path = path; else this.$path = null;
if (domain) this.$domain = domain; else this.$domain = null;
if (secure) this.$secure = true; else this.$secure = false;
}

// This function is the store() method of the Cookie object
function _Cookie_store()
{
// First, loop through the properties of the Cookie object and
// put together the value of the cookie. Since cookies use the
// equals sign and semicolons as separators, we'll use colons
// and ampersands for the individual state variables we store
// within a single cookie value. Note that we escape the value
// of each state variable, in case it contains punctuation or other
// illegal characters.
var cookieval = "";

for(var prop in this) {
// ignore properties with names that begin with '$' and also methods
if ((prop.charAt(0) == '$') || ((typeof this[prop]) == 'function'))
continue;
if (cookieval != "") cookieval += '&';
cookieval += prop + ':' + escape(this[prop]);
}

// Now that we have the value of the cookie, put together the
// complete cookie string, which includes the name, and the various
// attributes specified when the Cookie object was created.
var cookie = this.$name + '=' + cookieval;
if (this.$expiration)
cookie += '; expires=' + this.$expiration.toGMTString();
if (this.$path) cookie += '; path=' + this.$path;
if (this.$domain) cookie += '; domain=' + this.$domain;
if (this.$secure) cookie += '; secure';

// Now store the cookie by setting the magic Document.cookie property
this.$document.cookie = cookie;
}

// This function is the load() method of the Cookie object
function _Cookie_load()
{
// First, get a list of all cookies that pertain to this document.
// We do this by reading the magic Document.cookie property
var allcookies = this.$document.cookie;
if (allcookies == "") return false;

// Now extract just the named cookie from that list.
var start = allcookies.indexOf(this.$name + '=');
if (start == -1) return false; // cookie not defined for this page.
start += this.$name.length + 1; // skip name and equals sign.
var end = allcookies.indexOf(';', start);
if (end == -1) end = allcookies.length;
var cookieval = allcookies.substring(start, end);

// Now that we've extracted the value of the named cookie, we've
// got to break that value down into individual state variable
// names and values. The name/value pairs are separated from each
// other with ampersands, and the individual names and values are
// separated from each other with colons. We use the split method
// to parse everything.
var a = cookieval.split('&'); // break it into array of name/value pairs
for(var i=0; i < a.length; i++) // break each pair into an array
a[i] = a[i].split(':');

// Now that we've parsed the cookie value, set all the names and values
// of the state variables in this Cookie object. Note that we unescape()
// the property value, because we called escape() when we stored it.
for(var i = 0; i < a.length; i++) {
this[a[i][0]] = unescape(a[i][1]);
}

// We're done, so return the success code
return true;
}

// This function is the remove() method of the Cookie object.

function _Cookie_remove()
{
var cookie;
cookie = this.$name + '=';
if (this.$path) cookie += '; path=' + this.$path;
if (this.$domain) cookie += '; domain=' + this.$domain;
cookie += '; expires=Fri, 02-Jan-1970 00:00:00 GMT';

this.$document.cookie = cookie;
}

// Create a dummy Cookie object, so we can use the prototype object to make
// the functions above into methods.
new Cookie();
Cookie.prototype.store = _Cookie_store;
Cookie.prototype.load = _Cookie_load;
Cookie.prototype.remove = _Cookie_remove;

//===================================================================
// The code above is the definition of the Cookie class
// The code below is a sample use of that class.
//===================================================================
// Create the cookie we'll use to save state for this web page.
// Since we're using the default path, this cookie will be accessible
// to all web pages in the same directory as this file or "below" it.
// Therefore, it should have a name that is unique among those pages.
// Not that we set the expiration to 10 days in the future.
var visitordata = new Cookie(document, "name_color_count_state", 240);

// First, try to read data stored in the cookie. If the cookie is not
// defined, or if it doesn't contain the data we need, then query the
// user for that data.
if (!visitordata.load() || !visitordata.name || !visitordata.color) {
visitordata.name = prompt("What is your name:", "");
visitordata.color = prompt("What is your favorite color:", "");
}

// Keep track of how many times this user has visited the page:
if (visitordata.visits == null) visitordata.visits = 0;
visitordata.visits++;

// Store the cookie values, even if they were already stored, so that the
// expiration date will be reset to 10 days from this most recent visit.
// Also, store them again to save the updated visits state variable.
visitordata.store();

// Now we can use the state variables we read:
document.write('<FONT SIZE=7 COLOR="' + visitordata.color + '">' +
'Welcome, ' + visitordata.name + '!' +
'</FONT>' +
'<P>You have visited ' + visitordata.visits + ' times.');
</SCRIPT>

<FORM>
<INPUT TYPE="button" VALUE="Forget My Name" onClick="visitordata.remove();">
</FORM>