<? if($_POST) { header('Content-type: text/html; charset=windows-1251'); exit(iconv('utf-8', 'windows-1251', 'Текст в CP1251')); } ?> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <style> </style> <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js"></script> <script> $(function() { $('<iframe/>').appendTo('body').css({width : 600, height : 400}).attr('src', 'about:blank').load(function() { var doc = this.contentWindow.document; $(doc.head).append('<meta http-equiv="Content-Type" content="text/html; charset=windows-1251" />') $.post(location, {a:1}, function(d) { $(doc.body).append('<p>'+d+'</p>') }) }) }); </script> </head> <body> </body> </html> Поместите на свой локальный сервер под любым именем, но сохранив обязательно в utf-8. Локальный сервер также должен либо в этой кодировке по умолчанию работать, либо не должен передавать заголовка кодировки. Запустите - iframe будет отображать строку в 1251, которую ему отдаст сервер, предварив вывод передачей соответствующего заголовка. И как можете убедиться проблем нет. |
Вашу идею кажется понял, надо попробовать прикрутить ее к изначальной задаче.
|
---
|
Цитата:
|
Цитата:
Цитата:
MrBean, вот эти два твоих сообщения противоречат друг другу. Сначала ты хочешь: с другой кодировкой без конвертаций а затем: в оригинальной кодировке без кракозябр Если твоя строка в левой кодировке, то как можно ОДНОВРЕМЕННО обойтись "без конвертаций" и без "без кракозябр"? Или ты думаешь, что обозреватели сети ничего не определяют и не изменяют при отображении? Кто же по твоему это делает? Такое сделать НЕЛЬЗЯ как ты хочешь! Кодировка должна быть известна ОБОЗРЕВАТЕЛЮ СЕТИ при загрузке, либо она должна быть определена после неё. Если второе, то после этого обязательно нужно перевести строку из опознанной кодировки в Unicode (все строки после загрузки отображаются в JavaScript в Unicode) и только потом уже вставляются туда, куда там тебе надо. Именно поэтому у тебя не выходит и никогда не выйдет без преобразования в Unicode записать в IFRAME то, что ты хочешь. Также ты слукавил (или по незнанию) и написал, что: Цитата:
В этом случае эта строка ВСЕГДА будет грузиться исходя ИЗ той кодировки, в которой стоит 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 |
Часовой пояс GMT +3, время: 23:14. |