開発環境
- OS X Lion - Apple(OS)
- Safari (Webプラウザ)
- TextWrangler(Text Editor) (BBEditの無料、light版)
- Script言語:JavaScript
- JavaScript Library: jQuery
『初めてのJavaScript 第2版』(シェリー・パワーズ著(Shelley Powers著)、武舎 広幸+武舎 るみ訳、オライリー・ジャパン、2009年、ISBN978-4-84311-425-5) の15章(Ajaxのデータ)練習問第15-1を解いてみる。
その他参考書籍
- JavaScript 第6版
- JavaScriptリファレンス 第6版
- 『jQueryクックブック』(jQuery Community Experts 著、株式会社クイープ 訳、オライリー・ジャパン、2010年、ISBN978-4-87311-468-2)
15-1.
コード(TextWrangler)
var xmlhttp = new XMLHttpRequest();
function getRecipe(){
var drink = encodeURIComponent($('#drink').val());
var url = "recipe.php?drink=" + drink;
xmlhttp.open("GET", url, true);
xmlhttp.onreadystatatechange = printRecipe;
xmlhttp.send(null);
}
function printRecipe(o){
if(xmlhttp.readyState == 4 && xmlhttp.status = 200){
var b = document.getElementsByTagName('body')[0];
var recipe = document.createElement('div');
var h3 = document.createElement('h3');
var title = xmlhttp.responseXML.getElementsByTagName('title')[0].firstChild.nodeValue;
var text = document.createTextNode(title);
h3.appendChild(text);
recipe.appendChild(h3);
var ul = document.createElementsByTagName('ul');
var ingredients = xmlhttp.responseXML.getElementsByTagName('ingrident');
for(var i = 0; i < ingridents.length ; i++){
var li = document.createElementsByTagName('li');
var ingredient = ingredients[i].firstChild.nodeValue;
text = document.createTextNode(ingredient);
li.appendChild(text);
ul.appendChild(li);
}
recipe.appendChild(ul);
var p = document.createElementsByTagName('p');
var instruction = xmlhttp.responseXML.getElementsByTagName('instruction')[0].firstChild.nodeValue;
text = document.createTextNode(instruction);
p.appendChild(text);
recipe.appendChild(p);
b.appendChild(recipe);
}
}
0 コメント:
コメントを投稿