相対パスと絶対パスの使い方

相対パスと絶対パスの使い方

相対パスと絶対パスは、ファイルやリソースを参照するための方法です。相対パスは現在のファイルからの位置関係でリソースを探し、絶対パスはサイトのルートディレクトリまたはURLの先頭から指定します。どちらを使うかはプロジェクトの構造や用途によって異なります。

✅ 一、相対パス(現在のファイルの位置を基準)

✴️ よく使われる書き方

書き方意味
./file.html現在のディレクトリ内の file.html
../file.html1つ上のディレクトリにある file.html
folder/file.html現在のディレクトリ内の folder フォルダにあるファイル
../../img/pic.jpg2つ上のディレクトリにある img フォルダ内の画像

✅ メリット

  • 柔軟性が高く、フォルダ構成を変更しても対応しやすい
  • サーバーのルートに依存しないため、ローカル開発に適している

❌ デメリット

  • ディレクトリ構成が変わると簡単にパスが壊れる
  • 大規模プロジェクトの共通リソース参照には不向き

✅ 二、絶対パス(ウェブサイトのルートまたは完全なURLを基準)

✴️ 2つのケース

1. サイトのルートディレクトリからのパス( / で始まる)

<link rel="stylesheet" href="/css/style.css">
<img src="/images/logo.png">

→ これは、サイトのルート / にある css/style.cssimages/logo.png を指します。

2. 完全な URL の場合

<script src="https://cdn.example.com/lib.js"></script>

→ 外部のサーバー(CDNなど)から読み込まれるリソースです。

✅ メリット

  • ファイルの場所がディレクトリ構造に左右されない
  • CDN や共通リソースなど、固定パスの指定に適している

❌ デメリット

  • サイトのディレクトリ構造が変わった場合、リンク切れになる可能性がある(管理者でない限り修正しにくい)
  • ローカル環境(HTML をダブルクリックして開いた場合)では / から始まるパスがうまく動作しないことがある

📝 注意点・補足

相対パスの落とし穴

  • ../ の階層を間違えると読み込めない
  • フォルダ構造を変更すると全て修正が必要になる場合もある

絶対パスの誤解

  • / から始まるのは「パソコンのルート」ではなく「ウェブサイトのルート」
  • ローカル環境で .html をダブルクリックして開くと絶対パスが効かないことがある

使い分けのコツ

  • 自分のファイルと同じ階層や下のフォルダなら相対パス
  • サイト全体で共通して使うリソースは絶対パス

❓ Web制作現場でよくある質問(FAQ)

Q1:相対パスはいつ使う?

A: 同じディレクトリ内や近くのファイルを参照するときに使います。コンポーネント内部などで便利です。

Q2:絶対パスはいつ使う?

A: サイト全体で使うCSSや画像、外部のCDNなど、常に同じ場所にあるものを参照したいときに使います。

Q3:/img/logo.pngの意味は?

A: サイトのルートディレクトリにある img フォルダの中の logo.png を指定しています。

Q4:絶対パスがローカルで動かないのはなぜ?

A: ブラウザで直接HTMLを開いていると、/ の意味が曖昧になり、正しく読み込めない場合があります。サーバー上では問題ありません。

Q5:混ぜて使っても大丈夫?

A: もちろん可能です。多くのプロジェクトでは、目的に応じて両方を使い分けています。


📝 まとめ(相対パス vs 絶対パス)

Web開発において、ファイルやリソースを正しく読み込むためには、「相対パス」と「絶対パス」の違いを理解しておくことが重要です。

✅ 相対パスの特徴

  • 現在のファイルの位置を基準にリソースを指定する方法
  • ローカル環境や柔軟なディレクトリ構成に適している
  • 例:./style.css../img/logo.png
  • フォルダ構造を変更するとパスが壊れることがある

✅ 絶対パスの特徴

  • サイトのルートディレクトリ(/)または完全な URL からの指定
  • サイト全体で共通のリソースや CDN に適している
  • 例:/css/main.csshttps://example.com/js/app.js
  • ローカルでの動作に注意が必要(/ で始まるパスは失敗することがある)

🔁 使い分けのポイント

  • 開発中・モジュール間の連携:相対パスが便利
  • 本番環境・共通ファイルや外部サービス:絶対パスが安定
  • 両方を場面によって使い分けるのが理想的

関連記事
IT業界の初心者が知っておくべきの用語(2025版)
新しいテクノロジーについて話すとき、時々自分がみんなのペースについていけないと感じることはありませんか?あるいは、その業界にいるのに、自分はまだ十分ではないと感じ、多くの専門用語を理解しなければならないこともあるでしょう。
Details
Details
6ヶ月前
IT業界の初心者が知っておくべきの用語(2025版)
フッターのJavaScriptは画像読み込みに影響する?ブラウザの読み込み順と最適化の基本
はじめに Webサイトの表示速度や操作感は、単にコンテンツの量や見た目だけでなく、ブラウザがリソースをどのように読み込むかによっても大きく左右されます。特にJavaScriptや画像の読み込み順序、そしてそれらがどのように相互作用しているか […]
解構人
解構人
6ヶ月前
フッターのJavaScriptは画像読み込みに影響する?ブラウザの読み込み順と最適化の基本
CSSによる絶対中央寄せ
実用性が高い方法順で7種類の実装方法を紹介 最も推奨されるのは Flexbox と Grid transform を使う方法はどんな要素にも応用可能 line-height や table-cell は特定用途向け JavaScript による制御も紹介されている
Details
Details
7ヶ月前
CSSによる絶対中央寄せ
はじめての二進数|10進数との変換方法をわかりやすく解説【初心者向け】
パソコンやスマホの中で使われている数字の仕組み、それが「二進数(バイナリ)」です。このページでは、10進数 ⇔ 2進数 の変換方法を、初心者の方でも理解できるようにやさしく解説します。 目次 二進数って何? 1|10進数から2進数に変換する […]
aki0o0
aki0o0
7ヶ月前
はじめての二進数|10進数との変換方法をわかりやすく解説【初心者向け】
CSS3 object-fit 属性浅析示例
object-fit は、画像や動画などの置き換え要素が、その親要素の枠内でどのように表示されるか(サイズ調整やトリミング)を指定するCSSプロパティです。 目次 CSS3のobject-fit属性の簡単な解説 文法 サンプル さまざまなo […]
Details
Details
7ヶ月前
CSS3 object-fit 属性浅析示例
よく使われるPHPライブラリ9選【公式リンク付き・2025年版】
2025年最新!PHPでのWeb開発に役立つライブラリ&フレームワーク12選を厳選紹介。Laravel・Symfony・PHPMailer・Guzzleなど、実務で使えるツールをまとめてチェック。公式リンク付きで、今すぐ使える便利リスト!
aki0o0
aki0o0
7ヶ月前
よく使われるPHPライブラリ9選【公式リンク付き・2025年版】
ページ遷移の一般的な方法
本記事では、Webページにおけるページ遷移(リダイレクト)の一般的な実装方法について紹介しています。JavaScript、HTMLのメタタグ、PHP、ASPを用いたリダイレクト方法をそれぞれ具体的なコード例と共に解説しています。
Details
Details
7ヶ月前
ページ遷移の一般的な方法
ブランドの認知を上げる効果的な施策とは?
ブランド認知を高めるための基本概念から具体的な施策、得られるメリットまでを網羅的に解説。戦略設計に役立つ実践的な内容です。
WASABI
WASABI
7ヶ月前
ブランドの認知を上げる効果的な施策とは?
和暦から西暦変換ツール
このツールは、日本の元号(和暦)と西暦を相互に変換できるシンプルな変換ツールです。「昭和64年は何年?」「2025年は令和何年?」といった場面で、すぐに答えがわかります。 履歴書の作成、行政手続き、年齢計算、歴史的資料の読み解きなどにご活用 […]
aki0o0
aki0o0
6ヶ月前
和暦から西暦変換ツール
【初心者向け】日本の国技 相撲【第3回】楽しみ方編|視聴や推し力士の作り方
今回は「楽しみ方編」。現在の相撲ブームがなぜ起こっているのか?相撲の色々な楽しみ方をご紹介。
WASABI
WASABI
6ヶ月前
【初心者向け】日本の国技 相撲【第3回】楽しみ方編|視聴や推し力士の作り方
PHPでMySQLのバージョンを確認する方法
PHPを使ってMySQLのバージョンを取得する方法には、mysqli_get_server_info()、PDO::getAttribute()、および SELECT VERSION() という3つの一般的な方法があります。それぞれの方法でMySQLへの接続が必要です。
Details
Details
6ヶ月前
PHPでMySQLのバージョンを確認する方法
SCSSの @for ループ(ループ文)
SCSSの @for ループ
無敵の小さな蚊
無敵の小さな蚊
7ヶ月前
SCSSの @for ループ(ループ文)
PHPでウェブサイトのフッターにあるCopyrightの年数範囲を自動更新する
auto_copyright() 関数は、動的に著作権の年数を出力します。引数として開始年を受け取り、現在の年と比較して、単一年または範囲(例: 2015 - 2025)を表示します。
Details
Details
7ヶ月前
PHPでウェブサイトのフッターにあるCopyrightの年数範囲を自動更新する
iPhone(iOS Safari)における input タグの角丸問題とその対策
iPhone(iOS Safari)でinputタグに自動で適用される角丸スタイルを無効化する方法を詳しく解説。CSSによるリセットやカスタムスタイルの実装手順を、具体的なコードとともに紹介します。
キウイフルーツ
キウイフルーツ
6ヶ月前
iPhone(iOS Safari)における input タグの角丸問題とその対策
PHPのcheckdnsrr関数徹底解説:メールアドレス検証での活用方法
目次 フォーム開発で遭遇した課題 checkdnsrr関数とは? 主な用途 メールアドレスのドメイン検証 ドメイン存在確認 SPFレコードチェック ネットワーク診断ツール メリット デメリットと制限事項 実際の活用例 基本的なメールドメイン […]
解構人
解構人
5ヶ月前
PHPのcheckdnsrr関数徹底解説:メールアドレス検証での活用方法