タイムアウト処理を行う
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<title>Sample</title>
<script type="text/javascript"><!--
function loadWebPage() {
xmlhttp = createXMLHttpRequest();
if (xmlhttp) {
document.getElementById("result").innerHTML = "読み込み中です";
pageURL = document.getElementById("sURL").value;
requestData = "curl.rb?sURL="+pageURL;
xmlhttp.onreadystatechange = check;
xmlhttp.open("get", requestData, true);
xmlhttp.send(null);
timerID = setTimeout("abortHttp()",3*1000); // 3秒でタイムアウト
}
}
function check() {
try {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
clearTimeout(timerID); // タイムアウトクリア
document.getElementById("result").innerHTML = xmlhttp.responseText;
}
}catch(e){}
}
function abortHttp()
{
xmlhttp.abort(); // 読み込み処理を中断
document.getElementById("result").innerHTML = "タイムアウトです。読み込みを中断しました";
}
// XMLHttpオブジェクト作成
function createXMLHttpRequest()
{
var XMLhttpObject = null;
try{
XMLhttpObject = new XMLHttpRequest();
}catch(e){
try{
XMLhttpObject = new ActiveXObject("Msxml2.XMLHTTP");
}catch(e){
try{
XMLhttpObject = new ActiveXObject("Microsoft.XMLHTTP");
}catch(e){
return null;
}
}
}
return XMLhttpObject;
}
// --></script>
</head>
<body>
<form>
URL:<input type="text" value="http://www.openspc.org/" id="sURL" size="40"><br>
<input type="button" value="指定ページの内容を表示する" onClick="loadWebPage()">
</form>
<div id="result"></div>
</body>
</html>
説明などは本書を参考にしてください。