Показать сообщение отдельно
  #25 (permalink)  
Старый 11.06.2016, 22:37
Аватар для pureJS
Аспирант
Отправить личное сообщение для pureJS Посмотреть профиль Найти все сообщения от pureJS
 
Регистрация: 04.06.2016
Сообщений: 70

Сообщение от MrBean Посмотреть сообщение
Нужен способ именно отобразить строку в документ с другой кодировкой без конвертаций.
Сообщение от MrBean Посмотреть сообщение
Имелось ввиду, может есть способ динамически сформировать содержимое iframe и заставить браузер при этом думать, что в iframe другой документ, чтобы он отобразил его в оригинальной кодировке без кракозябр.

MrBean, вот эти два твоих сообщения противоречат друг другу. Сначала ты хочешь:
с другой кодировкой без конвертаций
а затем:
в оригинальной кодировке без кракозябр

Если твоя строка в левой кодировке, то как можно ОДНОВРЕМЕННО обойтись "без конвертаций" и без "без кракозябр"? Или ты думаешь, что обозреватели сети ничего не определяют и не изменяют при отображении? Кто же по твоему это делает?

Такое сделать НЕЛЬЗЯ как ты хочешь! Кодировка должна быть известна ОБОЗРЕВАТЕЛЮ СЕТИ при загрузке, либо она должна быть определена после неё. Если второе, то после этого обязательно нужно перевести строку из опознанной кодировки в Unicode (все строки после загрузки отображаются в JavaScript в Unicode) и только потом уже вставляются туда, куда там тебе надо.

Именно поэтому у тебя не выходит и никогда не выйдет без преобразования в Unicode записать в IFRAME то, что ты хочешь.

Также ты слукавил (или по незнанию) и написал, что:
Сообщение от MrBean Посмотреть сообщение
В теле страницы есть строка, содержащая страницу в другой заведомо неизвестной кодировке.
...........
var unknown_charset_page = '<!doctype html><html>.........';

В этом случае эта строка ВСЕГДА будет грузиться исходя ИЗ той кодировки, в которой стоит charset документа. Однако мы можем получить такую строку в неверной кодировке, если получим её через неверно загруженный JavaScript или через AJAX.

Вот пример:
<!doctype html>
<html><head>
<meta charset="utf-8">
<style type="text/css">
</style>
<script type="text/javascript" src="string_in_win-1251.js" charset="windows-1251"></script>
<script type="text/javascript">
function showResult()
{
	var showcode=document.getElementById('result').contentDocument.open();
	showcode.write(string_in_win1251);
	showcode.close();
}
</script>
</head><body>
<iframe id="result" frameborder="0" style="border:1px solid gray" src="about:blank"></iframe>
<input type="button" value="Выполнить" onclick="showResult()">
</body></html>

Обрати внимание на то, что если убрать из загружаемого "string_in_win-1251.js" указание charset, то строка string_in_win1251 загрузится неверно и в этом случае нам не обойтись без преобразования в Unicode перед выводом, т.к. вывод будет в таком случае неверным.

Также обрати внимание на то, что в данном случае уже совершенно неважно какую кодировку мы укажем при записи в IFRAME, ибо в это время обозревателю сети это уже не важно - документ загружен.

Содержимое файла "string_in_win-1251.js", который сохранён в windows-1251:
var string_in_win1251 = '<b>Такое сделать НЕЛЬЗЯ как ты хочешь!</b>';

Также про кодировки можно почитать:
https://learn.javascript.ru/string
https://learn.javascript.ru/es-string
Ответить с цитированием