原生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 ...
随机推荐
- mybatis框架-choose when otherwise 的使用
需求:模拟实际业务情况,传入多条件进行查询 /** * 需求:模拟实际业务,用户传入多个条件,进行用户列表信息的查询 * @param roleids * @return */ public List ...
- Java Scanner语法
1.导入: import java.util.Scanner; 2.创建对象 Scanner scan = new Scanner(System.in);//一般变量名为scan或者in 最后关闭,s ...
- docker概述和安装及基本操作
一:概述 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器或Windows 机器上,也可以实现虚拟化,容器是完全使用 ...
- JavaScript遍历
- 获取当前页面url指定参数值
function getParam(paramName) { paramValue = "", isFound = !1; if (this.location.search.ind ...
- TensorFlow常用激活函数及其特点和用法(6种)详解
http://c.biancheng.net/view/1911.html 每个神经元都必须有激活函数.它们为神经元提供了模拟复杂非线性数据集所必需的非线性特性.该函数取所有输入的加权和,进而生成一个 ...
- centos7 编译安装 haproxy1.8.20
当前系统信息: [root@localhost ~]# cat /etc/os-release NAME="CentOS Linux" VERSION="7 (Core) ...
- 使用Swagger2构建SpringMVC项目中的Restful API文档
使用Swagger自动生成API文档,不仅增加了项目的可维护性,还提高了API的透明度更利于快速测试等工作,便于更快地发现和解决问题. 本篇文章只记录整合过程,关于Security Configura ...
- 为什么mysql事务回滚后,自增ID依然自增
因为innodb的auto_increament的计数器记录的当前值是保存在存内 存中的,并不是存在于磁盘上,当mysqlserver处于运行的时候,这个计数值只会随着insert改增长,不会随着de ...
- Java 解压 zip 文件
代码如下 package test_java; import java.io.File; import java.io.FileOutputStream; import java.io.IOExcep ...