我创建了一个受“站点地图”启发的菜单,该菜单使用svgs连接菜单中的每个项目。目前,svg是静态的。但是我相信可以抽签吗?
我有一个复杂的问题,我只希望在可见容器ul时画线。
当父级li悬停在上方时,这些是当前可见的...
#submenu-1 li:hover>ul {
visibility: visible;
opacity: 1;
max-height: 500px;
transition: opacity 0.5s ease-in;
}
这里是小提琴的链接 https://jsfiddle.net/spittman/sn3xg5Lb/113/show
有什么想法吗?
谢谢 山姆
答案 0 :(得分:0)
你被困在哪里?关于如何在SVG中设置线条动画的堆栈溢出问题很多。
对于您的情况,我建议您重新绘制每行,以使它们都从顶部开始并在其叶子点结束。目前,它们似乎分成了多个部分,并朝着随机的方向前进。有些从头到尾,有些则从头开始。
例如:
<svg viewBox="0 0 900 50">
<polyline points="450,0, 450,25, 112.5,25, 112.5,50" class="st0"/>
<polyline points="450,0, 450,25, 337.5,25, 337.5,50" class="st0"/>
<polyline points="450,0, 450,25, 562.5,25, 562.5,50" class="st0"/>
<polyline points="450,0, 450,25, 787.5,25, 787.5,50" class="st0"/>
</svg>
通过设置stroke-dasharray
等于线条的长度来完成线条绘制动画。然后,将stroke-dashoffset
的长度从该长度减小到0。我在这里不再赘述。
#submenu-1 li ul svg polyline.st0 {
stroke-dasharray: 388px;
stroke-dashoffset: 388px;
}
然后将鼠标悬停在stroke-dashoffset
上,将其从388转换为0。
#submenu-1 li:hover>ul svg polyline.st0 {
stroke-dashoffset: 0;
transition: stroke-dashoffset 1s ease-in;
}
您需要为每个树SVG重复上述步骤。对于较小的树形图,388px
的值需要减小。
完整示例:
$('#menu').mouseover(function () {
$('#page-title').hide();
});
$('#menu').mouseout(function () {
$('#page-title').show();
});
@import url("https://use.typekit.net/tud5kgo.css");
body {
margin: 0;
padding: 0;
border: 0;
background-color: black;
}
/* Main Menu*/
#submenu-1 {
list-style: none;
margin: 0;
padding: 0px 0 0 0;
}
/* Level 1 – List item */
#submenu-1 li {
width: 900px;
float: left;
text-align: center;
padding-top: 10px;
}
#submenu-1 li:hover>ul {
visibility: visible;
opacity: 1;
max-height: 500px;
transition: opacity 0.5s ease-in;
}
#submenu-1 li ul svg polyline.st0 {
stroke-dasharray: 388px;
stroke-dashoffset: 388px;
}
#submenu-1 li:hover>ul svg polyline.st0 {
stroke-dashoffset: 0;
transition: stroke-dashoffset 1s ease-in;
}
#submenu-1 ul {
list-style: none;
left: 0;
margin: 0;
padding: 0;
position: relative;
width: 900px;
float: left;
visibility: hidden;
opacity: 0;
transition: visibility 0s, opacity 0.5s linear;
max-height: 0;
transition: max-height 0.5s ease-out;
z-index: 600;
padding: 10px 0px 0px 0px;
}
a:link,
a:visited,
a:active {
color: white;
text-align: center;
text-transform: uppercase;
text-decoration: none;
font-family: "montserrat";
font-weight: 800;
font-size: 25px;
letter-spacing: 2px;
line-height: 1;
}
a:hover {
color: grey;
}
.st0{fill:none;stroke:#FFFFFF;stroke-width:6;stroke-miterlimit:10;}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="container">
<div id="menu">
<ul id="submenu-1">
<li id="m"><a href="#">what brings<br>you here?</a>
<ul>
<svg viewBox="0 0 900 50">
<polyline points="450,0, 450,25, 112.5,25, 112.5,50" class="st0"/>
<polyline points="450,0, 450,25, 337.5,25, 337.5,50" class="st0"/>
<polyline points="450,0, 450,25, 562.5,25, 562.5,50" class="st0"/>
<polyline points="450,0, 450,25, 787.5,25, 787.5,50" class="st0"/>
</svg>
</ul>
</li>
</ul>
</div>
</div>