Code:
<html><head>
<SCRIPT LANGUAGE="JavaScript">
<!-- hide javascript from non-JavaScript browsers.
// This function calculates the total for items in the form which are selected
function calculateTotal(inputItem) {
with (inputItem.form) {
// process each of the different input types in the form.
if (inputItem.type == "radio") { // process radio buttons
// subtract the previously selected radio button value from the total
calculatedTotal.value = eval(calculatedTotal.value) - eval(previouslySelectedRadioButton.value);
// save the current radio selection value
previouslySelectedRadioButton.value = eval(inputItem.value);
// add the current radio button selection value to the total
calculatedTotal.value = eval(calculatedTotal.value) + eval(inputItem.value);
} else { // process check boxes
if (inputItem.checked == false) { // item was uncheck. subtract item value from total
calculatedTotal.value = eval(calculatedTotal.value) - eval(inputItem.value);
} else { // item was checked. add the item value to the total
calculatedTotal.value = eval(calculatedTotal.value) + eval(inputItem.value);
}
}
// total value should never be less than 0
if (calculatedTotal.value < 0) {
InitForm();
}
// return total value
return(formatCurrency(calculatedTotal.value));
}
}
// format a value as currency.
function formatCurrency(num) {
num = num.toString().replace(/\$|\,/g,'');
if(isNaN(num))
num = "0";
sign = (num == (num = Math.abs(num)));
num = Math.floor(num*100+0.50000000001);
cents = num%100;
num = Math.floor(num/100).toString();
if(cents<10)
cents = "0" + cents;
for (var i = 0; i < Math.floor((num.length-(1+i))/3); i++)
num = num.substring(0,num.length-(4*i+3)) + ',' + num.substring(num.length-(4*i+3));
return (((sign)?'':'-') + '$' + num + '.' + cents);
}
// This function initialzes all the form elements to default values
function InitForm() {
//Reset values on form
document.selectionForm.total.value='$0.00';
document.selectionForm.calculatedTotal.value=0;
document.selectionForm.previouslySelectedRadioButton.value=0;
//Set all checkboxes and radio buttons on form to unchecked:
for (i=0; i < document.selectionForm.elements.length; i++) {
if (document.selectionForm.elements[i].type == 'checkbox' | document.selectionForm.elements[i].type == 'radio') {
document.selectionForm.elements[i].checked = false;
}
}
//Set default radio button
document.selectionForm.ET[3].click()
}
// end commenting javascript -->
</SCRIPT>
</head>
<body onload="InitForm();" onreset="InitForm();">
<form method="POST" name="selectionForm">
<b>Pizza Order</b> <br>
<font face=Arial size=2>
Small $10.00
<input type="checkbox" name="Steak" value=10.00 onclick="this.form.total.value=calculateTotal(this);">
Medium $12.00
<input type="checkbox" name="Chicken" value=12.00 onclick="this.form.total.value=calculateTotal(this);">
Large $15.00
<input type="checkbox" name="Sushi" value=15.00 onclick="this.form.total.value=calculateTotal(this);">
<br>
<br>
<b>Extra Toppings (only one selection allowed):</b> <br>
<input type="radio" name="ET" id="ET" value=0.00 onclick="this.form.total.value=calculateTotal(this);"> None
<br>
<input type="radio" name="ET" id="ET" value=1.00 onclick="this.form.total.value=calculateTotal(this);"> Extra Cheese $1.00
<br>
<input type="radio" name="ET" id="ET" value=2.00 onclick="this.form.total.value=calculateTotal(this);"> Vegetarian $2.00
<br>
<input type="radio" name="ET" id="ET" value=3.00 onclick="this.form.total.value=calculateTotal(this);"> Meat $3.00
<br>
<br>
<br>
<input type="hidden" name="calculatedTotal" value=0>
<input type="hidden" name="previouslySelectedRadioButton" value=0>
<font size=+1> Your total is: </font><font face=Arial size=2><font size=+1>
<input type="text" name="total" readonly onFocus="this.blur();">
</font></font><font size=+1> </font> <br>
<br>
</font>
</form>
</body>
</html>
Then add a line of code to simulate a mouse click - '.click()' in your initialise function.
This isn't the best way to do it though. A better solution, I think, is to make one of the radio buttons selected by default (using HTML)
Code:
<input type="radio" checked>
and then alter your initialise function to calculate prices using the whole form.
Bookmarks