私はPagelines Frameworkで構築されたサイトでWooCommerceを使っています。字幕/カスタマイズ可能なフィールドをサイト内のどこにでも表示させる必要があります。現状では、WooCommerceはその選択肢を提供していません。
私はカスタムフィールドを使ってみましたが、WooCommerceもこれらを使い、字幕と一緒に欲しくないものをたくさん出力しました。私のカスタムフィールドを "bookauthor"と名付けた場合、このコードは必要なカスタムフィールドのみを表示するように機能しますか?
<?php echo get_post_meta($id, "bookauthor", true); ?>
もしそうなら、どのように私は私の新しい分野をフロントエンドの製品タイトルのすぐ後に出力させるのですか?
私はこのphpファイルに必要なフックを見つけました(私はphpを知らない、と私はあなたに尋ねているのです)。
<?php
/*
* @hooked woocommerce_template_single_title - 5
* @hooked woocommerce_template_single_price - 10
* @hooked woocommerce_template_single_excerpt - 20
* @hooked woocommerce_template_single_add_to_cart - 30
* @hooked woocommerce_template_single_meta - 40
* @hooked woocommerce_template_single_sharing - 50
*/
?>
除外する方法は知っていますが、カスタムフィールドをそのリストに追加する方法を教えてください。
それとも私が必要なものを達成するためのまったく異なる方法がありますか?
手助けをしてくれる人に感謝の意を表します。
あなたの最初の質問に答えるために、このようにあなたのpost meta
"bookauthor"を得ることはまさにそれを反映するか表示するでしょう。あなたのコードで変数$id
を正しく定義しているのであれば - あるいは以下のようにすることもできます。
コードはあなたの2番目の質問、フックwoocommerce_single_product_summary
を通して2番目のタイトル行を製品ページに挿入する方法に答えるべきです。このように追加情報を追加するだけです。
function wpse116660_wc_add_2nd_title() {
?>
<div class="2nd-tile">
<?php echo get_post_meta(get_the_ID(), "bookauthor", true); ?>
</div>
<?php
}
add_action( 'woocommerce_single_product_summary', 'wpse116660_wc_add_2nd_title', 6 );
カスタム投稿メタをさらに快適にするために、@ pl4g4と@brasofiloが提案したことを実行して製品編集画面にメタボックスを追加することができますが、もちろん必須ではありません。 カスタムフィールドメタボックス 。
あなたはこのようにあなたのメタボックスを追加することができます、コードは add_meta_box wordpress codexページの最初の例に基づいています。
/**
* Adds a box to the main column on the Post and Page edit screens.
*/
function wpse116660_wc_2nd_title_mb() {
$screen = array( 'product' );
add_meta_box(
'wc_2nd_title_mb',
__( '2nd title', 'your_textdomain' ),
'wc_2nd_title_inner_mb',
$screen,
'advanced',
'high'
);
}
add_action( 'add_meta_boxes', 'wpse116660_wc_2nd_title_mb', 0 );
/**
* Prints the box content.
*
* @param WP_Post $post The object for the current post/page.
*/
function wpse116660_wc_2nd_title_inner_mb( $post ) {
// Add an nonce field so we can check for it later.
wp_nonce_field( 'wc_2nd_title_inner_mb', 'wc_2nd_title_inner_mb_nonce' );
/*
* Use get_post_meta() to retrieve an existing value
* from the database and use the value for the form.
*/
$value = get_post_meta( $post->ID, 'bookauthor', true );
echo '<label for="bookauthor_field">';
_e( "Bookauthor", 'your_textdomain' );
echo '</label> ';
echo '<input type="text" id="bookauthor_field" name="bookauthor_field" value="' . esc_attr( $value ) . '" size="50" />';
}
/**
* When the post is saved, saves our custom data.
*
* @param int $post_id The ID of the post being saved.
*/
function wpse116660_wc_2nd_title_save_postdata( $post_id ) {
/*
* We need to verify this came from the our screen and with proper authorization,
* because save_post can be triggered at other times.
*/
// Check if our nonce is set.
if ( ! isset( $_POST['wc_2nd_title_inner_mb_nonce'] ) )
return $post_id;
$nonce = $_POST['wc_2nd_title_inner_mb_nonce'];
// Verify that the nonce is valid.
if ( ! wp_verify_nonce( $nonce, 'wc_2nd_title_inner_mb' ) )
return $post_id;
// If this is an autosave, our form has not been submitted, so we don't want to do anything.
if ( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE )
return $post_id;
// Check the user's permissions.
if ( 'page' == $_POST['post_type'] ) {
if ( ! current_user_can( 'edit_page', $post_id ) )
return $post_id;
} else {
if ( ! current_user_can( 'edit_post', $post_id ) )
return $post_id;
}
/* OK, its safe for us to save the data now. */
// Sanitize user input.
$mydata = sanitize_text_field( $_POST['bookauthor_field'] );
// Update the meta field in the database.
update_post_meta( $post_id, 'bookauthor', $mydata );
}
add_action( 'save_post', 'wpse116660_wc_2nd_title_save_postdata' );