首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >onkeyup太慢了

onkeyup太慢了
EN

Stack Overflow用户
提问于 2011-08-24 05:08:15
回答 2查看 985关注 0票数 2

http://jsbin.com/ezecun/edit#javascript,html

我必须这样写,因为它是动态生成的,实际代码如下所示。我在jsbin中对它进行了一些简化。基本上,使用box的值更新数组需要很长时间,因此无法使用。

谢谢你看一看。

代码: php

代码语言:javascript
复制
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

代码语言:javascript
复制
function editItemInCart(newValue,fieldName,itemNum) {
    jQuery.ajax({
        type:"POST",
        url: "editItem.html",
        data: "newvalue=" + newValue + "&fieldname=" + fieldName + "&itemNum=" + itemNum,
    })
    //alert(newValue + fieldName + itemNum);
}
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-08-24 05:28:27

您真的想在每个键入的键上发布,还是在用户完成键入时发布?大多数人可以在处理一个字母之前键入一个完整的单词。你需要清点一下。如下所示:

代码语言:javascript
复制
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);
    }
}
票数 2
EN

Stack Overflow用户

发布于 2011-08-24 05:33:37

根据您的评论,您似乎想要对keyup事件执行debounce操作。我推荐Ben Alman的jQuery throttle / debounce plugin

代码语言:javascript
复制
var itemNum = $('#item_num_id').val();
$('#textarea_id').keyup($.debounce(250, editItemInCart(this.value,'comments', itemNum)));

上面的代码消除了内联事件处理程序,使您可以很好地分离标记和代码。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7167567

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档