首先来看看要实现的效果图
想要制作这么一个效果还是比较麻烦的,但是代码并不难理解。
首先,来看看 Html 代码。
XML/HTML Code复制内容到剪贴板- <div class="container">
- <div class="heading">
- <h2>Custom Select</h2>
- </div>
- <div class="select">
- <p>Please select</p>
- <ul>
- <li data-value="HTML5">HTML5</li>
- <li data-value="CSS3">CSS3</li>
- <li data-value="JavaScript">JavaScript</li>
- <li data-value="JQuery">JQuery</li>
- <li data-value="Backbone">Backbone</li>
- </ul>
- </div>
- </div>
可见,我们并没有利用原生的 select 元素,而是利用其它元素来模拟这个效果。我们为 li 元素指定了 data-value,主要是接下来我们会用 JQuery 获取选中值并将其放置到 p 元素下。
下面逐步来看 CSS 代码。
CSS Code复制内容到剪贴板- * {
- margin: 0;
- padding: 0;
- }
- html {
- font-family: 'Terminal';
- font-size: 62.5%;
- }
- body {
- background-color: #33CC66;
- }
1、将网页中所有元素的外边距和内边距设置为 0。
2、将网页中的默认字体设置为 Terminal,字体大小设置为 62.5%, 也就是 10px。
3、设置背景颜色为 #33CC66。
XML/HTML Code复制内容到剪贴板- <link href='http://fonts.googleapis.com/css?family=Lobster|Terminal+Dosis' rel='stylesheet' type='text/css'>
上面我们用到了 Terminal 字体,而且接下来我们还会使用 Lobster 字体,所以用这行代码添加引用。
1、指定 headng, select 宽度并指定其水平居中。
2、修改 heading 的宽度,主要是为了让其宽度大于 select 的宽度,显得更加美观。然后指定其上外边距和下外边距。
3、设置 heading 下 h2 元素的字体和字体大小,颜色。
CSS Code复制内容到剪贴板- .select > p, .select ul {
- background-color: #ffffff;
- font-size: 2rem;
- border: 1px solid bisque;
- border-radius: 5px;
- margin-bottom: 0;
- }
- .select > p {
- text-align: left;
- padding: 1rem;
- position: relative;
- border-bottom-rightright-radius: 0;
- border-bottom-left-radius: 0;
- cursor: pointer;
- color: rgba(102, 102, 102, .6);
- }
- .select > p:after {
- display: block;
- width: 10px;
- height: 10px;
- content: '';
- position: absolute;
- top: 1.4rem;
- rightright: 2rem;
- border-bottom: 1px solid #33CC66;
- border-left: 1px solid #33CC66;
- transform: rotate(-45deg);
- transition: transform .3s ease-out, top .2s ease-out;
- }
1、设置 p 和 ul 元素的背景颜色和边框等设置。
2、为 p 元素单独指定样式,并设置其 position 属性,主要是为了下面绘制右侧的下拉按钮。
3、利用 :after 在p 元素的右方绘制下拉按钮,可以看出来,我们是利用左下边框然后旋转 -45 度 模拟的这个效果。值得注意的是,我们需要将其 display 设置为 block,并且设置宽高,否则看不到 这个效果。
CSS Code复制内容到剪贴板- .select ul {
- margin-top: 0;
- border-top-left-radius: 0;
- border-top-rightright-radius: 0;
- list-style-type: none;
- cursor: pointer;
- overflow-y: auto;
- max-height: 0;
- transition: max-height .3s ease-out;
- }
- .select ul li {
- padding-left: 0.5rem;
- display: block;
- line-height: 3rem;
- text-align: left;
- }
1、设置 ul 的一些默认属性,并将其设置最大宽度为 0,指定 overflow-y 为 auto ,这个时候ul 将会被隐藏。
2、在这里设置的时候我遇到了一个问题,就是 li 标签始终占不满 ul 的一行,那是因为其默认有 margin 和 padding ,所以在一开始的时候就将网页中所有元素的外边距和内边距设置成了 0。
CSS Code复制内容到剪贴板- .select.open ul {
- max-height: 20rem;
- transform-origin: 50% 0;
- -webkit-animation: slide-down .5s ease-in;
- }
- .select.open > p:after {
- position: absolute;
- top: 1.6rem;
- transform: rotate(-225deg);
- transition: transform .3s ease-in, top .2s ease-in;
- }
1、为 open 设置最大高度,并为其指定动画效果。
2、将下拉按钮旋转 -225 度,并为其指定动画。
下面我们看看为 ul 元素指定的 slide-down 动画效果,这也是这个下拉特效的关键所在。
CSS Code复制内容到剪贴板- @-webkit-keyframes slide-down {
- 0% {
- transform: scale(1, 0);
- }
- 25% {
- transform: scale(1, 1.25);
- }
- 50% {
- transform: scale(1, 0.75);
- }
- 75% {
- transform: scale(1, 1.1);
- }
- 100% {
- transform: scale(1, 1);
- }
- }
看到以上代码可能就都明白了,就是不断改变 ul 的大小,让其在 0.75-1.25 之间进行缩放,所以就会有那个跳动的效果了。
下面还有一些简单的 CSS 代码,不再解释。
CSS Code复制内容到剪贴板- .select ul li:hover {
- background-color: rgba(102, 153, 102, 0.4);
- }
- .select .selected {
- background-color: rgba(102, 153, 102, 0.8);
- }
CSS 讲完了,下面就可以看看我们是如何利用 JQuery 控制这个效果的。
我们并不需要下载 JQuery 就可以使用,因为现在已经有很多网站提供了 CDN 服务,比如我使用的 BootCDN。
XML/HTML Code复制内容到剪贴板- <script src="http://cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>
下面就可以使用 JQuery 了。
XML/HTML Code复制内容到剪贴板- <script>
- $(document).ready(function () {
- $('.select ul li').on("click", function (e) {
- var _this = $(this);
- $('.select >p').text(_this.attr('data-value'));
- $(_this).addClass('selected').siblings().removeClass('selected');
- $('.select').toggleClass('open');
- cancelBubble(e);
- });
- $('.select>p').on("click", function (e) {
- $('.select').toggleClass('open');
- cancelBubble(e);
- });
- $(document).on('click', function () {
- $('.select').removeClass('open');
- })
- })
- function cancelBubble(event) {
- if (event.stopPropagation) {
- event.preventDefault();
- event.stopPropagation();
- } else {
- event.returnValue = false;
- event.cancelBubble();
- }
- }
- </script>
1、首先为 p 标签绑定 click 事件,在触发的时候,为 select 添加或移除 open class, 也就是将 ul 显示出来。
2、为 li 绑定 click 事件,当选中了一个 li 元素的时候,首先获取到 data-value,然后将其赋值给 p 标签,然后为选中的 li 添加 selected class,与此同时利用 siblings() 方法,让兄弟节点的 selected class 移除。
3、为 document 设置click 事件,当我们点击网页中任何一处地方的时候,如果 ul 是打开的,就将其关闭,不过这个时候由于所有元素都在 document 内,所以我们需要阻止事件冒泡,调用自己写的 cancelBubble() 方法。
总结
好了,本文的内容到这就基本介绍了,希望能对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流。
CSS,下拉框
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]