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

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

ただいまの
回答率

88.59%

Custom Field Templateを使って外部CSSのアップロード

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,265

Leon-Lionking

score 22

Wordpress で個別ページ・投稿ページごとに外部CSSをファイルアップロードさせる方法をご教授お願いします。

下のサイトの記事を参考してみましたが、

<a href="https://teratail.com/questions/32918" target="_blank" >https://teratail.com/questions/32918</a>

絶対パスを必ず入れなければならない状態です。

内容
・Custom Field Template のプラグインを使用
・外部CSSを読み込ませる。
・絶対パス(例:http://example.com/wp/wp-content/themes/mytheme/css/)手間のかかる入力は避けたい。

コード

//定義の設定
define( 'TEMPLATEURL', get_bloginfo( 'stylesheet_directory' ));

function include_custom_css(){
    if(is_single()||is_page()){
    $cssstr = get_post_meta( get_the_ID(), 'importCSS', true ) ){
    $cssarr = split( " ", $cssstr );
    for( $i = 0; $i < count( $cssarr ); $i++ ){
    echo "<link type="text/css" rel="stylesheet" href="' . TEMPLATEURL . '/css/' . $cssarr[ $i ] . '" />\n";
                        }
                    }
                }
add_action('wp_head','include_custom_css');

管理画面の「Custom Field Template」の設定

・テンプレートタイトル:importCSS
・投稿タイプ:●両方
・テンプレートコンテンツ:
[inportCSS]
type = file
size = 20
label = ファイルアップロードCSS

以上です。

ご教授よろしくお願い致します。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • kei344

    2017/04/27 14:54

    「読み込ませる」「インポート」の違いはどのようなものなのでしょうか。また、例示用ドメインはご自身で所有されていない限り example.com, example.jp, example.co.jp など例示用に予約されたドメイン名を利用してください。 http://www.atmarkit.co.jp/fwin2k/win2ktips/801exampledom/exampledom.html

    キャンセル

  • Leon-Lionking

    2017/04/27 15:20

    質問の内容がわからず、すみません。ドメインに関して、修正しておきました。また再度教授お願いします。

    キャンセル

回答 2

check解決した方法

0

アドバイスしてくれてありがとうございます。
概念を変えてみました。

/**
 *
 * 外部CSSを読み込む
 *
 */
// 定義設定
define( 'TEMPLATEURL', get_stylesheet_directory_uri() );

function include_css(){
    if( is_single || is_page() ){                    // single page 両方表示
        if( $string = get_post_meta( get_the_ID(), 'includeCSS', true ) ){
            $array = explode( ',', $string );
            for( $i = 0; $i < count( $array ); $i++ ){
                echo '<link href="' . TEMPLATEURL . '/css/' . $array[ $i ] . '" type="text/css" rel="stylesheet" />' . "\n";
            }
        }
    }
}

// カスタムCSS の読込
add_action( 'wp_head', 'include_css' );

管理画面の「Custom Field Template」の設定

・テンプレートタイトル:importCSS 
・投稿タイプ:●両方 
・テンプレートコンテンツ: 
[inportCSS] 
type = text 
size = 50 
label = 外部CSS

アドバイスしてくれてありがとうございます。

補足:PHP7以上の環境の場合
・split() この関数は PHP 5.3.0 で 非推奨 となり、 PHP 7.0.0 で 削除 されたそうです。
・explode() 代用の関数を使用することによって、正常に動きました。

参考
split — 正規表現により文字列を分割し、配列に格納する

WordPress 日本語版の推奨動作環境
・PHP バージョン 7 以上
・MySQL バージョン 5.6 以上 または MariaDB バージョン 10.0 以上

であれば、split() を使うのでなく、代用の関数 explode() を使うとよいでしょう。

以上です。

ありがとうございました。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

type = file の指定の仕方及び取得の仕方が下記記事になります。

【Custom Field Templateの使い方[WordPress]】
http://kotori-blog.com/wordpress/customfieldtemplate/#pdf

get_bloginfo は get_stylesheet_directory_uri を使うほうが良いです。(上記記事によるとそもそも使う必要が無いと思いますが)

【URLを出力する際に bloginfo() に代わるテンプレートタグ | Web Design Leaves】
http://www.webdesignleaves.com/wp/wordpress/97/

CSSは直接link要素を使わず、wp_enqueue_style を使うのが最近のやり方です。

【WordPress で CSS、JavaScript ファイルを読み込む正しい方法 | EastCoder;】
http://eastcoder.com/2014/07/proper-way-to-enqueue-scripts-and-styles-with-wordpress/

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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