получение новой строки внутри объекта json - PullRequest
0 голосов
/ 29 марта 2012

Я пытаюсь перенести набор текстов из базы данных PostgreSQL (тип поля - текст) с помощью ajax на мою веб-страницу. Проблема, которую я предпочитаю, - это новая строка, она прекрасно работает, когда нет новых строк в тексте в базе данных, но когда я использую новые строки в тексте внутри базы данных, json не дает мне данные, которые он хранит.

function selectCalendarEvents(user_id, event_datestart, event_datestop, callback) {
    var request;
    if(window.XMLHttpRequest)
        request = new XMLHttpRequest();
    else
        request = new ActiveXObject("Microsoft.XMLHTTP");

    request.onreadystatechange = function() {
        if (request.readyState == 4 && request.status == 200) {
            if(request.responseText.substr(0, 6) == "error ")
                alert(errorName[request.responseText.substr(6)]);
            else {
                jsonCalendarEvents = $.parseJSON(request.responseText);
                selectEvents(user_id, event_datestart, event_datestop, callback);
            }
        }
    }
    request.open("GET", "php/calendar.php?action=selectCalendarEvents&user_id=" + user_id + "&event_datestart=" + event_datestart + "&event_datestop=" + event_datestop, true);
    request.setRequestHeader("If-Modified-Since", "Sat, 1 Jan 2000 00:00:00 GMT");
    request.send();
}

это моя функция javascript, которая запрашивает набор данных

if($action == "selectCalendarEvents") {
        $user_id = $_GET["user_id"];
        $event_datestart = "'" . $_GET["event_datestart"] . "'";
        $event_datestop = "'" . $_GET["event_datestop"] . "'";

        require_once("connect.php");
        $query = "SELECT event_id, event_name, event_datestart, event_datestop, event_timestart, event_timestop, calendar_events.calendar_group, calendar_color, event_info FROM calendar_events LEFT JOIN calendar_calendars ON calendar_events.calendar_group = calendar_calendars.calendar_group WHERE user_id = " . $user_id . " AND calendar_show = true AND event_datestart <= ". $event_datestop . " AND event_datestop >= " . $event_datestart;
        $result = pg_query($connect, $query);
        if(!$result)
            die("error 1"); // query error

        $comma = '';
        $json = '{"events":[';
        while ($row = pg_fetch_row($result)) {
            $json .= $comma . '{';
            $json .= '"event_id":"' . $row[0] . '",';
            $json .= '"event_name":"' . $row[1] . '",';
            $json .= '"event_datestart":"' . $row[2] . '",';
            $json .= '"event_datestop":"' . $row[3] . '",';
            $json .= '"event_timestart":"' . $row[4] . '",';
            $json .= '"event_timestop":"' . $row[5] . '",';
            $json .= '"calendar_group":"' . $row[6] . '",';
            $json .= '"calendar_color":"' . $row[7] . '",';
            $json .= '"event_info":"' . $row[8] . '"';
            $json .= '}';
            $comma = ',';
        }
        $json .= ']}';

        echo $json;
    }

это мой php, который возвращает набор данных. Если строка [8], то есть event_info, хранит текст с символами новой строки в нем ... когда я пытаюсь заполнить свой календарь событиями, кажется, что json не хранит в нем никаких данных или что-то в этом роде.

1 Ответ

0 голосов
/ 04 апреля 2012

Я обнаружил, что должен заменить \r\n на <br/>, и это будет работать.я использую вот так replace(/\r\n/g, "<br/>") когда я даю строку ответа json

jsonCalendarEvents = $.parseJSON(request.responseText.replace(/\r\n/g, "<br/>"));
...