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

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

相対パスと絶対パスは、ファイルやリソースを参照するための方法です。相対パスは現在のファイルからの位置関係でリソースを探し、絶対パスはサイトのルートディレクトリまたは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
  • ローカルでの動作に注意が必要(/ で始まるパスは失敗することがある)

🔁 使い分けのポイント

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

関連記事
Facebookがウェブページを開いたときに自動でFacebookアプリを起動し、指定したユーザーのページを開く方法
このチュートリアルでは、ウェブページからFacebookアプリを自動または手動で起動し、指定したFacebookページを開く方法を紹介しています。ページIDの取得方法、iPhoneとAndroidで異なるリダイレクト方法、リンクによる手動遷移の実装例を説明し、最後にクライアント判別を含むサンプルパッケージも提供しています。Facebook誘導やモバイルUX改善を目指す方におすすめです。
Details
Details
10ヶ月前
Facebookがウェブページを開いたときに自動でFacebookアプリを起動し、指定したユーザーのページを開く方法
inputのプレースホルダー(placeholder)の色を変更する
プレースホルダーの色は::placeholder疑似要素で変更可能 IEやEdgeなどの古いブラウザ向けに:-ms-input-placeholder、::-ms-input-placeholderを併用 Firefoxでは透明度の調整のためopacity指定が推奨される
Details
Details
10ヶ月前
inputのプレースホルダー(placeholder)の色を変更する
【CSSテクニック】:not()セレクタで階層を跨いだ除外を実現
:not()疑似クラスはCSSでの除外指定に便利ですが、親要素や階層関係に対しては思わぬ制約があります。本記事では、WordPressの投稿構造を例に、インラインコードとコードブロックを正確に区別するためのセレクタ設計を解説します。
無敵の小さな蚊
無敵の小さな蚊
9ヶ月前
【CSSテクニック】:not()セレクタで階層を跨いだ除外を実現
日本語用WebサイトのCSSフォント設定(日本語フォント/游ゴシック/游明朝)
日本語フォントはOSにより異なるため、複数のフォントを優先順に指定する。 "Yu Gothic"や"Yu Mincho"はモダンな日本語フォントでWindows 8.1以降に搭載。 "ヒラギノ角ゴ"や"ヒラギノ明朝"はmacOS向けで、高品質。 "メイリオ"や"MS 明朝"などは古いWindows環境にも対応。 ゴシック体はカジュアル・読みやすさ重視、明朝体はフォーマル・高級感重視に適している。
Details
Details
10ヶ月前
日本語用WebサイトのCSSフォント設定(日本語フォント/游ゴシック/游明朝)
【2025年6月最新版】TIOBEインデックスで見る人気プログラミング言語ランキングとは?
2025年6月最新版のTIOBEインデックスから、今人気のプログラミング言語を解説。Python、C、C++、Javaなどの注目度や、インデックスの活用方法も紹介します。
解構人
解構人
9ヶ月前
【2025年6月最新版】TIOBEインデックスで見る人気プログラミング言語ランキングとは?
和暦から西暦変換ツール
このツールは、日本の元号(和暦)と西暦を相互に変換できるシンプルな変換ツールです。「昭和64年は何年?」「2025年は令和何年?」といった場面で、すぐに答えがわかります。 履歴書の作成、行政手続き、年齢計算、歴史的資料の読み解きなどにご活用 […]
aki0o0
aki0o0
9ヶ月前
和暦から西暦変換ツール
PHPでランダムIDを生成するランダムな文字列を生成する
このPHPコードは、セキュリティ重視のWebシステムに必要な「予測不可能な」ランダムトークンを生成するために設計されています。openssl_random_pseudo_bytes() を使うことで、一般的な rand() や mt_rand() よりも格段に安全なランダム性が確保されます。
Details
Details
10ヶ月前
PHPでランダムIDを生成するランダムな文字列を生成する
IT業界の初心者が知っておくべきの用語(2025版)
新しいテクノロジーについて話すとき、時々自分がみんなのペースについていけないと感じることはありませんか?あるいは、その業界にいるのに、自分はまだ十分ではないと感じ、多くの専門用語を理解しなければならないこともあるでしょう。
Details
Details
9ヶ月前
IT業界の初心者が知っておくべきの用語(2025版)
【CSS & JavaScript & SVG対応】円グラフ(扇形図)のアニメーション表現まとめ
はじめに 円グラフ(パイチャート)は、比率や構成比を視覚的に伝えるのに最適なUIコンポーネントです。最近、業務で使う機会があり、さまざまな方法でエフェクトをつけて表示する実装を試しました。 この記事では、以下の3パターンで実装する方法を紹介 […]
キウイフルーツ
キウイフルーツ
9ヶ月前
【CSS & JavaScript & SVG対応】円グラフ(扇形図)のアニメーション表現まとめ
ABテストとは?赤か青か?データが導く最適な選択
ABテストは、今やデジタルマーケティングの「常識」となった科学的な意思決定手法です。日本のECサイトやアプリ開発の現場でも、「どちらのデザインが効果的か」「どんなキャッチコピーが響くか」を決める際に頻繁に活用されています。 この手法のルーツ […]
解構人
解構人
8ヶ月前
ABテストとは?赤か青か?データが導く最適な選択
固定ヘッダー対応!jQueryベースのアンカーリンク平滑スクロール+位置補正実装
固定ヘッダーで隠れない! ページ内リンクをクリックしてもスクロール先が見えない問題を、jQueryを使って滑らかに解決。スムーズスクロール+動的補正により、非同期コンテンツにも対応した実用的な実装コードを紹介します。
キウイフルーツ
キウイフルーツ
9ヶ月前
固定ヘッダー対応!jQueryベースのアンカーリンク平滑スクロール+位置補正実装
PHPの hash_equals 関数とは?なぜ == や === を使わないのか?
hash_equals は PHP において、2つの文字列が等しいかを安全に比較するための関数です。特にパスワードのハッシュや署名の検証などで使われます。== や === といった通常の比較演算子とは異なり、タイミング攻撃(Timing A […]
解構人
解構人
8ヶ月前
PHPの hash_equals 関数とは?なぜ == や === を使わないのか?
JavaScriptでURL(パス)からファイル名を取得する
window.location.pathname でURLのパス部分を取得。 lastIndexOf('/') で最後のスラッシュ位置を検出。 substring でスラッシュの次から最後までを切り出し、ファイル名を抽出。
Details
Details
10ヶ月前
JavaScriptでURL(パス)からファイル名を取得する
SCSSの @for ループ(ループ文)
SCSSの @for ループ
無敵の小さな蚊
無敵の小さな蚊
10ヶ月前
SCSSの @for ループ(ループ文)
CSSで等間隔配置を実現:1行に複数または複数行に配置
CSSでは、特にレスポンシブデザインにおいて、複数の要素を等間隔に配置する必要があります。列数や間隔を動的に制御することで、柔軟なレイアウトが実現可能です。この記事では、FlexboxとGridの2つの方法を使って、1行に複数のアイテムを等間隔に配置する方法を紹介します。コード内の変数(列数や間隔)を調整することで、1行に表示するアイテム数やその間隔を簡単に管理でき、レイアウト調整が容易になり、開発効率が大幅に向上します。
無敵の小さな蚊
無敵の小さな蚊
9ヶ月前
CSSで等間隔配置を実現:1行に複数または複数行に配置