将具有不同名称的输入数组保存到数据库

时间:2013-04-26 18:31:20

标签: php jquery post wordpress-plugin dynamic-variables

这是一个wordpress插件。

所以我有一个隐藏的输入复选框,在创建新项目时创建。可以使用滑动切换(复选框)打开/关闭这些项目。通过打开/关闭某些项目进行测试后,在使用var_dump($_POST)

时,看起来像是在发布数组

即:

array (size=3)
  'new_filter' => string '' (length=0)
  'dp_show_filter_15' => string 'yes' (length=3)
  'dp_show_filter_16' => string 'yes' (length=3) 

但仅当项目设置为yes时,不返回任何内容。

即使转储显示更新的数组,也没有任何值发布到数据库,并且Firebug中的输入值为空。

这是我的PHP代码:

/*------------------------------------------*/
/*    Check if the filter is active or not  */
/*------------------------------------------*/

$settings="select * from wp_dp_settings";
$filters=$wpdb->get_results($settings,ARRAY_A);

/*------------------------------------------*/
/*    We'll use this to save active states  */
/*------------------------------------------*/

if($_POST){
    ${active}=isset($_POST["dp_show_filter_[$i]"]);
    var_dump($_POST);
    $update="UPDATE wp_dp_settings SET active_filter = '".$active."' WHERE id"; 
    //die( $qry );
    $ok=$wpdb->query($update);

    if($ok==0)
    {
        echo mysql_error();
    }
    else
    { 
        header("Location: admin.php?page=profolio_theme");
        /** Just lettin you know that there was a successful save **/
        echo "<div class='updated settings-error' id='setting-error-settings_updated'> 
        <p><strong>Active State Saved.</strong></p></div>";
    }
}


?>
<td><label for="new_filter">Create a New Filter :<span class="tip">Must be one word</span></label></td>
<td><input type="text" name="new_filter" id="new_filter"/></td>
<td>
</tr>
<?php $object = new stdClass(); ?>
<?php foreach( $filters as $key => $value ) {
    ?>
    <tr>
        <td><label for="show_filter">Show <?php echo $object->$key = $value['filter']; ?> Filter</label></td>        
        <td><input type="checkbox" id="show_filter_<?php echo $object->$key = $value['id']; ?>" <?php //if ( $row['active_filter'] === 'yes' ) { ?>checked="checked"<?php //} ?> name="dp_show_filter_<?php echo $object->$key = $value['id']; ?>" value="<?php echo $object->$key = $value['active_filter']; ?>"/><?php echo $object->$key = $value['active_filter']; ?></td>
        <td><a class="button-primary" href="?page=profolio_theme&del=<?php echo $object->$key = $value['id'];?>">Delete</a></td>
    </tr>
    <?php
    $i++;
}
?>

当我将id添加到输入名称时引入了此问题,因为它曾经是name="dp_show_filter"而不是name="dp_show_filter_15"但是这导致所有项目在我引用输入名称时自然更新在我的javascript中。

如果有帮助,你可以看一下:

jQuery(document).ready(function(e) {
    var $ = jQuery.noConflict();

        $i = 0;
        customCheckbox = $('.dp_wrap input[type="checkbox"]');
        values = [];

            return customCheckbox.each(function(i) {

                // the dynamic id
                var id = parseInt(this.id.replace("show_filter_", ""));
                var showFilter = $("#show_filter_" + id);

                // the element
                var el = this;

                // Hide checkbox
                $(this).hide();

                // Replace element
                var rep = $('<a href="#"><span></span></a>').addClass('dp-checkbox').insertAfter(this);

                // default state
                if( $(showFilter[i]).val() === 'yes'){
                        $(showFilter).prop('checked', true);
                        $(rep).removeClass('off').addClass('on');
                    } else {
                        $(showFilter).prop('checked', false);
                        $(rep).removeClass('on').addClass('off');
                    }
                if($(this).is(':checked') ) {
                    $(rep).addClass('on');
                } else {
                    $(rep).addClass('off');
                }

                // Click event
                $(rep).click(function(e) {

                    e.preventDefault();

                    if( $(el).is(':checked') ) {

                        values.push($(showFilter).val('no'), ++$i);

                        $(el).prop('checked', false);
                        $(rep).removeClass('on').addClass('off');
                    } else {

                        values.push($(showFilter).val('yes'), ++$i);

                        $(el).prop('checked', true);
                        $(rep).removeClass('off').addClass('on');
                    }
                });
            });
});

因此,当我打开/关闭项目时,使复选框值为是/否,这些值应该发布到数据库。注意:当我打开/关闭时,我注意到Firebug中的值分别变为是/否,所以我知道我的javascript正在运行。

非常感谢任何和所有帮助,谢谢!

1 个答案:

答案 0 :(得分:0)

1)您使用${active}=isset($_POST["dp_show_filter_[$i]"]);isset()将返回一个布尔值,你无法回应这个,请尝试:

$i=3;
$active=isset($_POST["dp_show_filter_[$i]"]);
var_dump($active);
echo $active;

因此,您的查询中不会打印$ active。

2)${active}不是声明变量使用$active的正确方法。

3)即使设置了$i$_POST["dp_show_filter_[$i]"]也会引用带有密钥dp_show_filter [3]的$ _POST($ i = 3)。你的var_dump显示这应该是dp_show_filter_3

所以尝试类似的事情:

$id = 17;
$active=isset($_POST['dp_show_filter_'.$id]);
var_dump($_POST);
$update="UPDATE wp_dp_settings SET active_filter = '".($active)?'true':'false'."' WHERE id=".$id; 
$ok=$wpdb->query($update);