ボタンをクリックする度に異なる処理を行う

説明

ランダムに実行する関数を変更するには、あらかじめ配列に関数を定義しておきます。JavaScriptでは配列に関数を入れることもでき、実行する際にはサンプルのようにrndFunc[n]()として呼び出すことができます。
JavaScriptテクニック ブック  詳しい解説などはJavaScriptテクニック ブックを参照してください。

サンプルコード [実行]

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<title>JavaScript Sample</title>
<link rel="stylesheet" type="text/css" href="main.css" media="all">
<script type="text/javascript" src="main.js"></script>
</head>
<body>
<h1>ボタンをクリックする度に異なる処理を行う</h1>
<form action="./enq.cgi" method="get" id="mainForm" name="mainForm">
金額:<input type="text" name="price" id="price" value="215">
<input type="button" id="setButton" value="実行">
</form>
<div id="result">結果:</div>
</body>
</html>

window.onload = function(){
document.getElementById("setButton").onclick = function(){
var n = Math.floor(Math.random() * rndFunc.length);
rndFunc[n]();
}
}
var rndFunc = [
function(){
var pr = document.getElementById("price").value;
document.getElementById("result").innerHTML = pr+"円";
},
function(){
var pr = document.getElementById("price").value;
document.getElementById("result").innerHTML = "¥"+pr;
},
function(){
var pr = document.getElementById("price").value;
document.getElementById("result").innerHTML = "$"+pr;
}