0

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 は空ですが、その理由が本当にわかりません! post['dates[]'] に対して 'data','dates','data'... も試しましたが、何も機能しませんでした。data は (何らかの理由で?) 選択された日付の配列を含むオブジェクトです。PHP スクリプトからの応答が NULL です。送信パラメータは次のとおりです。dates[]:"12.6.17"

編集: $_POST が私が欲しいものを与えるので、それは CodeIgniter のバグでなければなりません!

4

1 に答える 1

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);

それがあなたを助けることを願っています。

于 2017-01-09T16:56:09.180 に答える