http://jsbin.com/ezecun/edit#javascript,html
我必须这样写,因为它是动态制作的,下面列出了实际代码。我在jsbin中简化了一下。基本上,使用盒子的值更新数组需要很长时间才能使用它。
谢谢你看看。
CODE: PHP
echo "<label style='float:left'>Comments: </label> <textarea onKeyUp=\"editItemInCart(this.value,'comments',".$itemNum.")\" onChange=\"editItemInCart(this.value,'comments',".$itemNum.")\" >".$cart['comments']."</textarea><br />";
的javascript
function editItemInCart(newValue,fieldName,itemNum) {
jQuery.ajax({
type:"POST",
url: "editItem.html",
data: "newvalue=" + newValue + "&fieldname=" + fieldName + "&itemNum=" + itemNum,
})
//alert(newValue + fieldName + itemNum);
}
答案 0 :(得分:2)
您真的想在每个键入的键上发布,还是在用户完成输入时?大多数人在处理一个字母之前可以输入整个单词。你需要一个计数。像这样:
var count = 0;
function doEditItemInCart(newValue,fieldName,itemNum)
{
count++;
setTimeout("editItemInCart('"+newValue+"','"+fieldName+"',"+itemNum+","+count+")",200);
}
function editItemInCart(newValue,fieldName,itemNum,cnt) {
if (count == cnt) {
count = 0;
jQuery.ajax({
type:"POST",
url: "editItem.html",
data: "newvalue=" + newValue + "&fieldname=" + fieldName + "&itemNum=" + itemNum,
})
//alert(newValue + fieldName + itemNum);
}
}
答案 1 :(得分:0)
根据您的评论,听起来您想要debounce keyup
事件。我推荐Ben Alman的jQuery throttle / debounce plugin。
var itemNum = $('#item_num_id').val();
$('#textarea_id').keyup($.debounce(250, editItemInCart(this.value,'comments', itemNum)));
上面的代码消除了内联事件处理程序,使您可以很好地分离标记和代码。