Новые строки в Javascript и PHP5 - PullRequest
       7

Новые строки в Javascript и PHP5

0 голосов
/ 29 апреля 2009

У меня есть строка CSV, встроенная в документ XML, которая необходима для флеш-диаграммы, использующей XML. Проблема в том, что диаграмма получает настройки из файла HTML через фрагмент JavaScript, например:

<script type="text/javascript">
        // <![CDATA[        
        var so = new SWFObject("/gr/amstock.swf", "line", "100%", "100%", "8", "#FFFFFF");
        //so.addVariable("path", "../amline/");
        so.addVariable("chart_settings", escape('<settings><number_format><thousands_separator></thousands_separator><decimals_separator><![CDATA[.]]></decimals_separator></number_format><number_format><thousands_separator></thousands_separator><decimals_separator><![CDATA[.]]></decimals_separator></number_format><redraw><![CDATA[true]]></redraw><data_sets><data_set did="0"><color><![CDATA[#00688B]]></color><csv><separator><![CDATA[,]]></separator><date_format><![CDATA[MM/DD/YYYY]]></date_format><data><![CDATA[03/29/09,0
03/30/09,0
03/31/09,0
04/01/09,0
04/02/09,0</data><columns>...

Таким образом, очевидно, что переводы строк нарушают JavaScript (который отражается переменной PHP). Есть ли в любом случае удалить новые строки (или, по крайней мере, остановить новые строки, нарушающие JavaScript) и все же получить флэш-диаграмму, чтобы правильно прочитать ее как файл CSV.

Ответы [ 2 ]

3 голосов
/ 29 апреля 2009

Попробуй это. Если это не сработает, у меня есть другая идея.

<?php

// assumes *nix style newlines
echo str_replace( "\n", "\\n", $jsCode );
0 голосов
/ 29 апреля 2009
stringObj.replace("\n","");

где stringObj равно

<script type="text/javascript">
        // <![CDATA[            
        var so = new SWFObject("/gr/amstock.swf", "line", "100%", "100%", "8", "#FFFFFF");
        //so.addVariable("path", "../amline/");
        so.addVariable("chart_settings", escape('<settings><number_format><thousands_separator></thousands_separator><decimals_separator><![CDATA[.]]></decimals_separator></number_format><number_format><thousands_separator></thousands_separator><decimals_separator><![CDATA[.]]></decimals_separator></number_format><redraw><![CDATA[true]]></redraw><data_sets><data_set did="0"><color><![CDATA[#00688B]]></color><csv><separator><![CDATA[,]]></separator><date_format><![CDATA[MM/DD/YYYY]]></date_format><data><![CDATA[03/29/09,0
03/30/09,0
03/31/09,0
04/01/09,0
04/02/09,0</data><columns>...
...