做一个博客系统,用了百度富文本编辑器ueditor。但是插入代码后,待我重新编辑,调用ue的setContent时,出现错误。我的代码如下:
其中$articleContent是从数据库中得到的内容,值为:<pre class="brush:cpp;toolbar:false;">#include <stdio.h>
int main(){
printf("hello world!");
return 0;
}</pre>
注意,里面的换行就是换行\r\n的文本表示,这样前台的代码就被解释成如下:
而我们知道,js换行,默认是一个新的语句开始,上述代码的第一行initialContent的赋值是一个字符串,但是只有一个左单引号,所以js报错。
那么我们该如何解决呢?有人给我提议:现在后台代码用json_encode编码,再在前台用$.parseJson解码。这似乎能够解决问题,但是在parseJson解析时,却出现了很多问题,如:未定义的变量等。
后面找了很多资料,http://*.com/questions/16836816/is-json-parse-necessary让我突然有了想法,他说:JSON is a strict subset of JavaScript, so what you‘re really doing here is generating JavaScript code. JavaScript doesn‘t "see" a string. 意思是说,JSON其实就是一个严格的js子集,php的代码json_encode输出就是一个json对象,js并不会将他看成一个字符串,而是直接看成了js对象。也就是说,我们在前台根本就不需要对他在进行解码了。于是,我把代码改成如下
居然成功了,没有报错,并且成功初始化了ue。注意php代码并没有引号包住它。
当然,还有一个问题,就是,json_encode把一个换行解析成了\r\n,而ue将\r和\n都解析成了换行,这样,原来只有一个换行的就变成了两个换行了。可以在初始化之前,用字符串替换函数解决这个问题。如:initialContent=initialContent.replace(/\\r\\n/g,‘\\n‘);
原文链接:http://kangry.duapp.com/blog/?type=article&article_id=7