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
其中$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
相关文章推荐
- PHP插入数据库代码,编辑,删除
- UEditor编辑框插入的表格显示页无法显示的问题
- vc++6.0编辑窗口怎么才能插入而不覆盖后面的代码
- 从数据库中提取到ueditor并且重新编辑
- 百度UEditor插入图片尺寸自动适应编辑框大小问题
- PHP插入数据库代码,编辑,删除
- vc++6.0编辑窗口怎么才能插入而不覆盖后面的代码
- PHP插入数据库代码,编辑,删除
- 百度UEditor插入图片尺寸自动适应编辑框大小
- 红-黑树 插入节点的Java代码实现
- ABAP--如何限制REUSE_ALV_GRID_DISPLAY_LVC函数的某行某列的编辑(代码样例)
- 在线编辑代码[django]版本
- 在光标处插入字符串的实现代码兼容IE,Firefox
- 代码高亮插件SyntaxHighlighter 就是在页面中编辑代码
- 嘿嘿,中午给ewebeditor加了一个插入运行代码按钮
- 重构改善既有代码的设计--重新组织函数
- 改变static编辑框字体及颜色参考代码
- 重构改善既有代码设计-----重新组织函数
- [插件]ZenCoding-HTML/CSS代码编辑利器