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

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

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

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

PHP

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

Q&A

解決済

2回答

528閲覧

WordPressでカスタムフィールドのfunctionを簡略化したい

chacky

総合スコア16

WordPress

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

PHP

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

0グッド

0クリップ

投稿2019/03/22 14:06

###実現したいこと
functions.phpでカスタムフィールドを保存しているのですが、そのコードを簡略化したいです。

下記のコードで
function create_lang() {}
function create_sex() {}
function create_age() {}
という3つを
function create_all() {}
のように一括したい感じです。

###現在の状況
現在のコードはこの「言語」に対応する形で
add_meta_box( 'post_meta_lang', '言語', 'create_post_meta_lang', 'mypost', 'side' );

このfunctionがあり、フィールドが追加されるようになっています。
function create_lang() {}

しかしこのように「性別」や「年齢」などたくさんあったときに
add_meta_box( 'post_meta_sex', '性別', 'create_post_meta_sex', 'mypost', 'side' );
add_meta_box( 'post_meta_age', '年齢', 'create_post_meta_age', 'mypost', 'side' );

このようにいちいち同じようなfunctionを書きたくないと思いました。
function create_sex() {}
function create_age() {}

これらのfunction create_xxx() {}で違うのは$keyname = 'post_meta_xxx';の部分だけだからです。

そこで教えていただきたいのは、「言語」「性別」「年齢」などのすべてに対応できるfunctionです。

たとえばこのように1つにまとめるにはどうしたらよろしいでしょうか。
function create_all() {}

###現在のソースコード
現在のソースコードはこちらです。

php

1/* 2投稿編集画面でカスタムフィールドを表示する 3=======================================*/ 4add_action( 'admin_menu', 'add_meta_field' ); 5function add_meta_field() { 6 add_meta_box( 'post_meta_lang', '言語', 'create_post_meta_lang', 'mypost', 'side' ); 7 add_meta_box( 'post_meta_sex', '性別', 'create_post_meta_sex', 'mypost', 'side' ); 8 add_meta_box( 'post_meta_age', '年齢', 'create_post_meta_age', 'mypost', 'side' ); 9} 10 11/* これらをまとめたfunctionはどのようなコードになるか? */ 12function create_lang() { 13 $keyname = 'post_meta_lang'; 14 global $post; 15 $get_value = get_post_meta( $post->ID, $keyname, true ); 16 wp_nonce_field( 'action-' . $keyname, 'nonce-' . $keyname ); 17 echo '<input name="' . $keyname . '" value="' . $get_value . '">'; 18} 19function create_sex() { 20 $keyname = 'post_meta_sex'; 21 // create_langと同じだからまとめたい 22} 23function create_age() { 24 $keyname = 'post_meta_age'; 25 // create_langと同じだからまとめたい 26} 27 28/* 29投稿編集画面でカスタムフィールドを保存する 30=======================================*/ 31add_action( 'save_post', 'save_meta_field' ); 32function save_meta_field( $post_id ) { 33 $custom_fields = ['post_meta_lang','post_meta_sex','post_meta_age']; 34 foreach( $custom_fields as $d ) { 35 if ( isset( $_POST['nonce-' . $d] ) && $_POST['nonce-' . $d] ) { 36 if( check_admin_referer( 'action-' . $d, 'nonce-' . $d ) ) { 37 if( isset( $_POST[$d] ) && $_POST[$d] ) { 38 update_post_meta( $post_id, $d, $_POST[$d] ); 39 } else { 40 delete_post_meta( $post_id, $d, get_post_meta( $post_id, $d, true ) ); 41 } 42 } 43 } 44 45 } 46}

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

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

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

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

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

guest

回答2

0

ベストアンサー

php

1$custom_fields=['言語'=>'lang','年齢'=>'age','性別'=>'sex']; 2add_action( 'admin_menu',function()use($custom_fields){ 3 foreach($custom_fields as $label=>$key){ 4 $keyname='post_meta_'.$key; 5 add_meta_box( $keyname, $label, function($post)use($label,$keyname){ 6 $get_value = get_post_meta( $post->ID, $keyname, true ); 7 wp_nonce_field( 'action-' . $keyname, 'nonce-' . $keyname ); 8 echo '<input name="' . $keyname . '" value="' . $get_value . '">'; 9 }, 'mypost', 'side' ); 10 } 11});

save_postの方も同じ要領で$custom_fieldsを使い回す

投稿2019/03/22 16:29

編集2019/03/22 16:42
KazuhiroHatano

総合スコア7804

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

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

chacky

2019/03/23 14:25

どうもありがとうございます。 add_action( の中に add_meta_box( を書くことなんてできたんですね。 いつもこういうWPで元からある関数は分けて使っていました。 save_postの方も add_action( の中ということですよね? 二行目の「use($custom_fields)」とはなんでしょうか? 検索しても「名前空間」ばかり出てきて、でもそれとは別のもののようですし、今回のコードにおける役割もよくわかりませんでした。 もしよかったら教えてください。
KazuhiroHatano

2019/03/23 14:38

use()は無名関数に変数を渡すためのものです javascriptと違ってphpは関数の中と外でスコープがちゃんと別れてるので 関数の外の変数を使うには何らかの形で中に渡してあげなきゃいけません 無名関数はPHP5.3から使えるようになったものです WordPressが無名関数を避けているのは 多分PHP5.2対応のためだと思います 流石にもういいんじゃないかと思います
chacky

2019/03/23 14:59 編集

ありがとうございます。なんとなく、わかりました。 $custom_fieldsの配列は関数の外にあるから、 function()use($custom_fields){ によって関数の中に渡さないといけないということですね。 でもそれならば、$custom_fieldsの配列を、foreachの直前(関数の中)に書いてあげれば、 function()use($custom_fields){ でなく function(){ だけでよくなりますよね。 そのほうがシンプルで良いということはないのでしょうか? $custom_fieldsの配列を関数の外に出しておくことにはどのようなメリットがあるのですか?
KazuhiroHatano

2019/03/23 15:20

$custom_fieldsを外に出してるのはsave_postでも使いたいからです 仮に$custom_fieldsの項目が増えたとしても$custom_fieldsの要素を一つ増やすだけで フォームの出力と保存の処理の変更が一箇所の修正だけで済みますし どちらかだけを変更して片方を変更し忘れて動かなくなったとかいうことが起きにくくなります
chacky

2019/03/23 15:27

ナルホド!「admin_menuの$custom_fields」と「save_postの$custom_fields」とで、同じ「$custom_fields」を二か所に書くことになってしまうからですか。ご高察とお心遣いに感謝申し上げます。どうもありがとうございました。
guest

0

$callback_args が多分使えるのでは。

【add_meta_box – WordPress私的マニュアル】
https://elearn.jp/wpman/function/add_meta_box.html

【add_meta_box() | Function | WordPress Developer Resources】
https://developer.wordpress.org/reference/functions/add_meta_box/

投稿2019/03/22 14:20

kei344

総合スコア69407

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

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

chacky

2019/03/22 14:47 編集

ありがとうございます。 「表示用関数のパラメータを指定」とありますが使い方がわかりませんねこれ。 質問に沿った具体的なコードではどうなるかわかりますか? 「add_meta_field() {}」で「add_meta_box」がありますけど、 その「add_meta_box」に「$callback_args」を使うだけで 「function create_lang() {}」と「function create_sex() {}」と「function create_age() {}」がまとまるというわけでもありませんよね?
kei344

2019/03/22 14:50

> 使い方がわかりませんねこれ。 こっちのほうがわかりやすいかな。 【関数リファレンス/add meta box - WordPress Codex 日本語版】 https://wpdocs.osdn.jp/%E9%96%A2%E6%95%B0%E3%83%AA%E3%83%95%E3%82%A1%E3%83%AC%E3%83%B3%E3%82%B9/add_meta_box#.E3.82.B3.E3.83.BC.E3.83.AB.E3.83.90.E3.83.83.E3.82.AF.E5.BC.95.E6.95.B0 > 「$callback_args」を使うだけで(中略)がまとまるわけでもありませんよね? まとめた関数を割り当てることが出来るだけです。
chacky

2019/03/23 14:27 編集

むつかしかったです…汗 「>まとめた関数を割り当てることが出来る」というのも理解できませんでした。 今回は質問に沿った形でご回答を頂けまして、「$callback_args」というのは見送りらせていただこうかと思います。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問