Т.е на стороне сервера сформировать массив из выборки и потом через json_encode передать этот массив клиенту? Или можно обойтись без формирования массива из выборки на стороне сервера и передавать выборку каким-то образом напрямую в массив клиента?
|
У меня через json_encode не передаются русские строки. Это можно решить?
|
Цитата:
rawurlencode iconv |
Спасибо. Дело было действительно в кодировке БД. iconv выручил. В "исходном" тексте после передачи русской строки в JS отсутствовали двойные кавычки. Может быть, есть смысл просто их подставлять без перекодирования?
|
Я внёс бы поправку в код: нельзя забывать про кавычки при implode, это касается строковых значений массива:
<script>var a=['<?=implode("','",$arr)?>'];</script> |
Есть несколько решений, например вот
<?php function json_fix_cyr($json_str) { $cyr_chars = array ( '\u0430' => 'а', '\u0410' => 'А', '\u0431' => 'б', '\u0411' => 'Б', '\u0432' => 'в', '\u0412' => 'В', '\u0433' => 'г', '\u0413' => 'Г', '\u0434' => 'д', '\u0414' => 'Д', '\u0435' => 'е', '\u0415' => 'Е', '\u0451' => 'ё', '\u0401' => 'Ё', '\u0436' => 'ж', '\u0416' => 'Ж', '\u0437' => 'з', '\u0417' => 'З', '\u0438' => 'и', '\u0418' => 'И', '\u0439' => 'й', '\u0419' => 'Й', '\u043a' => 'к', '\u041a' => 'К', '\u043b' => 'л', '\u041b' => 'Л', '\u043c' => 'м', '\u041c' => 'М', '\u043d' => 'н', '\u041d' => 'Н', '\u043e' => 'о', '\u041e' => 'О', '\u043f' => 'п', '\u041f' => 'П', '\u0440' => 'р', '\u0420' => 'Р', '\u0441' => 'с', '\u0421' => 'С', '\u0442' => 'т', '\u0422' => 'Т', '\u0443' => 'у', '\u0423' => 'У', '\u0444' => 'ф', '\u0424' => 'Ф', '\u0445' => 'х', '\u0425' => 'Х', '\u0446' => 'ц', '\u0426' => 'Ц', '\u0447' => 'ч', '\u0427' => 'Ч', '\u0448' => 'ш', '\u0428' => 'Ш', '\u0449' => 'щ', '\u0429' => 'Щ', '\u044a' => 'ъ', '\u042a' => 'Ъ', '\u044b' => 'ы', '\u042b' => 'Ы', '\u044c' => 'ь', '\u042c' => 'Ь', '\u044d' => 'э', '\u042d' => 'Э', '\u044e' => 'ю', '\u042e' => 'Ю', '\u044f' => 'я', '\u042f' => 'Я', '\r' => '', '\n' => '<br />', '\t' => '' ); foreach ($cyr_chars as $cyr_char_key => $cyr_char) { $json_str = str_replace($cyr_char_key, $cyr_char, $json_str); } return $json_str; } echo json_fix_cyr(json_encode(array("собака","кошка"))); // ["собака","кошка"] ?> |
Ъь_,
Господи, это что? А что встроенные возможности PHP вдруг перестали работать? |
Теперь понадобилось вернуть достаточно большой массив обратно из js в php. GET уже не проходит по длине адресной строки. Есть ли способ передать массив целиком, а не поэлементно?
Если этот массив получится вернуть целиком, то хотелось бы засунуть его в SQL запрос в php: SELECT * FROM DB.simple WHERE ind IN ... Можно ли после IN поставить в строке запроса полученный массив, назовем его к примеру $arr? Тогда какова должна быть внутренняя структура такого массива? |
Цитата:
$query = 'SELECT * FROM DB.simple WHERE ind IN (' . implode(",", $arr) . ')'; |
Спасибо. Скорее всего получится работать с SQL и через json_encode. Остается еще вопрос, как передать массив на сервер с помощью POST, желательно без JQuery. Вроде надо использовать JSON в JS, тем более, что JSON поддерживают современные браузеры. Поле, понятно, hidden, но как именно подставить в value массив?
|
Часовой пояс GMT +3, время: 17:10. |