我正在使用JavaScript创建一些聊天应用程序,允许用户在按下回车键后发送消息
window.onkeydown=function(event){
if(event.keyCode==13){
sendNew();
}
}
并在 sendNew()函数中;
var msg=document.getElementById('txt').value.toString().trim();
if(msg!=="") {
//send message
document.getElementById('txt').value = "";
}
当textarea onfocus 时按Enter键,文本被清除,但似乎插入一个新行字符,光标将转到textarea中的下一行。
我怎样才能摆脱这种情况并拥有一个完全空的textarea?
答案 0 :(得分:12)
您需要做的是在按Enter键时取消浏览器的默认行为(您必须阻止浏览器添加新行)。
解决方案:使用event.preventDefault()
。文档:
https://developer.mozilla.org/en/docs/Web/API/Event/preventDefault
试试这段代码:
window.onkeydown=function(event){
if(event.keyCode==13){
sendNew();
if(event.preventDefault) event.preventDefault(); // This should fix it
return false; // Just a workaround for old browsers
}
}
有些开发人员忘记了
event.preventDefault
并写了return false
。这是一个不好的做法,我建议你 新方法。
答案 1 :(得分:4)
这是因为enter键的默认行为是插入一个新行。为了防止这种情况发生,来自keydown事件处理程序的return false
。
window.onkeydown=function(event){
if(event.keyCode==13){
sendNew();
return false; // prevent default behavior if ENTER key
}
}