onkeydown 解决按回车键直接提交方案

登陆页面需要扑捉用户按下回车自动提交的需求:

在body里添加onkeydown事件 跳javascript 在提交表单。

查找文档如下

onkeydown 事件会在用户按下一个键盘按键时发生。

语法:οnkeydοwn="SomeJavaScriptCode"

支持该事件的html标签;

<a>, <acronym>, <address>, <area>, <b>, <bdo>, <big>, <blockquote>, <body>, <button>, <caption>, <cite>, <code>, <dd>, <del>, <dfn>, <div>, <dt>, <em>, <fieldset>, <form>, <h1> to <h6>, <hr>, <i>, <input>, <kbd>, <label>, <legend>, <li>, <map>, <object>, <ol>, <p>, <pre>, <q>, <samp>, <select>, <small>, <span>, <strong>, <sub>, <sup>, <table>, <tbody>, <td>, <textarea>, <tfoot>, <th>, <thead>, <tr>, <tt>, <ul>, <var>

支持该事件的javascript对象:

document, image, link, textarea

浏览器差异:

Internet Explorer 使用 event.keyCode 取回被按下的字符,而 Netscape/Firefox/Opera 使用 event.which。

实例:在本例中,用户无法在输入框中键入数字
<html>
<body>
<script type="text/javascript">
function noNumbers(e)
{
var keynum
var keychar
var numcheck

if(window.event) // IE
  {
  keynum = e.keyCode
  }
else if(e.which) // Netscape/Firefox/Opera
  {
  keynum = e.which
  }

keychar = String.fromCharCode(keynum)
numcheck = /\d/
return !numcheck.test(keychar)
}
</script>

<form>
<input type="text" οnkeydοwn="return noNumbers(event)" />
</form>

</html>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用Ant Design中的TreeSelect组件来实现选择后按回车键实现搜索的功能。首先,您需要设置TreeSelect的`showSearch`属性为`true`,然后在`onKeyDown`事件中监听回车键的按下事件,当按下回车键时,调用TreeSelect的`filterTreeNode`方法来对树节点进行搜索。 以下是一个简单的示例代码: ```jsx import React, { useState } from 'react'; import { TreeSelect } from 'antd'; const { TreeNode } = TreeSelect; const treeData = [ { title: 'Node 1', value: 'node1', children: [ { title: 'Child Node 1', value: 'child1' }, { title: 'Child Node 2', value: 'child2' }, ], }, { title: 'Node 2', value: 'node2', children: [ { title: 'Child Node 3', value: 'child3' }, { title: 'Child Node 4', value: 'child4' }, ], }, ]; const SearchableTreeSelect = () => { const [searchValue, setSearchValue] = useState(''); const handleKeyDown = (e) => { if (e.keyCode === 13) { // 13 is the key code for Enter key e.preventDefault(); e.stopPropagation(); setSearchValue(''); } }; const handleSearch = (value) => { setSearchValue(value); }; const renderTreeNodes = (data) => data.map((item) => { const { title, value, children } = item; const lowerCaseTitle = title.toLowerCase(); const lowerCaseSearchValue = searchValue.toLowerCase(); const index = lowerCaseTitle.indexOf(lowerCaseSearchValue); if (index === -1 && (!children || children.length === 0)) { return null; } let titleNode = title; if (index > -1) { titleNode = ( <> {title.substr(0, index)} <span className="search-highlight">{title.substr(index, searchValue.length)}</span> {title.substr(index + searchValue.length)} </> ); } return ( <TreeNode key={value} title={titleNode} value={value}> {children && renderTreeNodes(children)} </TreeNode> ); }); return ( <TreeSelect showSearch filterTreeNode={false} onSearch={handleSearch} onKeyDown={handleKeyDown} treeDefaultExpandAll style={{ width: '100%' }} > {renderTreeNodes(treeData)} </TreeSelect> ); }; export default SearchableTreeSelect; ``` 在这个示例中,我们使用了`useState` Hook来存储搜索关键字,并在`onKeyDown`事件中监听回车键的按下事件。当用户按下回车键时,我们将搜索关键字重置为空字符串。 在`renderTreeNodes`函数中,我们使用了递归算法来渲染树节点,并根据搜索关键字高亮显示匹配的文本。 最后,我们在TreeSelect组件中设置了`showSearch`属性为`true`,并将`filterTreeNode`属性设置为`false`,这样我们就可以自己处理搜索逻辑。在`onSearch`事件中,我们将搜索关键字存储到`searchValue`状态中,以便在`renderTreeNodes`函数中使用。 希望这可以帮助到您!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值