ランディングページやキャンペーンサイトなどでは全画面イメージからスクロールさせるような場合が多くあります。
下にスクロールさせたいけど矢印に気づいてもらえないなんてことになってはもともこもありませんね。
そこで使えるのが、スクロールを促すための矢印アクションです。
目立ちすぎず、でも気がつきやすいホバーエフェクトを備えた矢印をご用意しました。
<div class="cp_arrows">
<a class="link cp_arrow" href="#">svgで作成した画像を変更する
<svg class="arrow_icon" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewbox="0 0 32 32">
<g fill="none" stroke="#039BE5" stroke-width="1.5" stroke-linejoin="round" stroke-miterlimit="10">
<circle class="arrow_icon_circle" cx="16" cy="16" r="15.12"></circle>
<path fill="#039BE5" d="M22.364 14.55L17 19.914V8h-2v11.914L9.636 14.55l-1.414 1.414L16 23.742l7.778-7.778z"/>
</g>
</svg>
</a>
</div>
.cp_arrows *, .cp_arrows *:before, .cp_arrows *:after {
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
.cp_arrows {
position: relative;
display: flex;
height: 300px;
margin: 2em auto;
justify-content: center;
align-items: center;
}
.cp_arrows .link {
cursor: pointer;
text-decoration: none;
color: #039be5;
}
.cp_arrows .cp_arrow {
line-height: 2rem;
display: inline-block;
height: 2rem;
}
.cp_arrows .cp_arrow .arrow_icon {
position: relative;
top: -1px;
-webkit-transition: -webkit-transform 0.3s ease;
transition: -webkit-transform 0.3s ease;
transition: transform 0.3s ease;
transition: transform 0.3s ease, -webkit-transform 0.3s ease;
vertical-align: middle;
}
.cp_arrows .cp_arrow .arrow_icon_circle {
-webkit-transition: stroke-dashoffset 0.3s ease;
transition: stroke-dashoffset 0.3s ease;
stroke-dasharray: 95;
stroke-dashoffset: 95;
}
.cp_arrows .cp_arrow:hover .arrow_icon {
-webkit-transform: translate3d(5px, 0, 0);
transform: translate3d(5px, 0, 0);
}
.cp_arrows .cp_arrow:hover .arrow_icon_circle {
stroke-dashoffset: 0;
}
<div class="cp_arrows">
<a href="#" class="cp_arrowcontainer">
<div class="cp_arrow"></div>
<div class="cp_arrow"></div>
<div class="cp_arrow"></div>
</a>
</div>
.cp_arrows *, .cp_arrows *:before, .cp_arrows *:after {
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
.cp_arrows {
position: relative;
display: flex;
height: 300px;
margin: 2em auto;
justify-content: center;
align-items: center;
}
.cp_arrows .cp_arrowcontainer {
position: absolute;
top: 50%;
left: 50%;
display: block;
width: 100px;
height: 100px;
-webkit-transform: translate(-50%, -50%) rotateZ(0deg);
transform: translate(-50%, -50%) rotateZ(0deg);
}
.cp_arrows .cp_arrowcontainer:hover {
cursor: pointer;
}
.cp_arrows .cp_arrowcontainer:hover .cp_arrow {
top: 50%;
}
.cp_arrows .cp_arrow {
position: absolute;
left: 50%;
-webkit-transition: all 0.3s ease-in-out;
transition: all 0.3s ease-in-out;
}
.cp_arrows .cp_arrow:before, .cp_arrows .cp_arrow:after {
position: absolute;
display: block;
width: 4px;
height: 50px;
content: '';
-webkit-transition: all 0.3s ease-in-out;
transition: all 0.3s ease-in-out;
-webkit-transform: translate(-50%, -50%) rotateZ(-65deg);
transform: translate(-50%, -50%) rotateZ(-65deg);
transform-origin: bottom right;
border-radius: 10px;
background: #FF5722;
}
.cp_arrows .cp_arrow:after {
-webkit-transform: translate(-50%, -50%) rotateZ(65deg);
transform: translate(-50%, -50%) rotateZ(65deg);
-webkit-transform-origin: bottom left;
transform-origin: bottom left;
}
.cp_arrows .cp_arrow:nth-child(1) {
top: 30%;
opacity: 0.3;
}
.cp_arrows .cp_arrow:nth-child(2) {
top: 50%;
opacity: 0.6;
}
.cp_arrows .cp_arrow:nth-child(3) {
top: 70%;
opacity: 1;
}
<div class="cp_arrows">
<a href="#" class="cp_arrowcontainer">
<div class="cp_arrow"></div>
<div class="cp_arrow"></div>
<div class="cp_arrow"></div>
</a>
</div>
.cp_arrows *, .cp_arrows *:before, .cp_arrows *:after {
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
.cp_arrows {
position: relative;
display: flex;
height: 300px;
margin: 2em auto;
justify-content: center;
align-items: center;
}
.cp_arrows .cp_arrowcontainer {
position: absolute;
top: 50%;
left: 50%;
display: block;
width: 100px;
height: 100px;
-webkit-transform: translate(-50%, -50%) rotateZ(0deg);
transform: translate(-50%, -50%) rotateZ(0deg);
}
.cp_arrows .cp_arrowcontainer:hover {
cursor: pointer;
}
.cp_arrows .cp_arrowcontainer:hover .cp_arrow {
top: 50%;
}
.cp_arrows .cp_arrowcontainer:hover .cp_arrow:before {
-webkit-transform: translate(-50%, -50%) rotateZ(-45deg);
transform: translate(-50%, -50%) rotateZ(-45deg);
}
.cp_arrows .cp_arrowcontainer:hover .cp_arrow:after {
-webkit-transform: translate(-50%, -50%) rotateZ(45deg);
transform: translate(-50%, -50%) rotateZ(45deg);
}
.cp_arrows .cp_arrow {
position: absolute;
left: 50%;
-webkit-transition: all 0.3s ease-in;
transition: all 0.3s ease-in;
}
.cp_arrows .cp_arrow:before, .cp_arrows .cp_arrow:after {
position: absolute;
display: block;
width: 4px;
height: 50px;
content: '';
-webkit-transition: all 0.3s ease-in;
transition: all 0.3s ease-in;
-webkit-transform: translate(-50%, -50%) rotateZ(-60deg);
transform: translate(-50%, -50%) rotateZ(-60deg);
transform-origin: bottom right;
border-radius: 10px;
background: #009688;
}
.cp_arrows .cp_arrow:after {
-webkit-transform: translate(-50%, -50%) rotateZ(60deg);
transform: translate(-50%, -50%) rotateZ(60deg);
-webkit-transform-origin: bottom left;
transform-origin: bottom left;
}
.cp_arrows .cp_arrow:nth-child(1) {
top: 30%;
opacity: 0.3;
}
.cp_arrows .cp_arrow:nth-child(2) {
top: 50%;
opacity: 0.6;
}
.cp_arrows .cp_arrow:nth-child(3) {
top: 70%;
opacity: 1;
}
<div class="cp_arrows">
<div class="cp_round">
<span></span>
<span></span>
<span></span>
<span></span>
</div>
</div>
.cp_arrows *, .cp_arrows *:before, .cp_arrows *:after {
-webkit-box-sizing: border-box;
box-sizing: border-box;
}
.cp_arrows {
position: relative;
display: flex;
height: 300px;
margin: 2em auto;
justify-content: center;
align-items: center;
}
.cp_arrows .cp_round {
position: relative;
width: 100px;
height: 100px;
border: 3px solid #42a5f5;
border-radius: 100%;
cursor: pointer;
}
.cp_arrows span {
position: absolute;
z-index: 999;
display: block;
width: 35px;
height: 5px;
-webkit-transition: 0.4s ease-in;
transition: 0.4s ease-in;
border-radius: 3px;
background: #42a5f5;
}
.cp_arrows span:first-child {
bottom: 30%;
left: 18%;
transform: rotate(30deg);
}
.cp_arrows span:nth-child(2) {
bottom: 30%;
left: 47%;
transform: rotate(-30deg);
}
.cp_arrows span:nth-child(3) {
bottom: 55%;
left: 18%;
transform: rotate(30deg);
}
.cp_arrows span:nth-child(4) {
bottom: 55%;
left: 47%;
transform: rotate(-30deg);
}
.cp_arrows .cp_round:hover span:nth-child(1) {
transform: rotate(-155deg);
}
.cp_arrows .cp_round:hover span:nth-child(2) {
transform: rotate(155deg);
}
.cp_arrows .cp_round:hover span:nth-child(3) {
transform: rotate(205deg);
}
.cp_arrows .cp_round:hover span:nth-child(4) {
transform: rotate(-205deg);
}
CSS3などで新たに追加された要素・装飾方法など、日々コードを書いていないと忘れてしまったり、ささっとプロトタイプを作る時などちょっとしたことに時間をかけている暇はない。そんな時に「あ〜、あれストックしときゃよかったなぁ」って困った自分用のストックブログです。カスタマイズなどがしやすいよう、昨今のweb制作に取り入れられる一般的なコードを中心に掲載しています。
@copypet_jp More Info