原生js、html、css实现自定义select框(带搜索框和滚动条)

本文展示了如何使用原生js、html和css创建一个自定义的select框,该框具备搜索功能和滚动条。当自定义select值改变时,普通select也会同步更新,满足表单提交需求。作者分享了实现思路,包括隐藏原生select,使用div模拟,限制高度以显示滚动条,并通过oninput事件实现搜索过滤。
摘要由CSDN通过智能技术生成

原生js、html、css实现自定义select框(带搜索框和滚动条)

效果展示

在这里插入图片描述

功能描述

  如效果所见,它可以实现一般的select功能的同时,还附加搜索功能,输入关键词即可快捷搜索
  为了使其可以应用于实际,我还给他同步写了一个普通select,当此自定义select框的值修改时,普通select也跟着修改,可以满足表单提交的需求。
  接下来听听我的思路吧!

思路解析

  • 普通select写出后隐藏,做表单提交之用
  • 用div模仿select的功能写出一个复制体
  • 给div的value-body限制高度使其自动出现滚动条
  • 用input的oninput事件实时搜索条件,不符的值隐藏

代码参考

  • 准备图片三张
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 代码
    本人粗浅,代码出现不兼容状况实属常事,不过本人已测试火狐、Chrome、QQ浏览器最新版本兼容其功能。

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style type="text/css">

		*{
    
			padding: 0;
			margin: 0;
		}

		body{
    
			width: 100vw;
			height: calc(100vh - 20px);
		}

		div.select select{
    
			display: none;
		}

		div.select-box{
    
			width: 200px;
			margin: 20px 20px;
		}

		div.select-head{
    
			position: relative;
			height: 30px;
			width: 100%;
			display: flex;
			border: solid 1px #000;
			align-items: center;
			cursor: pointer;
		}

		div.select-head span{
    
			font-size: 16px;
			margin-left: 5px;
			color: #AAA;
		}

		div.select-head span.fill{
    
			color: #000;
		}

		div.select-head i{
    
			position: absolute;
			height: 16px;
			width: 16px;
			right: 5px;
			background-image: url(./arrow.png);
			background-size: 16px auto;
		}

		div.select-body{
    
			display: none;
			width: 100%;
			border: solid 1px #000;
			border-top: none;
		}

		div.search-input{
    
			position: relative;
			height: 40px;
		}

		div.search-input input{
    
			height: 30px;
			width: 150px;
			margin: 5px 8px;
			text-indent: 10px;
			padding-right: 30px;
		}

		div.search-input i{
    
			position: absolute;
			display: block;
			height: 20px;
			width: 20px;
			top: 12px;
			right: 15px;
			background-image: url(./search-normal.png);
			background-size: 20px 20px;
			cursor: pointer;
		}

		div.search-input i:hover{
    
			background-image: url(./search-active.png);
		}

		div.value-body{
    
			max-height
  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值