おはようございます。
現在、Web ページに少し動的なものを追加しようとしているので、すべてのページをリロードせずにイベント リスナーを使用して外部ページをロードすることにしました。
この時点から、次のテスト ページ コンテンツを作成しました。
HTML:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Test</title>
<link href="http://fonts.googleapis.com/css?family=Open+Sans" rel="stylesheet" type="text/css">
<link type="text/css" rel="stylesheet" media="all" href="./assets/css/style.css">
</head>
<body>
<header>
<nav>
<ul>
<li><h1>Tagline of the page</h1></li>
<li id="login"><h1><a href="#" id="authentication">Classic Authentication</a></h1></li>
</ul>
</nav>
</header>
<section id='messages'>
<p class="title">I'm sorry dave, but you can't access this facility right now!</p>
</section>
<script src="/assets/scripts/ajax.js"></script>
</body>
</html>
Javascript:
function loadview(url, id) {
var xhr_object = null;
if (window.XMLHttpRequest) {
xhr_object = new XMLHttpRequest();
xhr_object.open("GET", url, true);
xhr_object.onreadystatechange = function(){
if (xhr_object.readyState != 4) {
return;
}
if (xhr_object.status != 200 && xhr_object.status != 304 && xhr_object.status !=0){
console.log("erreur :" + xhr_object.status);
return;
}
document.getElementById(id).innerHTML = xhr_object.responseText;
};
xhr_object.send();
}
}
var element = document.getElementById('authentication');
var target = document.getElementById('messages');
element.addEventListener("click",loadview('/views/auth_form.html',target.id),false);
ここで、私の問題は、ジョブを正しく実行していないイベント リスナーから発生しています。ID 'authentication'で識別される要素でイベントクリックが検出されたときにloadview()関数を実行するように彼に依頼しましたが、代わりに、ページが読み込まれるとすぐにイベント リスナーが loadview 関数を実行しています。私のために、あなたの助けを求めます SOF 達人 ^^
特に Js の部分では、私のコードがきれいではなく、かなり醜いことはわかっていますが、私のloadview()関数が正しく機能していることも知っています。また、古いスタイルのインラインonclick()メソッドを使用すると、完璧に動作します。
この特定のトピックについて手がかりが得られた場合は、私が聞いています;-) すべての改善アドバイスは受け入れられますが、最初に問題を解決したいので、このコードを実際にきれいにしたくないことに注意してください。
このコードはテストのみを目的としているため、完全にクリーンでなくても、個人的な学習以外は気にしません ;-)