我正在構建一個簡單的留言箱。用jquery插入html不起作用
這裏的HTML:
<div id="shoutbox">
<form method="post" id="form" class="shoutbox-form">
<table>
<tr>
<td><label>User</label></td>
<td><input class="text user" id="nick" type="text" MAXLENGTH="25" /></td>
</tr>
<tr>
<td><label>Message</label></td>
<td><input class="text" id="shout" type="text" MAXLENGTH="255" /></td>
</tr>
<tr>
<td></td>
<td><input id="send-shout" type="submit" value="Dodaj!" /></td>
</tr>
</table>
</form>
<div id="shoutbox-container">
<span class="clear"></span>
<div class=".shoutbox">
<div id="shoutbox-loading"><img src="css/images/loading.gif" alt="Loading..." /></div>
<ul>
</ul>
</div>
</div>
</div
>
這裏的js代碼:
$(document).ready(function(){
var inputUser = $("#nick");
var inputMessage = $("#shout");
var loading = $("#shoutbox-loading");
var messageList = $(".shoutbox > ul");
function updateShoutbox(){
messageList.hide();
loading.fadeIn();
$.ajax({
type: "POST",
url: "/shouts/",
data: "action=refresh",
success: function(data){
var data = JSON.parse(data);
loading.fadeOut();
messageList.html(data["response"]);
messageList.fadeIn(2000);
}
});
}
});
但顯然messageList.html(數據[ 「迴應」])不起作用雖然螢火蟲顯示我的迴應是:
{"response": "<li><strong>user1</strong><img src=\"\" alt=\"\" >test<span class=\"date\">2010-10-07 19:36:13</span></li><li><strong>user2</strong><img src=\"\" alt=\"\" >test2<span class=\"date\">2010-10-07 20:23:56</span></li>"}
如果不是success
在阿賈克斯我有complete
我得到var data = JSON.parse(data);
錯誤。任何想法可以改變以解決這個問題?
UPDATE:
添加:
var c = data["response"];
console.log(c);
給我:
<li><strong>user1</strong><img src="" alt="" >test<span class="date">2010-10-07 19:36:13</span></li><li><strong>user2</strong><img src="" alt="" >test2<span class="date">2010-10-07 20:23:56</span></li>
在Firebug控制檯。
...除非在IE 6和7中沒有可用的JSON對象。 (和類名稱的好處) – lonesomeday 2010-10-07 21:31:12