利用HTML5的Datalist元素实现输入提示

2023-06-06 11:08 阅读 929 次 评论 0 条

HTML5有无限可能,总是在释出一些新鲜实用的功能,让原生的web环境更加炫酷。

今天看到datalist 这个元素,可以用来预先定义一个输入框的潜在选项,也就是我们在平时项目中经常用jQuery插件或者自己写JS来实现的autocomplete「自动补全,但似乎自动提示更贴切一些」功能。

具体来说,页面上的input还是原来的input,只是在它的下面定义一下新的datalist在其中填充触发提示的文本,同时在该input元素上指定list属性指向这个list。一个大概的例子大概是像下面这样:

你最喜欢的浏览器是: <input list="browsers">
<datalist id="browsers">
  <option value="Internet Explorer">
  <option value="Firefox">
  <option value="Chrome">
  <option value="Opera">
  <option value="Safari">
</datalist>

最后出来的效果又差不多是这样的:

 

但是有一个不足之处,在input右边会有向下的箭头,这让它看起来就像一个dropdown 或者select 「下拉框」,解决办法是多加两句CSS代码来将它隐藏,但此方法只是针对webkit内核的浏览器进行的优化:

input::-webkit-calendar-picker-indicator {
    display: none;
    -webkit-appearance: none;
}

这样之后出来的效果差不多成了这样:

浏览器兼容性

 

可以看出,遥遥领先的依然是风采依旧的Chrome,对该元素的支持全线飘绿!

版权声明:本文著作权归原作者所有,欢迎分享本文,谢谢支持!
转载请注明:利用HTML5的Datalist元素实现输入提示 | 雨晨博客

发表评论


表情