【发布时间】:2021-03-18 07:52:04
【问题描述】:
我有一个问题,手风琴菜单在我的 codepen 上看起来不错,但是当我在我的网站上实际实现手风琴菜单时,它有一个跳跃的过渡。您可以查看下面的代码笔:
https://codepen.io/tiffany-koval/pen/OJRVKGp
CSS
* {
margin: 0;
padding: 0;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
}
body {
background: #fff;
font-family: "Avenir Next Demi Bold";
font-size: 13px;
letter-spacing: 3px;
line-height: auto;
}
ul {
list-style-type: none;
}
a {
color: #000;
text-decoration: none;
}
.line-break {
border-bottom: 1px solid #ebebeb;
max-width: 800px;
margin-left: auto;
margin-right: auto;
}
.faq h1 {
font-family: "Avenir Next Medium";
font-size: 24px;
font-weight: 500px;
letter-spacing: 3px;
margin: 0;
text-transform: uppercase;
text-align: center;
line-height: auto;
margin-bottom: 10px;
}
.faq h2 {
font-family: "Avenir Next Medium";
font-size: 12px;
font-weight: 500px;
letter-spacing: 3px;
margin: 0;
text-align: center;
line-height: auto;
margin-bottom: 60px;
}
.faq {
margin-top: 100px;
}
@media screen and (max-width: 720px){
.faq {
margin-top: 40px !important;
}
}
/** =======================
* Accordion
===========================*/
.accordion {
width: 100%;
max-width:800px;
margin: 30px auto -5px;
background: #fbfbfb;
}
.accordion .link {
cursor: pointer;
display: block;
padding: 18px 15px 18px 15px;
color: #000;
font-size: 14px;
font-weight: 700;
border-bottom: 3px solid #fff;
position: relative;
-webkit-transition: all 0.4s ease;
-o-transition: all 0.4s ease;
transition: all 0.4s ease;
}
.accordion li:last-child .link {
border-bottom: 3px solid #fff;
margin-bottom: 0px !important;
}
.accordion li i {
position: absolute;
top: 22px;
left: 12px;
font-size: 18px;
color: #000;
-webkit-transition: all 0.4s ease;
-o-transition: all 0.4s ease;
transition: all 0.4s ease;
}
.accordion li i.fa-chevron-down {
right: 12px;
left: auto;
font-size: 12px;
}
.accordion li.open .link {
color: #000;
}
.accordion li.open i.fa-chevron-down {
-webkit-transform: rotate(180deg);
-ms-transform: rotate(180deg);
-o-transform: rotate(180deg);
transform: rotate(180deg);
}
.accordion li.default .submenu {display: block;}
/**
* Submenu
-----------------------------*/
.submenu {
display: none;
background: #fbfbfb;
font-size: 13px;
letter-spacing: 3px;
}
.submenu p {
border-bottom: 3px solid #fff;
}
.submenu p {
display: block;
font-family: "Avenir Next";
text-decoration: none;
color: #000;
padding: 15px;
padding-left: 18px;
-webkit-transition: all 0.25s ease;
-o-transition: all 0.25s ease;
transition: all 0.25s ease;
}
.submenu p:hover {
background: #fbfbfb;
color: #000;
}
/**
* More FAQs
-----------------------------*/
.accordion + .more-faqs {
margin-top: 0px !important;
background: none !important;
}
.fa-chevron-right {
margin-left: 115px;
font-size: 10px !important;
}
#more-faqs {
font-size: 13px;
letter-spacing: 3px;
font-family: "Avenir Next Medium";
}
Javascript
$(function(){
var Accordion = function(el, multiple) {
this.el = el || {};
this.multiple = multiple || false;
var link = this.el.find('.link');
link.on('click', {el: this.el, multiple: this.multiple},this.dropdown)
}
Accordion.prototype.dropdown = function(e) {
var $el = e.data.el;
$this = $(this),
$next = $this.next();
$next.slideToggle();
$this.parent().toggleClass('open');
if(!e.data.multiple){
$el.find('.submenu').not($next).slideUp().parent().removeClass('open');
}
}
var accordion = new Accordion($('#accordion'), false);
});
我一直认为这与手风琴菜单本身的填充或高度有关,但玩弄代码并没有改变。我怎样才能使我网站上的手风琴菜单看起来更像我的 codepen?有什么想法吗?
【问题讨论】:
标签: javascript html jquery css accordion