Вопрос был:
Как вернуть ответ от асинхронного вызова?
blockquote>, который может быть интерпретирован как:
Как сделать синхронный асинхронный код синхронным?
blockquote>Решение будет состоять в том, чтобы избежать обратных вызовов и использовать комбинацию 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")
Запуск XSLT в браузере зависит от некоторых ограничений:
По этим причинам XSLT чаще запускается на сервере или в пакетном режиме, а не в браузере.
Если вы хотите запустить XSLT в браузере и работать с Chrome, Firefox и IE, вы должны
xml-stylesheet
в файле XML, как вы это сделали, чтобы связать файл XSLT с XML-файлом: <?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" href="http://origin-domain/path/to/file.xsl"?>
<rootElement>...</rootElement>
Наконец, убедитесь, что проверьте консоль браузера для любых сообщений об ошибках. Например, вот что показывает IE, когда XSLT не может быть найден:
[/g4]
Поскольку этот ответ связан с другими вопросами, я добавлю обновление: теперь можно запустить таблицы стилей XSLT 3.0 в браузере, используя реализацию Saxon-JS. Это снимает многие ограничения, присущие встроенным XSLT-процессорам, которые поставляются с различными браузерами.