将getDates从Multidatespicker发布到jquery ajax post请求时的空数据

时间:2017-01-09 15:48:25

标签: jquery ajax codeigniter jquery-multidatespicker

HTML:

    <script>
    $(function () {
        var min = new Date(2017, 03, 01);
        var max = new Date(2017, 05, 30);
        $("#datepicker").multiDatesPicker({
            maxPicks: 21, numberOfMonths: [1, 3], dateFormat: 'd.m.y', defaultDate: '1.4.17', minDate: min, maxDate: max, onSelect: function (dateText, inst) {
                $("#save").text("Speichern").removeClass("btn-success").addClass("btn-default")
            }
        });
        $("#datepicker").addClass("center");
    });
</script>
<script>
    function speichern() {
        var url;
        var success;
        var data;
        var error;
        var dataType = "text";
        $("#save").text("Wird gespeichert...");
        success = function (ergebnis) {
            $("#save").text("Gespeichert").removeClass("btn-default").addClass("btn-success");
        };
        url = "saver/save";
        data = {'dates[]': $("#datepicker").multiDatesPicker("getDates")};
        error = function (event, jqXHR, thrownError) {
            alert(thrownError.toLocaleString());
        }
        $.post({url: url, success: success, data: data, error: error, dataType: dataType});
    }
</script><p>
<div id="datepicker"></div></p>
<button id="save" class="btn btn-default" style="float:right;margin-bottom: 10px" onclick="speichern()">Speichern</button>

PHP:

<?php

class saver extends CI_Controller
{
    function save()
    {
        $dates = $this->input->post['dates[]'];
        var_dump($dates);
        echo $dates;
        //echo "erfolgreich gespeichert";
    }
}

$日期是空的,但我真的不知道为什么!还尝试了'数据','日期','数据'...发布['dates []'],但没有任何效果。 data是包含具有所选日期的数组的对象(由于某种原因?)。 PHP脚本的响应为NULL。发送参数例如:dates []:“12.6.17”

编辑:它必须是CodeIgniter Bug,因为$ _POST给了我我想要的东西!

1 个答案:

答案 0 :(得分:0)

在javascript数组中创建为:

var dates = [] OR var dates = new Array();

所以改变你的脚本代码如下:

<script>
    function speichern() {
        var url;
        var success;
        var data;
        var error;
        dates = [];
        dates = $("#datepicker").multiDatesPicker("getDates");
        var dataType = "text";
        $("#save").text("Wird gespeichert...");
        success = function (ergebnis) {
            $("#save").text("Gespeichert").removeClass("btn-default").addClass("btn-success");
        };
        url = "saver/save";
        data = {'dates':dates};
        error = function (event, jqXHR, thrownError) {
            alert(thrownError.toLocaleString());
        }
        $.post({url: url, success: success, data: data, error: error, dataType: dataType});
    }
</script>

在php中:

$date = $this->input->post('dates');
print_r($date);

希望它会对你有所帮助。