jQuery Datepicker不会覆盖动态创建的输入中的值,需要刷新页面

时间:2018-12-03 16:19:44

标签: javascript jquery dynamic datepicker

  

EDIT1:
  所以我设法解决了这个问题。但是我不确定如何。   我一直在使用两种具有不同ID的完全相同的表单   原因(添加和编辑表单)。在那些表格中,我输入了带有ID的信息。   但是对于这两种形式,我一直在使用相同的ID作为输入。   因此,我将这些ID更改为类(应该如何)。我认为这是   错误的原因。   我更改的第二件事是删除   我先点击第二个表单(编辑   表单/按钮),因为这很麻烦,我没有遇到麻烦   在这里,我认为这与我无关   最初的问题。只要写我在任何情况下所做的一切。

我在使用jQuery Datepicker和Timepicker时遇到问题。我会尝试描述我的情况。
我已经为本地存储值动态创建了html(用它自己的数据想象正方形。)

我的问题...如果我只是简单地加载这些正方形,并且想通过单击“编辑”按钮来更改某些内容,它将通过单击其中一个输入(即日历)来创建一个其中包含预写值的表单出现。然后,在单击某个日期后,预写的值将随着我单击的日期的值而更改。时间选择器也一样。但!有一个问题。

如果我想用新数据创建新方块(通过使用输入动态创建表单,则将数据保存到本地存储中),然后(无需刷新页面)单击“编辑”按钮,并带来相同的旧表单(如前所述)上方),然后单击某些输入,日历就会显示出来,但单击某个日期后,输入的值不会改变。与Timepicker相同,不会覆盖pre-witten值。

但是,如果我刷新页面并要编辑某些内容(而不创建新的正方形/数据),则Datepicker可以毫无问题地更改值。

能帮我吗?如果需要,我将尝试回答任何问题。

此处是一项功能,可显示保存在本地存储中的所有内容。

function fetchBookmarks() {
var bookmarks = JSON.parse(localStorage.getItem("bookmarks"));
bookmarks.sort(function compare(a, b) {
    var dateA = new Date(a.date);
    var dateB = new Date(b.date);
    return dateB - dateA;
  });

var results = document.getElementById("results");
results.innerHTML = "";
for (var i = 0; i < bookmarks.length; i++) {
    var date = bookmarks[i].date;
    var distance = bookmarks[i].distance;
    var time = bookmarks[i].time;

    results.innerHTML += '<div class="bookmarks shadow p-3 m-2 bg-light rounded">' +
        '<div class="row">' +
        '<div class="col">' +
        '<h3>Date: </h3>' +
        '<h3>Distance: </h3>' +
        '<h3>Time: </h3>' +
        '</h3><input onclick="editBookmarks(\'' + time + '\')" class="btn btn-outline-primary mr-1 btn-lg" id="edit" type="button" value="Edit"><input onclick="deleteBookmarks(\'' + time + '\')" class="btn btn-outline-danger btn-lg" id="deleteBookmarks" type="button" value="Delete">' +
        '</div>' +
        '<div class="col">' +
        '<h3 class="font-weight-bold">' + date + '</h3>' +
        '<h3 class="font-weight-bold">' + distance + '</h3>' +
        '<h3 class="font-weight-bold">' + time + '</h3>'
    '</div>' +
        '</div>' +
        '</div>';
};

};

这是单击编辑按钮后的功能...

function editBookmarks(time) {
var bookmarks = JSON.parse(localStorage.getItem("bookmarks"));
for (var i = 0; i < bookmarks.length; i++) {
    if (bookmarks[i].time == time) {
        $(".bookmarks").hide();
        results.innerHTML += '<form class="bookmarks shadow p-3 m-2 bg-light rounded" id="editForm">' +
            '<h4>Date: </h4><input class="form-control form-control-lg" id="date" placeholder="Select" value="' + bookmarks[i].date + '" type=""><br>' +
            '<h4>Distance: </h4><input class="form-control form-control-lg" id="distance" placeholder="In miles" value="' + bookmarks[i].distance + '" type="text"><br>' +
            '<h4>Time: </h4><input class="form-control form-control-lg" id="time" placeholder="Select" value="' + bookmarks[i].time + '" type=""><br>' +
            '<input class="btn btn-success btn-lg" type="submit" value="Submit">' +
            '</form>';

        /* $('#date').datepicker()
        $('#time').timepicker({
            timeFormat: "H:mm",
            hourMin: 0,
            hourMax: 4
        }); */
        bookmarks.splice(i, 1);
    };
};


$("#editForm").on("submit", function (e) {
    var date = $("#date").val();
    var distance = $("#distance").val();
    var time = $("#time").val();

    if (!distance.length || !date.length || !time.length) {
        alert("Something missing!")
    } else {
        var bookmark = {
            date: date,
            distance: distance,
            time: time
        };

        bookmarks.push(bookmark);
        localStorage.setItem("bookmarks", JSON.stringify(bookmarks));

        fetchBookmarks();
        $("#editForm").hide();
    };
    e.preventDefault();
});
$("#search").hide();
};

这是带有时间选择器的Datepicker

$('body').on('focus', "#date", function () {
$(this).datepicker();
});

$('body').on('focus', "#time", function () {
$(this).timepicker({
    timeFormat: "H:mm",
    hourMin: 0,
    hourMax: 4
});
});

我知道这是很多问题,我在表达方面存在问题。我只是迷路了。
感谢您的帮助。

这是GitHub文件的链接,我认为这比在此处发布代码要好。如果您有兴趣,我的整个问题在文件的底部。
https://github.com/ovy1448/MyRun/blob/master/js/main.js
再次感谢。

2 个答案:

答案 0 :(得分:0)

据我了解,由于您使用onfocus事件来附加日期选择器/时间选择器,因此日期选择器/时间选择器的所有事件都未附加到该字段。 2-3年前,我遇到了类似的问题。我所做的是为datepicker onSelect事件添加了一个函数,该函数更新了字段值。您可以尝试使用此方法(如下所示),让我知道它是否有效

$('body').on('focus', "#date", function () {
$(this).datepicker({onSelect: function(dateStr){
  $('body').('#date').val(dateStr);
}});
});

$('body').on('focus', "#time", function () {
$(this).timepicker({
    timeFormat: "H:mm",
    hourMin: 0,
    hourMax: 4,
    onSelect: function(timeStr){
      $('body').('#time').val(timeStr);
    }
});
});

答案 1 :(得分:0)

所以我确实设法解决了这个问题。但是我不确定如何。由于不同的原因,我一直在使用两个具有不同ID的相同表单(添加和编辑表单)。在那些表格中,我输入了带有ID的信息。但是对于这两种形式,我一直在使用相同的ID作为输入。因此,我将这些ID更改为类(应该如何)。我认为这是导致该错误的原因。 我更改的第二件事是立即删除第二个表单(单击编辑表单/按钮),因为这很麻烦,我没有在这里添加麻烦,我也不认为这很麻烦与我最初的问题有关。只要写我在任何情况下所做的一切。