HTMLの書き方
head終了タグ直前に自作のCSSを読み込みます。
<link rel="stylesheet" type="text/css" href="css/5-3-3.css">
body内のテキストナビゲーションを表示させたい場所に以下のHTMLを記載します。
<ul class="gnavi">
<li class="current"><a href="#">Home</a></li><!--現在地にはcurrentクラスを付ける-->
<li><a href="#">About</a></li>
<li><a href="#">Service</a></li>
<li><a href="#">Contact</a></li>
</ul>
CSSの書き方
/*==================================================
共通 横並びのための設定
===================================*/
.gnavi{
display: flex;
flex-wrap: wrap;/*スマホ表示折り返し用なのでPCのみなら不要*/
margin:0 0 50px 0;
list-style: none;
}
.gnavi li a{
display: block;
padding:10px 30px;
text-decoration: none;
color: #333;
}
.gnavi li{
margin-bottom:20px;
}
/*==================================================
5-3-3 左から右に線が伸びる(下部)
===================================*/
.gnavi li a{
/*線の基点とするためrelativeを指定*/
position: relative;
}
.gnavi li.current a,
.gnavi li a:hover{
color:#0481A2;
}
.gnavi li a::after {
content: '';
/*絶対配置で線の位置を決める*/
position: absolute;
bottom: 0;
left: 10%;
/*線の形状*/
width: 80%;
height: 2px;
background:#0481A2;
/*アニメーションの指定*/
transition: all .3s;
transform: scale(0, 1);/*X方向0、Y方向1*/
transform-origin: left top;/*左上基点*/
}
/*現在地とhoverの設定*/
.gnavi li.current a::after,
.gnavi li a:hover::after {
transform: scale(1, 1);/*X方向にスケール拡大*/
}
HTMLの書き方
head終了タグ直前に自作のCSSを読み込みます。
<link rel="stylesheet" type="text/css" href="css/5-3-2.css">
body内のテキストナビゲーションを表示させたい場所に以下のHTMLを記載します。
<ul class="gnavi">
<li class="current"><a href="#">Home</a></li><!--現在地にはcurrentクラスを付ける-->
<li><a href="#">About</a></li>
<li><a href="#">Service</a></li>
<li><a href="#">Contact</a></li>
</ul>
CSSの書き方
/*==================================================
共通 横並びのための設定
===================================*/
.gnavi{
display: flex;
flex-wrap: wrap;/*スマホ表示折り返し用なのでPCのみなら不要*/
margin:0 0 50px 0;
list-style: none;
}
.gnavi li a{
display: block;
padding:10px 30px;
text-decoration: none;
color: #333;
}
.gnavi li{
margin-bottom:20px;
}
/*==================================================
5-3-2 中心から外に線が伸びる(中央)
===================================*/
.gnavi li a{
/*線の基点とするためrelativeを指定*/
position: relative;
}
.gnavi li a::after {
content: '';
/*絶対配置で線の位置を決める*/
position: absolute;
top:50%;
left: 10%;
/*線の形状*/
width: 80%;
height: 1px;
background: #666;
/*アニメーションの指定*/
transition: all .3s;
transform: scale(0, 1);/*X方向0、Y方向1*/
transform-origin: center top;/*上部中央基点*/
}
/*現在地とhoverの設定*/
.gnavi li.current a::after,
.gnavi li a:hover::after {
transform: scale(1, 1);/*X方向にスケール拡大*/
}
HTMLの書き方
head終了タグ直前に自作のCSSを読み込みます。
<link rel="stylesheet" type="text/css" href="css/9-2-1.css">
body内のテキストナビゲーションを表示させたい場所に以下のHTMLを記載します。
<ul class="gnavi">
<li class="current"><a href="#">Home</a></li><!--現在地にはcurrentクラスを付ける-->
<li><a href="#">About</a></li>
<li><a href="#">Service</a></li>
<li><a href="#">Contact</a></li>
</ul>
CSSの書き方
/*==================================================
共通 横並びのための設定
===================================*/
.gnavi{
display: flex;
flex-wrap: wrap;/*スマホ表示折り返し用なのでPCのみなら不要*/
margin:0 0 50px 0;
list-style: none;
}
.gnavi li a{
display: block;
padding:10px 30px;
text-decoration: none;
color: #333;
}
.gnavi li{
margin-bottom:20px;
}
/*==================================================
5-3-1 中心から外に線が伸びる(下部)
===================================*/
.gnavi li a{
/*線の基点とするためrelativeを指定*/
position: relative;
}
.gnavi li.current a,
.gnavi li a:hover{
color:#0481A2;
}
.gnavi li a::after {
content: '';
/*絶対配置で線の位置を決める*/
position: absolute;
bottom: 0;
left: 10%;
/*線の形状*/
width: 80%;
height: 2px;
background:#0481A2;
/*アニメーションの指定*/
transition: all .3s;
transform: scale(0, 1);/*X方向0、Y方向1*/
transform-origin: center top;/*上部中央基点*/
}
/*現在地とhoverの設定*/
.gnavi li.current a::after,
.gnavi li a:hover::after {
transform: scale(1, 1);/*X方向にスケール拡大*/
}
HTMLの書き方
head終了タグ直前に自作のCSSを読み込みます。
<link rel="stylesheet" type="text/css" href="css/8-2-2.css">
body内にHeaderと、リンク元、リンク先のHTMLを記載します。
<header id="header">
<h1>Logo</h1>
</header>
<ul id="page-link">
<li><a href="#area-1">Area 1</a></li>
<li><a href="#area-2">Area 2</a></li>
</ul>
<section id="area-1">
<h2>タイトル</h2>
<p>内容</p>
</section>
<section id="area-2">
<h2>タイトル</h2>
<p>内容</p>
</section>
body 終了タグ直前に jQuery、動きを制御する自作のJS の2 つを読み込みます。
<script src="https://code.jquery.com/jquery-3.4.1.min.js" integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo=" crossorigin="anonymous"></script>
<!--自作のJS-->
<script src="js/8-2-2.js"></script>
CSSの書き方
/*== ヘッダー追従のためのCSS */
#header{
position: fixed;/*追従ナビのためpositionをfixedにする*/
top:0;/*ポジション設定topを0*/
height: 70px;/*headerの高さを指定*/
width:100%;/*position:fixed;にしたため、横幅100%を設定*/
background:#333;
color:#fff;
text-align: center;
padding: 20px;
}
/*検証のためのCSS*/
section{
padding: 500px 0;
}
#page-link{
padding-top: 100px;
}
JSの書き方
$('#page-link a[href*="#"]').click(function () {//全てのページ内リンクに適用させたい場合はa[href*="#"]のみでもOK
var elmHash = $(this).attr('href'); //ページ内リンクのHTMLタグhrefから、リンクされているエリアidの値を取得
var pos = $(elmHash).offset().top-70;//idの上部の距離からHeaderの高さを引いた値を取得
$('body,html').animate({scrollTop: pos}, 500); //取得した位置にスクロール。500の数値が大きくなるほどゆっくりスクロール
return false;
});
HTMLの書き方
body内にリンク元のHTMLとリンク先のHTMLを記載します。
<ul id="page-link">
<li><a href="#area-1">Area 1</a></li>
<li><a href="#area-2">Area 2</a></li>
</ul>
<section id="area-1">
<h2>タイトル</h2>
<p>内容</p>
</section>
<section id="area-2">
<h2>タイトル</h2>
<p>内容</p>
</section>
body 終了タグ直前に jQuery、動きを制御する自作のJS の2 つを読み込みます。
<script src="https://code.jquery.com/jquery-3.4.1.min.js" integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo=" crossorigin="anonymous"></script>
<!--自作のJS-->
<script src="js/8-2-1.js"></script>
JSの書き方
$('#page-link a[href*="#"]').click(function () {//全てのページ内リンクに適用させたい場合はa[href*="#"]のみでもOK
var elmHash = $(this).attr('href'); //ページ内リンクのHTMLタグhrefから、リンクされているエリアidの値を取得
var pos = $(elmHash).offset().top; //idの上部の距離を取得
$('body,html').animate({scrollTop: pos}, 500); //取得した位置にスクロール。500の数値が大きくなるほどゆっくりスクロール
return false;
});