您的位置:首页 > 产品设计 > UI/UE

ueditor插入代码,重新编辑,setContent报错

2014-01-17 13:04 351 查看
做一个博客系统,用了百度富文本编辑器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://stackoverflow.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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  javascript 文本编辑