原生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 ...
随机推荐
- 如何让ThinkPHP支持模糊搜索
最近ytkah在做一个ThinkPHP的项目时发现了一个问题,搜索的功能只能检索出以*为开头的内容,不能检索出中间的词.例如:搜索包含6775的产品,搜索结果为空,而搜索000-6775 就有两个结果 ...
- 树莓派项目(1-2)人脸识别 C++
级联分类器 在这里,我们学习如何使用objdetect在我们的图像或视频中查找对象 https://docs.opencv.org/3.3.0/db/d28/tutorial_cascade_clas ...
- 模拟赛T2 线段树优化建图+tarjan+拓扑排序
然而这只是 70pts 的部分分,考场上没想到满分怎么做(现在也不会) code: #include <cstdio> #include <string> #include & ...
- 如何关闭/禁用.NET JIT调试对话框
当.NET程序有未处理的异常时,您可能会希望关闭出现的调试对话框.下面有两个选项: 1.启用JIT调试的注册表项 对于包含托管代码的应用程序,公共语言运行库将显示类似于JIT附加调试器的对话框.控制此 ...
- 6-STM32物联网开发WIFI(ESP8266)+GPRS(Air202)系统方案安全篇(Wi-Fi模块SSL连接MQTT)
5-STM32物联网开发WIFI(ESP8266)+GPRS(Air202)系统方案安全篇(配置MQTT的SSL证书,验证安全通信) 首先确定自己的固件打开了SSL,升级篇里面的固件我打开了SSL,如 ...
- ZROI 暑期高端峰会 A班 Day6 DP
[THUPC2018]城市地铁规划 (日常讲题之前 YY--) 一眼出 \(O(n^3+nk)\) 做法. \(dp[i][j]\) 表示前 \(i\) 个点,前 \(i\) 个点度数和为 \(j\) ...
- [HNOI2015]亚瑟王(概率期望,DP)
题目大意:很清晰了,不写了. $1\le T\le 444,1\le n\le 220,0\le r\le 132,0<p_i<1,0\le d_i\le 1000$. $p_i$ 和 $ ...
- haproxy 配置文件详解 之 综述
HAProxy 配置文件根据功能和用途,主要有5 个部分组成,但有些部分并不是必须的,可以根据需要选择相应的部分进行配置. 1.global 部分 用来设定全局配置参数,属于进程级的配置,通常和操作系 ...
- 第02组 Alpha冲刺(1/6)
队名:無駄無駄 组长博客 作业博客 组员情况 张越洋 过去两天完成了哪些任务 如何进行团队代码的版本管理 如何使用微信云开发 如何使用管理微信开发团队 接下来的计划 沟通前后端成员,监督.提醒他们尽快 ...
- 【技术博客】移动端的点击事件与Sticky Hover问题
目录 移动端的点击事件与Sticky Hover问题 TL;DR 前言 问题描述 背景 实现方式 问题 关于移动端浏览器的点击事件 初次发现问题后各种解决尝试:从点击事件本身下手 cursor: po ...