2016-04-12 29 views
0

Aynı ada sahip özel alanlar oluşturuyorum, meta alanlara değerlerimi geri yükledim ve bunları modelimde serileştirmek olarak kaydetmek istiyorum.Wordpress'te birden çok meta alan değerinin kaydedilmesiyle ilgili sorun

Bunun gibi

:

Array 
(
    [job] => 'sdfsdf' 
    [image] => Array 
     (
      [attachment_id] => '2121' 
      [url] => 'http://siteurl.com/wp-content/uploads/2016/04/image.jpg' 
     ) 

    [popup_text] => 'A quick brown fox jumps over the lazy dog.' 
) 

Ama değerlerini kaydederken, tüm değerler olarak boş geri yükleme.

Şimdi burada benim meta alanlar kodudur: Gerekli başına

global $wpdb; 

    $dsl_fw_options = get_post_meta($post->ID, 'dsl_fw_options', true); 

    $dsl_staff_qry = $wpdb->get_row("Select * From ". $wpdb->posts . " Where ID = ".$post->ID); 

    $dsl_staff_parent = $wpdb->get_row("Select * From ". $wpdb->posts . " Where post_parent = " . $post->ID . " And post_type = 'attachment' And (post_mime_type = 'image/jpeg' Or post_mime_type = 'image/png')"); 

?> 
    <table width="100%" cellspacing="2" cellpadding="2" border="0"> 
     <tr> 
      <td width="20%"> 
       <strong>Job Title</strong> 
      </td> 
      <td width="80%"> 
       <input type="text" name="dsl_txt_fw_options['job']" value="<?php echo $dsl_fw_options['job'] ?>" style="width: 50%;"> 
      </td> 
     </tr> 
     <tr> 
      <td> 
       <input type="text" name="dsl_txt_fw_options['attachment_id']" value="<?php echo $dsl_staff_parent->ID; ?>" style="width: 50%;"> 
       <br> 
       <input type="text" name="dsl_txt_fw_options['url']" value="<?php echo $dsl_staff_parent->guid; ?>" style="width: 50%;"> 
       <br> 
       <textarea name="dsl_txt_fw_options['popup_text']"><?php echo $dsl_staff_qry->post_content; ?></textarea> 
      </td> 
     </tr> 
    </table> 

DB'den değerleri almak ve mükemmel gösterir.

Ve işte benim güncelleme meta değerler kodudur:

add_action('save_post', 'dr_save_staff_post'); 
function dr_save_staff_post() { 
    global $post; 

    $dsl_arr = array(); 

    $dsl_arr_val = $_POST['dsl_txt_fw_options']; 

    foreach ($dsl_arr_val as $dsl_key => $dsl_val) { 
     $dsl_arr['job'] = $dsl_val->job; 
     $dsl_arr['image'] = array(
           'attachment_id' => $dsl_val->attachment_id, 
           'url' => $dsl_val->url 
          ); 
     $dsl_arr['popup_text'] = $dsl_val->popup_text; 
    } 

    update_post_meta($post->ID, 'fw_options', $dsl_arr); 
} 

Ben bu değerleri kaydetmek ve bana bu sonucu verir DB'den değerleri kontrol ettiğinizde:

a:3:{s:3:"job";N;s:5:"image";a:2:{s:13:"attachment_id";N;s:3:"url";N;}s:10:"popup_text";N;} 

Bilmiyorum yanlış yapıyorum, lütfen bana rehberlik edin.

cevap

0

İlk olarak her giriş türünün adını değiştirin. gibi

<table width="100%" cellspacing="2" cellpadding="2" border="0"> 
     <tr> 
      <td width="20%"> 
       <strong>Job Title</strong> 
      </td> 
      <td width="80%"> 
       <input type="text" name="dsl_txt_fw_job" value="<?php echo $dsl_fw_options['job ?>" style="width: 50%;"> 
      </td> 
     </tr> 
     <tr> 
      <td> 
       <input type="text" name="dsl_txt_fw_attachment_id" value="<?php echo $dsl_staff_parent->ID; ?>" style="width: 50%;"> 
       <br> 
       <input type="text" name="dsl_txt_fw_url" value="<?php echo $dsl_staff_parent->guid; ?>" style="width: 50%;"> 
       <br> 
       <textarea name="dsl_txt_fw_popup_text"><?php echo $dsl_staff_qry->post_content; ?></textarea> 
      </td> 
     </tr> 
    </table> 

O zaman istediğiniz formatta bir diziye bu değerleri dönüştürmek Bundan sonra

$dsl_val_job = $_POST['dsl_txt_fw_job']; 

$dsl_val_attachment_id = $_POST['dsl_txt_fw_attachment_id']; 

$dsl_val_url = $_POST['dsl_txt_fw_url']; 

$dsl_val_popup_text = $_POST['dsl_txt_fw_popup_text']; 

gibi bu değerleri olsun.

$dsl_val['job'] = $dsl_val_job; 

$dsl_val['image'] = array ('attachment_id' => $dsl_val_attachment_id, 

          'url'=> $dsl_val_url); 

$dsl_val['popup_text'] = $dsl_val_popup_text; 

Bu kadar. :-)

+0

Ben soooo aptal ..... Bu nasıl bir hata yapabilir ... thanx çok – deemi

İlgili konular