Даты не сохраняются при использовании MVC-Scaffolded Edit [duplicate]

Вопрос был:

Как вернуть ответ от асинхронного вызова?

, который может быть интерпретирован как:

Как сделать синхронный асинхронный код синхронным?

Решение будет состоять в том, чтобы избежать обратных вызовов и использовать комбинацию Promises и async / await.

Я хотел бы привести пример для запроса Ajax.

(Хотя он может быть записан в Javascript, я предпочитаю писать его на Python и компилировать его в Javascript, используя Transcrypt . Это будет достаточно ясно.)

Позволяет сначала включить использование JQuery, чтобы $ был доступен как S:

__pragma__ ('alias', 'S', '$')

Определить функцию, которая возвращает Promise, в этом случае вызов Ajax:

def read(url: str):
    deferred = S.Deferred()
    S.ajax({'type': "POST", 'url': url, 'data': { },
        'success': lambda d: deferred.resolve(d),
        'error': lambda e: deferred.reject(e)
    })
    return deferred.promise()

Использовать асинхронный код, как если бы он был синхронным:

async def readALot():
    try:
        result1 = await read("url_1")
        result2 = await read("url_2")
    except Exception:
        console.warn("Reading a lot failed")

0
задан John Dorean 18 January 2015 в 00:08
поделиться

1 ответ

Для рендеринга браузера datepicker (<input type="date" ..>) с помощью EditorFor() вам нужны следующие атрибуты свойства (обратите внимание, что формат ISO означает, что дата будет отображаться в соответствии с культурой браузера)

[DisplayFormat(DataFormatString = "{0:yyyy-MM-dd}", ApplyFormatInEditMode=true)]
[DataType(DataType.Date)]
public DateTime Date { get; set; }

и в представлении

@Html.EditorFor(m => m.Date)

Обратите внимание, что ввод даты HTML5 не поддерживается в старых браузерах, а вовсе не в FireFox - см. сравнение здесь

5
ответ дан Stephen Muecke 27 August 2018 в 03:08
поделиться
Другие вопросы по тегам:

Похожие вопросы: