JavaScript如何让select选择框可输入和可下拉选择
【1】Html+CSS兼容IE实现
基本原理:使用 input/select 两个元素,然后 input 覆盖在 select 上层 ,宽度并比select窄一点,这样用户就能点到select的箭头弹出下拉框
<div class="select-editable"> <select onchange="this.nextElementSibling.value=this.value"> <option value=""></option> <option value="115x175 mm">115x175 mm</option> <option value="120x160 mm">120x160 mm</option> <option value="120x287 mm">120x287 mm</option> </select> <input type="text" name="format" value="" /> </div>
.select-editable { position:relative; background-color:white; border:solid grey 1px; width:120px; height:18px; } .select-editable select { position:absolute; top:0px; left:0px; font-size:14px; border:none; width:120px; margin:0; } .select-editable input { position:absolute; top:0px; left:0px; width:100px; padding:1px; font-size:12px; border:none; } .select-editable select:focus, .select-editable input:focus { outline:none; }
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> .select-editable { position: relative; background-color: white; border: solid grey 1px; width: 120px; height: 18px; } .select-editable select { position: absolute; top: 0px; left: 0px; font-size: 14px; border: none; width: 120px; margin: 0; } .select-editable input { position: absolute; top: 0px; left: 0px; width: 100px; padding: 1px; font-size: 12px; border: none; } .select-editable select:focus, .select-editable input:focus { outline: none; } </style> <script src="./jquery.min.js"></script> </head> <body> <div class="select-editable"> <select onchange="this.nextElementSibling.value=this.value" id="cookies"> <!-- <option value=""></option> <option value="115x175 mm">115x175 mm</option> <option value="120x160 mm">120x160 mm</option> <option value="120x287 mm">120x287 mm</option> --> </select> <input type="text" name="format" value="" /> </div> <script> window.onload = function () { var optionList = [ { value: '1' }, { value: '2' }, { value: '3' }, { value: '4' }, { value: '5' }, ] $('#cookies').empty() if (optionList && optionList.length > 0) { for (var i = 0; i < optionList.length; i++) { $('#cookies').append(`<option value="` + optionList[i].value + `">`+optionList[i].value+`</option>`); } } } </script> </body> </html>
【2】datalist
Datalist是HTML5的原生标签,用于向input提供下拉和自动提示选项,支持输入和下拉选择两种方式。但是目前IE10及其以下浏览器并不支持, 并且IE11无法触发input和change事件,相当于IE系列均无法很好地实现。如果仅支持Chrome或Eletron桌面的应用则可以放心使用。
<input list="cookies" placeholder="Type of Cookie"/> <datalist id="cookies"> <option value="Chocolate Chip"/> <option value="Peanut Butter"/> <option value="Raisin Oatmeal"/> </datalist>
<body> <div> <input list="cookies" placeholder="请选择或输入" /> <datalist id="cookies"> <!-- <option value="Chocolate Chip" /> <option value="Peanut Butter" /> <option value="Raisin Oatmeal" /> --> </datalist> </div> <script> window.onload = function () { var optionList = [ { value: '1' }, { value: '2' }, { value: '3' }, { value: '4' }, { value: '5' }, ] $('#cookies').empty() if (optionList && optionList.length > 0) { for (var i = 0; i < optionList.length; i++) { $('#cookies').append(`<option value="` + optionList[i].value + `" />`); } } } </script> </body> </html>
总结
到此这篇关于JavaScript如何让select选择框可输入和可下拉选择的文章就介绍到这了,更多相关js select选择框可输入可下拉选择内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
CascadeView级联组件实现思路详解(分离思想和单链表)
本文介绍自己最近做省市级联的类似的级联功能的实现思路,为了尽可能地做到职责分离跟表现与行为分离,这个功能拆分成了2个组件并用到了单链表来实现关键的级联逻辑,下一段有演示效果的gif图2016-04-04js去掉数组中undefined及空字符串、null两种方法例子
这篇文章主要给大家介绍了关于js去掉数组中undefined及空字符串、null的两种方法例子,文中还介绍了undefined与null之间的区别,通过代码介绍的非常详细,需要的朋友可以参考下2024-04-04微信小程序van-field中的left-icon属性自定义实现过程
在小程序中,我们是用 Vant 组件库时,常常会用到 van-field 输入框控件,今天我将跟大家分享的是 van-field 输入框控件中的 left-icon 属性的自定义怎么实现,感兴趣的朋友一起看看吧2023-08-08
最新评论