TransformStream теперь поддерживается кроссбраузерно.
Оптимизируйте свои подборки
Сохраняйте и классифицируйте контент в соответствии со своими настройками.
Теперь, когда потоки преобразования поддерживаются в Chrome, Safari и Firefox, они наконец-то готовы к использованию в прайм-тайм!
Праздник: эта веб-функция теперь доступна во всех трех браузерных движках!
API Streams позволяет разбить ресурс, который вы хотите получить, отправить или преобразовать, на небольшие фрагменты, а затем постепенно обрабатывать эти фрагменты. Недавно Firefox 102 начал поддерживать TransformStream
, а это означает, что теперь TransformStream
наконец-то можно использовать во всех браузерах. Потоки преобразования позволяют передавать данные из ReadableStream
в WritableStream
, выполняя преобразование фрагментов, или напрямую использовать преобразованный результат, как показано в следующем примере.
class UpperCaseTransformStream {
constructor () {
return new TransformStream ({
transform ( chunk , controller ) {
controller . enqueue ( chunk . toUpperCase ());
},
});
}
}
button . addEventListener ( 'click ', async () = > {
const response = await fetch ( '/script.js');
const readableStream = response . body
. pipeThrough ( new TextDecoderStream ())
. pipeThrough ( new UpperCaseTransformStream ());
const reader = readableStream . getReader ();
pre . textContent = '';
while ( true ) {
const { done , value } = await reader . read ();
if ( done ) {
break ;
}
pre . textContent += value ;
}
});
Демо
Если не указано иное, контент на этой странице предоставляется по лицензии Creative Commons "С указанием авторства 4.0" , а примеры кода – по лицензии Apache 2.0 . Подробнее об этом написано в правилах сайта . Java – это зарегистрированный товарный знак корпорации Oracle и ее аффилированных лиц.
Последнее обновление: 2022-07-01 UTC.
[{
"type": "thumb-down",
"id": "missingTheInformationINeed",
"label":"Отсутствует нужная мне информация"
},{
"type": "thumb-down",
"id": "tooComplicatedTooManySteps",
"label":"Слишком сложен/слишком много шагов"
},{
"type": "thumb-down",
"id": "outOfDate",
"label":"Устарел"
},{
"type": "thumb-down",
"id": "translationIssue",
"label":"Проблема с переводом текста"
},{
"type": "thumb-down",
"id": "samplesCodeIssue",
"label":"Проблемы образцов/кода"
},{
"type": "thumb-down",
"id": "otherDown",
"label":"Другое"
}]
[{
"type": "thumb-up",
"id": "easyToUnderstand",
"label":"Прост для понимания"
},{
"type": "thumb-up",
"id": "solvedMyProblem",
"label":"Помог мне решить мою проблему"
},{
"type": "thumb-up",
"id": "otherUp",
"label":"Другое"
}]
{"lastModified": "\u041f\u043e\u0441\u043b\u0435\u0434\u043d\u0435\u0435 \u043e\u0431\u043d\u043e\u0432\u043b\u0435\u043d\u0438\u0435: 2022-07-01 UTC."}
[[["Прост для понимания","easyToUnderstand","thumb-up"],["Помог мне решить мою проблему","solvedMyProblem","thumb-up"],["Другое","otherUp","thumb-up"]],[["Отсутствует нужная мне информация","missingTheInformationINeed","thumb-down"],["Слишком сложен/слишком много шагов","tooComplicatedTooManySteps","thumb-down"],["Устарел","outOfDate","thumb-down"],["Проблема с переводом текста","translationIssue","thumb-down"],["Проблемы образцов/кода","samplesCodeIssue","thumb-down"],["Другое","otherDown","thumb-down"]],["Последнее обновление: 2022-07-01 UTC."]]