• 手机版

    扫码体验手机版

  • 微信公众号

    扫码关注公众号

国内首家协议开发

软芯音视解码保护平台

在线
客服

发布
需求

在线
聊天

天盟
APP

天盟APP下载

关注
微信

微信扫一扫访问
顶部

为什么这几行js代码,第一次触发keypress事件,输出的值总是为按下前的值?

想要每次在输入框输入文字,在控制台输出文本框内容。这是模仿百度搜索功能的一部分。问题是:我输入第一个字母,控制台输出的是空,然后按下第二个字母,控制台输出确实第一个,总是少了最后一个字符。var search = document.getElementById("search");var keyword;search.onkeypress = function () {        keyword = search.value;        console.log(keyword)}

免责声明:本内容仅代表回答会员见解不代表天盟观点,请谨慎对待。

版权声明:作者保留权利,不代表天盟立场。

使用道具 举报

全部参与1

因为你keypress的同时,是先执行了keypress的事件函数(在console上显示value),再在上显示你所按的键,因为这个执行顺序,每次console只能显示按键之前的value;
将js改成如下,增加了一个setTimeout(function(){},0),这么写可以改变setTimeout里面执行语句的执行顺序,让它在文档稳定后再执行;
varsearch=document.getElementById("search");varkeyword;search.onkeypress=function(){setTimeout(function(){keyword=search.value;console.log(keyword)},0)}你也可以试下将keypress改成keyup,也相当于改变了执行顺序

使用道具 举报

发新帖

发布任务需求已有1031289位用户正在使用天盟网服务

发布分类: *
任务预算: *
需求内容: *
手机号码: *
任务商家报价为
  • 预算价 :
  • 成交价 :
  • 完工期 :
  • 质保期 :

* 最终任务项目以服务商报价、双方协商为准!