有没有遇到过同样的问题
你外层用一个label 包住就能实现你这个功能,要不给 图片 加事件 可以利用 jquery的 trigger方法 触发 select picElement(图片元素).on('click',function(){
selectElement下拉框元素).trigger("select");
})
抱歉抱歉,没有测试直接发错误代码,对不起;看这个 demo
原理:
1、你可以直接通过修改 select 的 size 属性来实现,但是这样比较丑,很明显;
原来:
修改 size:
跟原生比丑在两点:
1)位置上移了
2)滚动条出现了
2、比较好的实现,就是通过 js clone 一个 select,原来的 select 暂且称为 selectA,克隆后的 select 暂且称为 selectB;
题主这边点击 img 的时候,修改 selectB 的 size,这个时候option就都出来了,然后把它往下移到selectA 下面,解决了位置的问题;
然后修改宽度和overflow属性,一般情况下,比如 option 少于 10条时,不显示滚动条;大于 10 条时,再显示滚动条;这样就模拟了selectA 的点击情况,解决了滚动条的问题;
最后再监听 selectB 的 change 事件来修改 selectA 的值;
完
参考文档:
8 回答4.8k 阅读✓ 已解决
6 回答3.5k 阅读✓ 已解决
5 回答2.9k 阅读✓ 已解决
5 回答6.4k 阅读✓ 已解决
4 回答2.3k 阅读✓ 已解决
5 回答1.3k 阅读✓ 已解决
4 回答2.8k 阅读✓ 已解决
input 外面包一层父极,图片作为背景图,input设置背景为透明,background:transparent;
不考虑ie,给你的小图标那一层加属性:pointer-events: none;