1

post.phpWordPressページでカスタム フィールドを追加および更新できる簡単なフォームを作成しました。

私が使用した作業コード

テーマfunction.phpの最後にこのコードを追加しました:

define('MY_WORDPRESS_FOLDER',$_SERVER['DOCUMENT_ROOT']);
define('MY_THEME_FOLDER',str_replace('\\','/',dirname(__FILE__)));
define('MY_THEME_PATH','/' . substr(MY_THEME_FOLDER,stripos(MY_THEME_FOLDER,'wp-content')));

add_action('admin_init','my_meta_init');

function my_meta_init()
{
    // review the function reference for parameter details
    // http://codex.wordpress.org/Function_Reference/wp_enqueue_script
    // http://codex.wordpress.org/Function_Reference/wp_enqueue_style

    //wp_enqueue_script('my_meta_js', MY_THEME_PATH . '/custom/meta.js', array('jquery'));
    wp_enqueue_style('my_meta_css', MY_THEME_PATH . '/custom/meta.css');

    // review the function reference for parameter details
    // http://codex.wordpress.org/Function_Reference/add_meta_box

    foreach (array('post','page') as $type) 
    {
        add_meta_box('my_all_meta', 'My Custom Meta Box', 'my_meta_setup', $type, 'normal', 'high');
    }

    add_action('save_post','my_meta_save');
}

function my_meta_setup()
{
    global $post;

    // using an underscore, prevents the meta variable
    // from showing up in the custom fields section
    $meta = get_post_meta($post->ID,'_my_meta',TRUE);

    // instead of writing HTML here, lets do an include
    include(MY_THEME_FOLDER . '/custom/meta.php');

    // create a custom nonce for submit verification later
    echo '<input type="hidden" name="my_meta_noncename" value="' . wp_create_nonce(__FILE__) . '" />';
}

function my_meta_save($post_id) 
{
    // authentication checks

    // make sure data came from our meta box
    if (!wp_verify_nonce($_POST['my_meta_noncename'],__FILE__)) return $post_id;

    // check user permissions
    if ($_POST['post_type'] == 'page') 
    {
        if (!current_user_can('edit_page', $post_id)) return $post_id;
    }
    else 
    {
        if (!current_user_can('edit_post', $post_id)) return $post_id;
    }

    // authentication passed, save data

    // var types
    // single: _my_meta[var]
    // array: _my_meta[var][]
    // grouped array: _my_meta[var_group][0][var_1], _my_meta[var_group][0][var_2]

    $current_data = get_post_meta($post_id, '_my_meta', TRUE);  

    $new_data = $_POST['_my_meta'];

    my_meta_clean($new_data);

    if ($current_data) 
    {
        if (is_null($new_data)) delete_post_meta($post_id,'_my_meta');
        else update_post_meta($post_id,'_my_meta',$new_data);
    }
    elseif (!is_null($new_data))
    {
        add_post_meta($post_id,'_my_meta',$new_data,TRUE);
    }

    return $post_id;
}

function my_meta_clean(&$arr)
{
    if (is_array($arr))
    {
        foreach ($arr as $i => $v)
        {
            if (is_array($arr[$i])) 
            {
                my_meta_clean($arr[$i]);

                if (!count($arr[$i])) 
                {
                    unset($arr[$i]);
                }
            }
            else 
            {
                if (trim($arr[$i]) == '') 
                {
                    unset($arr[$i]);
                }
            }
        }

        if (!count($arr)) 
        {
            $arr = NULL;
        }
    }
}

次に、テーマ フォルダー内に「custom」という名前のフォルダーを作成し、そこにこの 2 つのファイルを保存しました: meta.php と meta.css

meta.phpは次のようになります。

<div class="my_meta_control">

    <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras orci lorem, bibendum in pharetra ac, luctus ut mauris. Phasellus dapibus elit et justo malesuada eget <code>functions.php</code>.</p>

    <label>Name</label>

    <p>
        <input type="text" name="_my_meta[link]" value="<?php if(!empty($meta['link'])) echo $meta['link']; ?>"/>
        <span>Enter in a name</span>
    </p>

    <label>Description <span>(optional)</span></label>

    <p>
        <textarea name="_my_meta[description]" rows="3"><?php if(!empty($meta['description'])) echo $meta['description']; ?></textarea>
        <span>Enter in a description</span>
    </p>

</div>

meta.cssは次のようになります。

.my_meta_control .description { display:none; }

.my_meta_control label { display:block; font-weight:bold; margin:6px; margin-bottom:0; margin-top:12px; }

.my_meta_control label span { display:inline; font-weight:normal; }

.my_meta_control span { color:#999; display:block; }

.my_meta_control textarea, .my_meta_control input[type='text'] { margin-bottom:3px; width:99%; }

.my_meta_control h4 { color:#999; font-size:1em; margin:15px 6px; text-transform:uppercase; }

上記のコードを使用すると、次の結果が得られます。

ここに画像の説明を入力

これで、ここで名前と説明のカスタム フィールドを追加および更新できるようになりまし

それが私が望んでいたことですが、問題は次のとおりです。

このボックスは次の「名前」と「説明」を使用しますが、これ_my_metaは必要ありません。以前、公開したすべての投稿にカスタム フィールドの値を次のように保存しました: phone, home_city, home_country, name++

私の質問は 、このコードを変更して、この新しいを使用する代わりに、既に保存されているカスタム フィールドを使用するにはどうすればよい_my_metaですか? 前述のように、私のカスタム フィールド名は次のとおりです: phone, home_city, home_country, name++

4

1 に答える 1