2

製品用に作成したカスタム投稿タイプがあります。次のような10個のカスタムフィールドタイプがあります。

DocName1
DocUrl1

DocName2
DocUrl2

... 等々。カスタムフィールドのカスタム投稿タイプメタボックスのコードは次のとおりです。

//* Add custom Meta Boxes for Products *//

$prefix = 'aps_';  //To prevent conflicts with other plugins

$meta_box = array(
    'id' => 'products-meta-boxes',
    'title' => "Product Details",
    'page' => 'tf_products',  //attach to products custom post
    'context' => 'normal',
    'priority' => 'high',
    'fields' => array(
        array(
            'name' => 'Document Name 1',
            'desc' => 'Name of PDF or Document you want to share',
            'id' => $prefix . 'docname1',
            'type' => 'text',
            'std' => ''
        ),
        array(
            'name' => 'Document URL 1',
            'desc' => 'Web Address to PDF or document you want to share',
            'id' => $prefix . 'docurl1',
            'type' => 'text',
            'std' => 'http://'
        ),
        array(
            'name' => 'Document Name 2',
            'desc' => 'Name of PDF or Document you want to share',
            'id' => $prefix . 'docname2',
            'type' => 'text',
            'std' => ''
        ),
        array(
            'name' => 'Document URL 2',
            'desc' => 'Web Address to PDF or document you want to share',
            'id' => $prefix . 'docurl2',
            'type' => 'text',
            'std' => 'http://'
        )       
    )   
);

DocName1 - DocUrl1グリッドの1行にテキストボックスとしてエコーアウトできるように、それらをグループ化したいと思います。カスタム投稿タイプの追加/編集フォームにグリッドを用意しました。テキストボックスを追加または編集できるようにします。スクリーンショットはこちらhttp://i.stack.imgur.com/ZGqGI.png

簡単に実行してforeach ($meta_box['fields'] as $field)、それぞれのテキストボックスをエコーアウトできますが、これは各フィールド用であり、グループ(DocName1やDocUrl1など)ではありませんDocName1 - DocUrl1が、同じグリッド線上に配置する必要があります。これを行う方法はありますか?これを行うための効率的な方法に頭を悩ませることはできません。

私が今それをしている方法はそうです:

foreach ($meta_box['fields'] as $field) {
    // get current post meta data
    $meta = get_post_meta($post->ID, $field['id'], true);
    echo '<tr>',
           '<th style="width:20%"><label for="', $field['id'], '">',  $field['name'], '</label></th>',
               '<td>';
    echo '<input type="text" name="', $field['id'], '" id="', $field['id'], '" value="', $meta ? $meta : $field['std'], '" size="30"                    style="width:97%" />', '<br />', $field['desc'];
    echo '</td>',
        '</tr>';
}

しかしもちろん、このエコーは各フィールドの独自の行に出力されます。最初のグリッドラインにDocName1とDocUrl1があり、2番目のグリッドラインにDocName2とDocUrl2があるグリッドが必要です。

これが紛らわしい場合は申し訳ありません。

4

1 に答える 1

0

私はこれに自分で答えたと思います!

次のように、showmetabox関数でforループを作成しました。

//Show Meta Fields
function products_show_meta() {
global $meta_box, $post, $prefix;

// Use nonce for verification
echo '<input type="hidden" name="products_meta_box_nonce" value="', wp_create_nonce(basename(__FILE__)), '" />';

echo '<table class="widefat">',
        '<thead>',
            '<tr>',
                '<th style="width:30%">Document Name</th>',
                '<th>Document URL</th>',
            '</tr>',
        '<thead>',
        '<tfoot>',
            '<tr>',
                '<th>Document Name</th>',
                '<th>Document URL</th>',
            '</tr>',
        '<tfoot>';

echo    '<tbody>';

    for ($i=1; $i <= count($meta_box["fields"])/2; $i++) { 
        $current_docName = $prefix . 'docname' . $i;
        $current_docUrl = $prefix . 'docurl' . $i;
        $meta_docName = get_post_meta($post->ID, $current_docName, true);
        $meta_docUrl = get_post_meta($post->ID, $current_docUrl, true);

        echo '<tr>',
                '<td>',
                    '<input type="text" name="', $current_docName, '" id="', $current_docName, '" value="', $meta_DocName ? $meta_DocName                           : '', '" size="30" style="width:99%" />',
                '</td>',
                '<td>',
                    '<input type="text" name="', $current_docUrl, '" id="', $current_docUrl, '" value="', $meta_DocUrl ? $meta_DocUrl :                             'http://', '" size="30" style="width:99%" />',
                '</td>',
            '</tr>';             
    }

echo    '</tbody>',
    '</table>';

まず、テーブルのヘッダーとフッターをエコーアウトして、各列に適切な名前を付けます。次にfor、1から始まり、フィールドの数をカウントするループを実行します(2で割る必要があります。そうしないと、行が2倍になります)。次に、各フィールドを取得して、行をエコーアウトします。これは以下のコードがレンダリングするものです:http://i.stack.imgur.com/NPu66.png それは機能していて、データを完全に保存しています!

于 2011-05-03T04:57:25.470 に答える