テンプレートファイルでCSSファイルを読み込む指定をしましたが、うまく読みこめていないようで、
CSSファイルで指定した項目を意図した位置に表示することができません。
SMARTYを使ってます。テンプレートファイルにHTMLを記述しています。
環境は、WINDOWS VISTAにApacheを入れて動かしています。
このテンプレートファイル(reg.tpl)の中でのCSSファイルの読み込みやCLASSの指定では次のように書いてます。
(1)reg.tplの内容です。
<HTML>
<HEAD>
<TITLE>{$title}</TITLE>
{$form.javascript}
<link rel="stylesheet" href="layout.css" type="text/css" /> →ここでCSSファイルの読み込み指定
</HEAD>
<BODY bgcolor="#FFFFFF">
<CENTER>
<HR size="1" noshade>
<B>{$title}</B>
<HR size="1" noshade>
<DIV id="l1" CLASS="userid"> →ここでCSSファイルで設定したものを指定
<FONT size="2">{$form.user_id.label}:</FONT>
{if $form.user_id.error }
<font size="2">{$form.user_id.error}</font><BR>
{/if}
{$form.user_id.html}
</DIV>
~中略
(2)layout.cssの内容です。
.userid {
position : absolute;
top: 545px;
left: 150px;
width: 5%;
border:0px solid #FFB6C1;
}
(3)ファイルの設置場所は次の通りです。
┳templates━reg.tpl
______┗layout.css
(4)layout.cssをサーバーにアップロードして、上記(1)のreg.tplの<link …の指定部分を次のように絶対パスに変更すると
layout.cssが正常に読み込めます。(userid項目がcssファイルに指定した位置に表示されます)
<link rel="stylesheet" href="http://www.****.com/layout.css" type="text/css" />
(5)<link …で(1)のように指定した場合、layout.cssとreg.tplが同じフォルダにあれば実行しても
cssファイルが読み込めると認識していたのですが読み込めません。
index.htmlファイルとcssファイルを同じフォルダにおいて、index.htmlの中に(1)の<link …のようにファイル名のみの記述をするとうまく読み込めます。
テンプレートファイルの中で使う項目にCSSファイルを利用して自由なレイアウトを実現したいのですが、絶対パスでCSSファイルを指定する方法以外にないのでしょうか?
分かる方、ご教授下さい。
No.1ベストアンサー
- 回答日時:
> <link rel="stylesheet" href="layout.css" type="text/css" />
> <link rel="stylesheet" href="http://www.****.com/layout.css" type="text/css" />
> index.htmlファイルとcssファイルを同じフォルダにおいて、index.htmlの中に(1) の<link …のようにファイル名のみの記述をするとうまく読み込めます。
これらの事実がそのまま答えを示してくれていますね。
reg.tplはあくまでテンプレートファイルであり、CSSが実際に反映されるのはreg.tplからPHPによって生成されるHTMLファイルに対して、です。だからこの場合、(1)の相対パスによる記述が正しい位置関係になる為には、layout.cssの置き場所は、reg.tplと同じ階層ではないく、結果として生成されるHTMLファイルと同じでなければなりません。
つまり、(hoge.htmlが生成結果のHTMLファイルだとした場合)仮に下記の様な階層構造だったとしたら、
┳templates━reg.tpl
______┗layout.css
┗hoge.html
となっていしまい、HTMLファイルから見たlayout.cssは同じ階層にはいませんので(1)の相対パスの記述は正しくない事になってしまいます。(1)の相対パスの記述が正しくなる為には、
┳templates━reg.tpl
┗hoge.html
┗layout.css
こうならなければなりません。
CSSファイルや画像ファイルの相対パスというのは、あくまで(PHPから生成された結果としての)HTMLファイルから見た位置の事であって、テンプレートファイルから見た位置の事ではない、という事です。
ご回答ありがとうございました。
tplファイルに値を渡すphpファイルと同じフォルダにCSSを移動してもできませんでしたが、
最初に実行するindex.phpと同じフォルダ(ドキュメントルート)にCSSファイルを移動したら正常に
読み込めました。不思議です。本当にありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- HTML・CSS 書籍を見つつサイト造りの練習をしているのですが、見た目が一致しません 2 2022/11/28 15:00
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- JavaScript jqueryを使ったスムーススクロールのコードを書いたのですが、HTMLコード内にある、a butt 2 2022/04/14 10:59
- HTML・CSS cssが効かなくて困ってます 1 2023/01/01 23:57
- HTML・CSS 下にスクロールしても、追従するボタンのコードを書いたのですが、ボタンの中の画像が半分しか表示されない 1 2022/04/16 21:31
- HTML・CSS html/cssで要素が出てこなくて困ってます 1 2022/12/31 16:59
- HTML・CSS Dreamweaver のテンプレートでの相対パスの設定について 2 2023/06/13 17:28
- HTML・CSS アコーディオンメニューが思うように動作しません。 1 2023/08/20 16:48
- HTML・CSS CSSでサイトの背景に画像を組み込みたいのですが反映されません 2 2022/11/22 16:21
- HTML・CSS テキストを画面の真ん中に配置したいです。 2 2022/11/25 16:11
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
HTMLからフォルダを開きたい
-
iPadの標準ブラウザでローカルH...
-
htmlの中にexcelが埋め込むには...
-
社内で利用するWebサイトを立ち...
-
<a href=…></a>で表示されない。
-
、URL化させるにはどうしたらい...
-
htmlの謎
-
htmlファイルのソースをエクセ...
-
メールに添付されたhtmlファイ...
-
HTMLの<a href="xxx.html">~</...
-
一つのhtmlファイルでページを...
-
C# ローカルにあるhtmlの相対...
-
編集HTMLファイルを別のフォル...
-
vbでhtmlファイルを作成するに...
-
.xpn
-
CSSが反映されない
-
テクトロ オシロ 拡張子 ISFフ...
-
楽天でiFrameを利用したいので...
-
ビルダーのファイル名、『html...
-
VBScriptで作成したWebページで...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
HTMLからフォルダを開きたい
-
iPadの標準ブラウザでローカルH...
-
社内で利用するWebサイトを立ち...
-
htmlの中にexcelが埋め込むには...
-
HTMLで別PCのフォルダを開く
-
<a href=…></a>で表示されない。
-
メールに添付されたhtmlファイ...
-
、URL化させるにはどうしたらい...
-
htmlにtextファイルを表示させ...
-
htmlの謎
-
JSPの中にhtmlファイルを埋め込...
-
コマンドプロンプトでパラメー...
-
楽天でiFrameを利用したいので...
-
スマホサイト url SP
-
input type="file"のmaxlength...
-
テクトロ オシロ 拡張子 ISFフ...
-
HTMLで画像を表示させたいです
-
フォルダ内の画像を一括でhtml...
-
Word文書の.docファイルをWeb上...
-
外部ファイルに関数を置いて、...
おすすめ情報