質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.92%

共通部分の指定の仕方がわからない

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 619

syun625

score 17

JavaScriptで共通部分のheader, side, footerを作成してindex.htmlでは適用できたのですが、他のファイル下にあるhtml(下のディレクトリ図で言うpc.html)に適用しようとするとheader, side, footerのいずれも表示されないです。
(参考URL→https://qiita.com/hiroyukiwk/items/f2a74ba1406de9fad6f6)

簡単にディレクトリを書いてみました↓
web
├index.html
├js
│ └include.js
├diary
│   └pc.html
└include
.     ├header.html
.     ├side.html
.     └footer.html

下のheader, side, footerを指定するのが"<script>header('../');</script>"なんですがどのように変更すればよいかわかりません。

index.html

<!DOCTYPE html>
<html dir="ltr" lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, user-scalable=yes, maximum-scale=1.0, minimum-scale=1.0">
<title>*******</title>
<link rel="icon" type="image/png" href="./images/favicon.png">
<meta name="keywords" content="">
<meta name="description" content="">
<link rel="stylesheet" href="style.css" type="text/css" media="screen">
<!--[if lt IE 9]>
<script src="js/html5.js"></script>
<script src="js/css3-mediaqueries.js"></script>
<![endif]-->
<script src="js/jquery1.7.2.min.js"></script>
<script src="js/script.js"></script>
<script src="js/include.js"></script>
</head>
<body>

<script>header('../');</script>

<div id="wrapper">

    //本文

    <script>side('../');</script>

</div>

<script>footer('../');</script>

</body>
</html>

pc.html

<!DOCTYPE html>
<html dir="ltr" lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, user-scalable=yes, maximum-scale=1.0, minimum-scale=1.0">
<title>*******</title>
<link rel="icon" type="image/png" href="./images/favicon.png">
<meta name="keywords" content="">
<meta name="description" content="">
<link rel="stylesheet" href="style.css" type="text/css" media="screen">
<!--[if lt IE 9]>
<script src="js/html5.js"></script>
<script src="js/css3-mediaqueries.js"></script>
<![endif]-->
<script src="C:/Apache24/home/web/js/jquery1.7.2.min.js"></script>
<script src="C:/Apache24/home/web/js/script.js"></script>
<script src="C:/Apache24/home/web/js/include.js"></script>
</head>
<body>

<script>header('../');</script>

<div id="wrapper">

    //本文

    <script>side('../');</script>

</div>

<script>footer('../');</script>

</body>
</html>

include.js

function header(rootDir){
    $.ajax({
        url: rootDir + "include/header.html",
        cache: false,
        async: false,
        dataType: 'html',
        success: function(html){
            html = html.replace(/\{\$root\}/g, rootDir); 
            document.write(html);
        }
    });
}

function side(rootDir){
    $.ajax({
        url: rootDir + "include/side.html",
        cache: false,
        async: false,
        dataType: 'html',
        success: function(html){
            html = html.replace(/\{\$root\}/g, rootDir); 
            document.write(html);
        }
    });
}

function footer(rootDir){
    $.ajax({
        url: rootDir + "include/footer.html",
        cache: false,
        async: false,
        dataType: 'html',
        success: function(html){
            html = html.replace(/\{\$root\}/g, rootDir); 
            document.write(html);
        }
    });
}

補足情報

Apache/2.4.37 (Win64)

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • 退会済みユーザー

    退会済みユーザー

    2018/12/26 02:44 編集

    ajax部分のurlはどんな値になっているか表示できますか?

    キャンセル

  • syun625

    2018/12/26 16:07

    include.jsのことですかね…
    でも解決しました!ありがとうございました!

    キャンセル

回答 1

checkベストアンサー

+5

Apache配下で動作させているのでしたら
「C:/Apache24/home/」のようなパスにはなりません。
DocumentRootからの絶対パスまたは自ファイルからの相対パスを指定してください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/12/26 16:06

    できました!ありがとうございます!

    キャンセル

  • 2018/12/26 16:08

    解決されたようで何よりです。
    せっかくapache入れられてるならphp利用された方がスッキリするように思います。ご検討ください。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.92%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る