2011-01-25 8 views
0

私はwordpressのテーマオプションパネルで作業しています。私はオプションとして1つ以上のチェックボックスを使い始めるとバグに遭遇しました。Ajaxify WPオプション - jqueryのシリアライズとチェックボックスの使用に関する問題

私のコードはjqueryを使用してすべてのフォームデータをシリアル化し、wpのajax-urlに送信します。私はコールバック関数を追加し、WPはDBにオプションを保存するように設定した関数にデータを送信することを知っています。

ボックスをオンにして、保存しても何の問題もなくなったときに動作します。値は保存されます。しかし、今度はボックスのチェックが1または2のチェックを外して保存をクリックしようとすると、ボックスがチェックされます。 DBの値はまだ 'ON'です。私はこれがb/cだと思うが、jqueryはチェックされていないチェックボックスをシリアル化しないので、update_option配列には渡されない。それらがupdate_option配列にないので、それらのキーの値は、現在DBにあるものと同じままです。したがって、変更はありません。私のテストチェックボックスの3つをすべてオフにすれば、それは正しくアップデートされます。

ですから、適切な値でオプションを更新し、チェックボックスのチェックを外しても問題はありません。

<?php 

add_action('admin_menu', 'test_add_theme_page'); 

function test_add_theme_page() { 
    if (isset($_GET['page']) && $_GET['page'] == basename(__FILE__)) { 

     add_action('admin_head', 'test_theme_page_head'); 
    } 
    add_theme_page(__('Test Admin'), __('Test Admin'), 'edit_themes', basename(__FILE__), 'test_theme_page'); 
} 




function test_theme_page_head() { 
?> 

    <script type="text/javascript"> 
    jQuery(document).ready(function($) { 

     jQuery('form#test_form').submit(function() { 
      var data = jQuery(this).serialize(); 

    alert(data); 

      jQuery.post(ajaxurl, data, function(response) { 
       if(response == 1) { 
        show_message(1); 
        t = setTimeout('fade_message()', 2000); 
       } else { 
        show_message(2); 
        t = setTimeout('fade_message()', 2000); 
       } 
      }); 
      return false; 
     }); 

    }); 

    function show_message(n) { 
     if(n == 1) { 
      jQuery('#saved').html('<div id="message" class="updated fade"><p><strong><?php _e('Options saved.'); ?></strong></p></div>').show(); 
     } else { 
      jQuery('#saved').html('<div id="message" class="error fade"><p><strong><?php _e('Options could not be saved.'); ?></strong></p></div>').show(); 
     } 
    } 

    function fade_message() { 
     jQuery('#saved').fadeOut(1000); 
     clearTimeout(t); 
    } 
    </script> 

<?php 
} 




function test_theme_page() { 
?> 

<div class="wrap"> 

    <h2><?php _e('Test Admin'); ?></h2> 

    <div id="saved"></div> 
    <?php $options = get_option('test_theme'); 

echo "<br>"; 
print_r($options); 
echo"<br>"; 
?> 
    <form action="/" name="test_form" id="test_form"> 
     Text<input type="text" name="test_text" value="<?php echo $options['test_text']; ?>" /><br /> 
     Check1<input type="checkbox" name="test_check1" <?php echo ($options['test_check1'] == 'on') ? 'checked' : ''; ?> /><br /> 
    Check2<input type="checkbox" name="test_check2" <?php echo ($options['test_check2'] == 'on') ? 'checked' : ''; ?> /><br /> 
    Check3<input type="checkbox" name="test_check3" <?php echo ($options['test_check3'] == 'on') ? 'checked' : ''; ?> /><br /> 
     <input type="hidden" name="action" value="test_theme_data_save" /> 
     <input type="hidden" name="security" value="<?php echo wp_create_nonce('test-theme-data'); ?>" /> 
     <input type="submit" value="Submit" /> 
    </form> 

</div> 

<?php 
} 




add_action('wp_ajax_test_theme_data_save', 'test_theme_save_ajax'); 

function test_theme_save_ajax() { 

    check_ajax_referer('test-theme-data', 'security'); 

    $data = $_POST; 
    unset($data['security'], $data['action']); 

    if(!is_array(get_option('test_theme'))) { 
     $options = array(); 
    } else { 
     $options = get_option('test_theme'); 
    } 

    if(!empty($data)) { 
     $diff = array_diff($options, $data); 
     $diff2 = array_diff($data, $options); 
     $diff = array_merge($diff, $diff2); 
    } else { 
     $diff = array(); 
    } 

    if(!empty($diff)) { 
     if(update_option('test_theme', $data)) { 
      die('1'); 
     } else { 
      die('0'); 
     } 
    } else { 
     die('1'); 
    } 
} 

あなたは完全なコードここ http://pastebin.com/BCHwsBi5

答えて

1

は明らかに1以上に複雑なものだったと2.にupdate_optionを更新した場合にTRUEを返し、そこには変更はありませんし、そうでない場合はFALSEを返すことを理解していない見ることができます失敗時に。ここ

が修正test_theme_save_ajaxだ()関数:

function test_theme_save_ajax() { 

    check_ajax_referer('test-theme-data', 'security'); 

    $data = $_POST; 
    unset($data['security'], $data['action']); 

    update_option('test_theme', $data); 
    die('1'); 

} 
関連する問題