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

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

新規登録して質問してみよう
ただいま回答率
85.48%
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

376閲覧

[WordPress] WordPressで自作プラグインに独自のCSSを読み込ませたい

DaisukeMori

総合スコア225

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2022/05/13 05:27

現在やろうとしてること

WordPressで自作プラグインにその中で適用できるcssを読み込ませたい。

こちらの記事には答えらしきものがありますが、これ通りにしてもスタイルが当たってくれません。

ディレクトリ構成

custom-field |- custom-field.php |- css |- form.css

php

1<?php 2/* 3Plugin Name: custom-field 4Plugin URI: http://www.example.com/plugin 5Description: This is Plugin Test. 6Author: Name 7Version: 1.0 8Author URI: http://www.example.com 9*/ 10 11if (! defined('ABSPATH')) { 12 exit; 13} 14 15// 記事通りに記述 16// 本来ならこれでスタイルが読み込まれるはず 17add_action('wp_enqueue_script','register_my_scripts'); 18function register_my_scripts(){ 19 $dir = plugin_dir_path( __FILE__ ); 20 wp_enqueue_style( $dir . 'css/form.css'); // ここは変更 21} 22 23// カスタムフィールドのメタボックス 24function add_custom_fields() { 25 add_meta_box('id', '独自カスタムフィールド(通常投稿)', 'insert_custom_fields', 'post', 'normal'); // postにすると通常投稿に追加 26} 27add_action('admin_menu', 'add_custom_fields'); 28 29// post投稿の入力エリア 30function insert_custom_fields() { 31 global $post; 32 33 // テキスト この場所に独自のスタイルを当てたい 34 echo ' 35 <div> 36 <p>タイトル</p> 37 <input type="text" name="title" value="'.get_post_meta($post->ID, 'title', true).'" /> 38 </div>'; 39} 40 41// カスタムフィールドの値を保存 42function save_custom_fields($post_id) { 43 if (!empty($_POST['title'])) { 44 update_post_meta($post_id, 'title', $_POST['title']); 45 } 46} 47add_action('save_post', 'save_custom_fields'); 48

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

内容が不明ですので、form.css のなかの CSS は正しいと仮定します。


$dir = plugin_dir_path( FILE );
wp_enqueue_style( $dir . 'css/form.css'); // ここは変更

まず、ここが間違っています。

wp_enqueue_style のパラメータは
1つめのパラメータが「スタイルシートのハンドル」
2つ目のパラメータが「CSSファイルの URL
です。(3つ目以降省略)

質問のコードでは、1つのパラメータしか指定していませんので、「$dir . 'css/form.css'」という「スタイルシートのハンドル」で、wp_register_style 関数で事前に登録されているスタイルシートを読み込もうとします。

また、第2パラメータは、 URL を与える必要がありますが、 plugin_dir_path( __FILE__ ) で取得できるのは、 /var/www/html/wp-content/plugins/myplugin/ のような OS 上のディレクトリパスになりますので、URL としてアクセスしてもファイルが存在しないので、404 で読み込まれないと思います。

おそらく、下記のようにする必要があるのではないでしょうか。

$dir = plugin_dir_url( __FILE__ ); wp_enqueue_style( 'my_plugin_style', $dir . 'css/form.css');

投稿2022/05/13 12:06

編集2022/05/13 12:07
CHERRY

総合スコア25171

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

DaisukeMori

2022/05/16 01:14

ありがとうございました。 あとadd_action('wp_enqueue_script','register_my_scripts'); ではできなくて、 普通に関数実行すれば適用されました。 register_my_scripts(); これはWordPressのルール上大丈夫でしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問