CKEditor - 内联编辑:浏览器POST不是完整内容

时间:2013-02-12 13:17:35

标签: php javascript ajax ckeditor inline-editing

以下是保存“edit_body”字段的浏览器脚本:

<script>
$(document).ready(function(){
 $("#save_editable").click(function(){
  var edit_body = $("#edit_body").html();
  setTimeout(function(){
   $.ajax({
    url:'http://my-url.com/my_editor.php?id_to_update=123',
    type:'POST',
    data:{edit_body:edit_body},
    success:function(data){
     if(data=='1'){
      alert('Saved');
     }
    }
   });
  },5000);
 });
});
</script>

服务器执行下一步操作:

if(@$_POST["edit_body"]){
 $id_to_update=intval($_GET['id_to_update']);
 $edit_body=iconv('UTF-8', 'windows-1251', html_entity_decode($_POST["edit_body"], ENT_QUOTES, "utf-8"));
 if(mysql_query(sprintf('update my_table set body="%s" where id="%s";',$edit_body,$id_to_update)){
  print '1';
 }
}

问题是: 当“edit_body”包含大量文本时,它会成功保存但不完整内容。 浏览器越弱,保存的文本就越少。 在这种情况下,我已经使用5秒延迟的setTimeout函数。但有时候它没有帮助..

我怎么能告诉浏览器在Ajax发布之前等待处理变量“edit_body”?

1 个答案:

答案 0 :(得分:1)

问题解决使用CKEditor getData()方法获取文档而不是jQuery html()方法:

var edit_body = CKEDITOR.instances["edit_body"].getData();