原生JS实现上拉下拉列表
话不多说,代码上来,有些知识点直接就在注释里
HTML
<div class="list-down">
<button id="btn">选择项</button>
<ul id="list-chooses" style="display: none;">
<li><a href="#">Python</a></li>
<li><a href="#">JavaScript</a></li>
<li><a href="#">Java</a></li>
<li><a href="#">PHP</a></li>
<li><a href="#">C++</a></li>
<li><a href="#">C语言</a></li>
<li><a href="#">Android</a></li>
<li><a href="#">微信小程序</a></li>
<li><a href="#">Node.js</a></li>
<li><a href="#">Bootstrap</a></li>
<li><a href="#">HTML && CSS</a></li>
<li id="close"><a href="#">关闭</a></li>
</ul>
</div>
CSS
<style type="text/css">
* {
margin:;
padding:;
font-size: 16px;
/* 消除按钮点击之后默认出现的蓝色边框 */
outline: none;
}
ul {
list-style: none;
}
.list-down {
width: 150px;
margin: 10px auto;
text-align: center;
}
.list-down button {
width: 150px;
height: 40px;
cursor: pointer;
background-color: #ea6f5a;
border: none;
color: #ccc;
}
.list-down button:hover {
color: #fff;
font-size: 17px;
font-style:;
}
.list-down button:focus {
border: none;
} .list-down #list-chooses {
border-top: 1px solid #ddd;
}
.list-down #list-chooses li {
width: 150px;
height:;
line-height: 40px;
background-color: #ea6f5a;
}
.list-down #list-chooses li a {
color: #ccc;
text-decoration: none;
}
.list-down #list-chooses li:hover a {
color: #fff;
font-size: 17px;
font-style:;
}
.list-down #list-chooses li#close {
border-top: 1px solid #ddd;
}
</style>
JavaScript
<script type="text/javascript"> window.onload = () => {
const listBtn = document.getElementById('btn')
const lists = document.getElementById('list-chooses');
const listsLis = lists.querySelectorAll('li');
const listsCloseBtn = document.getElementById('close'); // 列表选项从上而下出现
let listDown = () => {
let startHeight = 0;
let stopHeight = 40; let timeId = setInterval(() => {
startHeight++;
// 注意:forEach() 方法在 IE8 以下不支持
listsLis.forEach((item) => {
item.style.height = startHeight + 'px';
});
if (startHeight >= stopHeight) {
clearInterval(timeId);
}
}, 10); lists.style.display = 'block';
}; // 列表选项从下而上消失
let listUp = () => {
let startHeight = 40;
let stopHeight = 0; let timeId = setInterval(() => {
startHeight--;
listsLis.forEach((item) => {
item.style.height = startHeight + 'px';
});
if (startHeight <= stopHeight) {
clearInterval(timeId);
}
}, 10); // 这里,如果不延时的话,会直接消失,而没有上拉的效果
setTimeout(() => {
lists.style.display = 'none';
}, 350);
}; // 如果列表选项为隐藏,点击则显示;如果列表选项为显示,点击则隐藏
listBtn.addEventListener('click', () => {
if (lists.style.display == 'none') {
listDown();
} else {
listUp();
}
}); listsCloseBtn.addEventListener('click', () => {
listUp();
});
};
</script>
原生JS实现上拉下拉列表的更多相关文章
- 原生js实现上拉加载
原生js实现上拉加载其实超级简单,把原理整明白了你也会,再也不用去引一个mescroll啦~ 好了,废话不多说,开始进入正题:上拉加载是怎么去做的,原理就是监听滚动条滑到页面底部,然后就去做一次请求数 ...
- js_原生js实现上拉加载更多的功能。
1.人生啊,是我莽撞了啊.这是我公司一个喜欢读书的女孩子的个性签名,喜欢哪些句子,不悲伤,却切切实实的令人喜好. 2.写程序是一件很直接明了的事情,明白了就是明白了,不懂就是不懂,不懂装懂的会让你走很 ...
- iscroll.js实现上拉刷新,下拉加载更多,应用技巧项目实战
上拉刷新,下拉加载更多...仿原生的效果----iscroll是一款做滚动效果的插件,具体介绍我就不废话,看官方文档,我只写下我项目开发的一些用到的用法: (如果不好使,调试你的css,想必是个很蛋疼 ...
- 引用iScroll.js实现上拉和下拖刷新
使用技巧 1.引用iScroll.js, 在初始化时添加两个事件监听:touchMove.DOMContentLoaded. 2.实现iScroll插件的onScrollEnd事件, 也就是在这个事件 ...
- dropload.js(上拉加载插件使用过程中遇到的坑)
dropload.js相关介绍和使用以及demo下载详见:https://github.com/ximan/dropload (原文出处) 之前因为项目需要一个上拉加载的效果,然后无意中看到了此插件, ...
- js:基于原生js的上啦下啦刷新功能
链接:https://www.jianshu.com/p/a8392115e6f0演示地址:http://wonghan.cn/iscroll-demo/html:<body> <d ...
- js实现上拉加载思路整理
1.整体模拟滚动 监听touchmove事件,比较 scrollTop 和 $scroller.scrollHeight() - $container.height(). 缺点:滑动不流畅, tran ...
- 原生js封装二级城市下拉列表
闲的蛋疼,封装了个二级城市下拉 先保证html里有 <select id="province" size=1 > </select> <select ...
- 原生js实现二级联动下拉列表菜单
二级联动下拉列表菜单的难点在于对后台返回的数据进行解析,不多逼逼,直接上代码 上图是后台返回的数据 实现代码如下: var deviceNotExist = true;//防止数据重复 if(data ...
随机推荐
- nginx在linux下安装(源码编译)
下载 http://nginx.org/en/download.html 安装 安装依赖 yum -y install gcc gcc-c++ zlib zlib-devel pcre-devel o ...
- python nose 自写插件打乱class类中用例执行顺序,但将test_a和test_z排除
在使用nose时,有这样一个需求,用例执行打乱,但部分用例因场景原因必须先执行,这类用例在写用例时人为的加上了test_a或test_z字样 网上找了一圈,都没找到合适的方法,只有自己写插件了 已写完 ...
- 第二阶段冲刺(个人)——three
今天的个人计划:选择功能界面的选择框排版设计.使得一些选择功能当点击鼠标事件后才会出现. 昨天做了什么?测试登录功能并优化. 遇到了什么困难?一些js函数的运用不熟悉,好多借助了百度.
- SpringBoot如何切换Redis默认库
一些闲扯的话 我们清楚,Redis 尽管提供了 16 个索引库,但是每个数据库之间是隔离互不共享的,客户端默认连接使用的是 0 号数据库 . 注意:上方情况是基于单机 Redis 的,在集群模式下是没 ...
- 梅尔倒谱系数特征(Mel-frequency cepstral coefficients,MFCC)
引言 感知实验表明,人耳对于声音信号的感知聚焦于某一特定频率区域内,而非在整个频谱包络中. MFCC特征是应用非常广泛的语音特征. 语音的MFCC特征是基于人耳感知实验得到,将人耳当成特定的滤波器,只 ...
- SDOI 2019 R2 摸鱼记
其实并没有什么动力来写这篇游记,毕竟呢,明明已经做好了被吊打的心理准备,可是当 Day 2 挂到没分时,当看到自己在高一里还排名二十时,还是有些,有些难言的滋味.学长们该走的真的都走了,就要只剩下 z ...
- B 题解————2019.10.16
相信他说的话,但不要当真 [题目描述]有一个长度为 n 的自然数序列 a,要求将这个序列恰好分成至少 m 个连续子段. 每个子段的价值为该子段的所有数的按位异或.要使所有子段的价值按位与的结果最大,输 ...
- React - 入门:前导、环境、目录、原理
前导介绍: facebook.2013开源.官网:https://reactjs.org/ 版本v16之后,对其底层的核心算法进行了重构,引入了底层的新引擎React Fiber(16版本以后的rea ...
- 使用 udev 进行动态内核设备管理(转自suse文档)
第 12 章使用 udev 进行动态内核设备管理¶ 目录 12.1. /dev 目录 12.2. 内核 uevents 和 udev 12.3. 驱动程序.内核模块和设备 12.4. 引导和启动设备设 ...
- git 学习网站
GitBook :https://git-scm.com/book/zh/v2 Git 教程 廖雪峰 :https://www.liaoxuefeng.com/wiki/89604348802960 ...