ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
href 属性とは
href (Hypertext REFerence) は a 要素や link 要素でリンク先 URLを指定する属性です。Web を「Web (くも の巣)」たらしめている最重要属性のひとつ。
基本構文
<a href="リンク先 URL">表示テキスト</a>
<a href="https://example.com/">Example へ</a>
指定可能な URL の種類
| 種類 | 例 | 説明 |
|---|---|---|
| 絶対 URL | https://example.com/page.html | プロトコル + ドメインから完全に指定 |
| プロトコル相対 URL | //example.com/page.html | 現在のプロトコル (http/https) を引き継ぐ |
| ルート相対 URL | /about/ | サイト ルートからの絶対パス |
| 文書相対 URL | ./next.html / ../up.html | 現在の文書からの相対 |
| ページ内リンク (フラグメント) | #section1 | 同一ページの id へジャンプ |
| 他ページの特定セクション | /article.html#section2 | ページ移動 + フラグメント |
| mailto | mailto:user@example.com | メーラ起動 |
| tel | tel:+81-3-1234-5678 | 電話発信 (スマホ) |
| sms | sms:+81-90-1234-5678 | SMS アプリ起動 |
| javascript | javascript:alert('hi') | JS 実行 (非推奨) |
絶対 URL
<!-- 完全な URL -->
<a href="https://example.com/path/to/page.html">完全な絶対 URL</a>
<!-- プロトコル相対 (http/https どちらにも対応) -->
<a href="//example.com/page.html">プロトコル相対</a>
相対 URL
<!-- 現在の URL: https://example.com/blog/article.html -->
<a href="next.html"> <!-- https://example.com/blog/next.html -->
<a href="./next.html"> <!-- 上と同じ (./ は明示) -->
<a href="../about.html"> <!-- https://example.com/about.html (1 つ上) -->
<a href="/contact.html"> <!-- https://example.com/contact.html (ルートから) -->
<a href="?q=hello"> <!-- 同 URL + クエリパラメータ -->
ページ内リンク (フラグメント)
# に続けて id を書くと、その要素までスクロールします。
<!-- 目次から本文へ -->
<ul>
<li><a href="#chapter-1">第 1 章</a></li>
<li><a href="#chapter-2">第 2 章</a></li>
</ul>
<h2 id="chapter-1">第 1 章</h2>
<p>...</p>
<h2 id="chapter-2">第 2 章</h2>
<p>...</p>
<!-- ページ先頭に戻る -->
<a href="#top">▲ ページの先頭へ</a>
mailto / tel / sms — プロトコルリンク
<!-- メール送信 (本文・件名・宛先を URL パラメータで指定可) -->
<a href="mailto:info@example.com">問い合わせる</a>
<a href="mailto:info@example.com?subject=お問い合わせ&body=本文">
件名と本文付き
</a>
<!-- 電話発信 (国際表記推奨) -->
<a href="tel:+81-3-1234-5678">03-1234-5678</a>
<!-- SMS 送信 -->
<a href="sms:+81-90-1234-5678?body=こんにちは">SMS</a>
target 属性 — リンクの開き方
| 値 | 意味 |
|---|---|
_self | 同じタブで開く (デフォルト) |
_blank | 新しいタブで開く |
_parent | 親フレームで開く (iframe 内) |
_top | 最上位ウィンドウで開く |
| (名前) | 指定した名前の (i)frame で開く |
<!-- 新規タブで開く + セキュリティ対策 -->
<a href="https://external.example.com/"
target="_blank"
rel="noopener noreferrer">外部サイト</a>
重要: target="_blank" に rel="noopener noreferrer" を付けないと、Reverse Tabnabbing という攻撃を許す恐れがあります (リンク先 JS が window.opener 経由で元タブを操作可能)。最新ブラウザではデフォルト無効化されつつありますが、明示推奨。
rel 属性 — リンクの関係性
| 値 | 意味 |
|---|---|
noopener | 新規タブから window.opener 経由のアクセスを禁止 |
noreferrer | リファラを送信しない |
nofollow | 検索エンジンに辿らせない (SEO 評価を渡さない) |
ugc | ユーザー生成コンテンツ (コメント / 投稿) |
sponsored | 広告 / アフィリエイト |
external | 外部サイトへのリンク |
me | 自分の他プロフィールへのリンク |
ダウンロードリンク
download 属性を付けると、リンクをクリックしたときにブラウザがダウンロードとして扱います。
<!-- 元ファイル名のままダウンロード -->
<a href="/files/report.pdf" download>レポート PDF</a>
<!-- ファイル名を指定してダウンロード -->
<a href="/files/report.pdf" download="2026年4月レポート.pdf">
4 月レポートをダウンロード
</a>
注意: クロスオリジンの URL では download 属性が無効化される (CORS の制限)。
空のリンク / プレースホルダ
JS で動的にリンク先を入れる場合、暫定で空のリンクを書くことがあります。href="#" はページトップにジャンプしてしまうので注意。
<!-- NG: ページトップに飛ぶ + ブラウザ履歴を汚す -->
<a href="#" onclick="doSomething()">ボタン</a>
<!-- 改善: イベントを止める -->
<a href="#" onclick="event.preventDefault(); doSomething();">ボタン</a>
<!-- 推奨: ボタンには button 要素を使う -->
<button type="button" onclick="doSomething()">ボタン</button>
アクセシビリティ
- リンクテキストは意味のある言葉に — 「こちら」「クリック」は NG
- 同じテキストで違うリンク先は避ける — スクリーンリーダーで区別できなくなる
- 外部サイトリンクには明示的なアイコンや説明を
- ファイルダウンロードはサイズや形式も伝える: 「PDF 形式 (2.3MB)」
FAQ
Q: 相対 URL と絶対 URL どちらが良い?
A: 内部リンクは相対 (またはルート相対)。ドメイン変更や開発環境への移植が楽。SEO 上の差はない。
Q: javascript: 疑似プロトコルは使うべき?
A: 非推奨。CSP (Content Security Policy) で禁止されることが多く、アクセシビリティも悪い。button + イベントリスナーを使う。
Q: tel: リンクは PC で動く?
A: スマホ / Skype 等のソフト電話アプリで起動。PC で何も起きなくても、CSS で隠さず表示するのが UX 上良い。
関連
- address要素 — 問い合わせ先を表すセマンティック要素
a要素 — アンカー本体link要素 — head 内のリソースリンクtarget/rel/download— 関連属性
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- href属性
- target属性
- download 属性
- rel 属性
- hreflang属性
- type属性
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 2026-06-22 12:19:10
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 2026-06-22 12:17:25
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?