`
xiaoboss
  • 浏览: 648155 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

FCKEdior'自动保存'的解决方案

阅读更多

FCKEditor没有自动保存功能但受office操作习惯的影响,人们都希望有自动保存的功能.避免错误关闭,浏览器崩溃,导致自己正编辑的文章丢失.很多产品或网站都实现了这个功能.比如Discuz!等.现在我也实现一个.

我这里使用到了JQuery脚本库,后台使用asp.net.

第一部分:

    // 自动保存时间间隔  
    var AutoSaveTime=90000;  
      
    // 计时器对象  
    var AutoSaveTimer;  
      
    // 设置自动保存状态函数  
    function SetAutoSave() {  
        AutoSaveTimer = setInterval("SaveContent()", AutoSaveTime);  
    }   
      
    $(document).ready(function() {  
        // 启动自动保存  
        SetAutoSave();  
    });   

 这是很简单又很自然的写法.要自动保存,就必须使用定时器,而且要在页面启动后,启动自动保存.

第二部分:

    //获取内容  
    function SaveContent() {  
        //editorClientID 页面上FCKEditor的ID  
        var oEditor = FCKeditorAPI.GetInstance(editorClientID);  
        if (!oEditor.IsDirty()) return;       
      
        //文章内容  
        var content = oEditor.GetXHTML(true);  
      
      
        var articleInfo = {          
            Content: content,          
            Title: $("#ArticleInput1_txtTitle").val()  
        }  
        $.post("/ArticleAutoSave.aspx", articleInfo, function(data) {  
            if (data == "ok") {  
                oEditor.ResetIsDirty();  
            }  
        })  
    }   

 这是自动保存的核心函数:进行页面内容保存的实质操作.总的思路是首先获得编辑器的内容,ajax异步提交到asp.net后台来实现自动保存.

有两个关键点我想说一下.

if (!oEditor.IsDirty()) return;   
  //和
if (data == "ok") {  
     oEditor.ResetIsDirty();  
} 

 1.我们并不是盲目的自动保存,当编辑器内容发生了变化时,我们才自动保存.IsDirty()为true表示编辑器内容发生了变化.

2.我们必须在自动保存成功 ,把重置Dirty状态. ResetIsDirty就是完成此工作的.服务器是否保存成功,我通过asp.net页面输出一个"ok"来标志的.

这里用到了FCKEditor API不熟悉的请参考:《FCKeditor API使用详解

第三部分:

本来应该是asp.net后台处理程序ArticleAutoSave.aspx页面了.这个与特定的业务有关,太简单了.就不写了.

分享到:
评论

相关推荐

    FCKedior文本编辑器(让web 程序拥有如MS Word 这样强大的编辑功)

    FCKeditor是一款开源的Web富文本编辑器,它允许开发者为他们的网站或应用程序添加类似Microsoft Word的强大编辑功能。这个编辑器支持多种编程语言,包括Java(JSP),使得Web开发者可以轻松集成到自己的项目中,提供...

    fckedior 4实现文件上传

    由于fckeditor改为ckeditor后,删除了文件上传功能,文件上传功能改用ckfinder来实现。此包将ckeditor和ckfinder组合起来,用Java语句实现了文件的上传下载功能。并对信息进行了优化,删除了系统中的某些英文展示...

    基于C51单片机Proteu仿真实例及软件源码+文档说明 之-电子琴.zip

    基于C51单片机Proteu仿真实例及软件源码+文档说明 之-电子琴.zip

    #_ssm_144_mysql_在线投票系统wlw_.zip

    均包含代码,文章,部分项目包含ppt

    基于java的智乐健身后台管理系统设计与实现.docx

    基于java的智乐健身后台管理系统设计与实现.docx

    基于java的鲜花销售管理系统设计与实现.docx

    基于java的鲜花销售管理系统设计与实现.docx

    数字孪生技术在智能制造的应用与展望

    内容概要:本文回顾了近年来关于数字孪生(Digital Twin)的概念和技术的发展历程,并详尽介绍了这种技术在未来车间中的潜在应用场景和需克服的难关。数字孪生是一种用于集成物理和虚拟系统的技术手段,它能够在产品设计、智能生产和预防性维护等多个领域发挥作用。 适合人群:研究人员和工程师们希望更好地理解数字孪生的基本理论与具体应用实践。 使用场景及目标:涵盖了从产品的设计、制造过程到服役阶段故障预测的全过程,并探讨了基于DT的具体实施路径。 其他说明:强调了信息物理系统的交互融合是DT成功部署的基础,而建立高准确度的多维虚拟模型、孪生数据驱动和实现动态实时交互将是推进这一前沿概念向前发展的关键。

    java-ssm+vue线上旅行信息管理系统实现源码(项目源码-说明文档)

    管理员能够查看、添加、修改和删除景点分类信息,景点分类管理 用户在系统前台可查看系统信息,包括首页、景点信息、酒店信息以及客房信息等 用户要登录界面可输入用户名、密码,点击登录按钮进行登录系统 项目关键技术 开发工具:IDEA 、Eclipse 编程语言: Java 数据库: MySQL5.7+ 后端技术:ssm 前端技术:Vue 关键技术:springboot、SSM、vue、MYSQL、MAVEN 数据库工具:Navicat、SQLyog

    网络管理是什么 网络管理做什么 网络管理长什么样 1.带机量(支持用户数) 2.端口数 3.吞吐量,并发连接数 4.

    关键字:UTM/企业防火墙/NGFW 功能:vpn,sdwan,无线控制器,ldap,双因子认证,nat/透明,终端控制,av防病毒,ips入侵检测,应用控制,web过滤, FortiGate UTM/NGFW产品 ①端口:8口、16口、24口、48口 ②层数:二层(接入层交换机、傻瓜式交换机)、三层(核心交换机、汇聚交换机) ③是否网管 网管: 非网管(傻瓜式交换机,即插即用) WEB网管(S1720GW系列) 全网管(S1720GFR系列,S2700以上的型号都为全网管) ④速率:百兆、千兆、万兆等 1.带机量(支持用户数) 2.端口数 3.吞吐量,并发连接数 4.功能 功能差异须知 NG-xxxx产品特有功能 TG-xxxx&NG-xxxx共有功能 TG-xxxx产品特有功能 FW:网络接入、安全防护、高可用性、身份认证、系统服务、系统管理 ●应用层DDOS攻击防护 负载均衡:多链路负载均衡与备份、多链路智能选路技术、多算法的服务器负载均衡 ●异常行为分析:内置统计只能算法,智能学习

    让数据库设计变得更简单!立即使用我们的SQLite3数据库设计工具,提升您的开发效率,轻松应对各种数据库管理挑战!

    简化设计,轻松管理 一键设计:快速创建和管理SQLite3数据库,简化数据库设计流程。 高效查询:强大的查询功能,帮助您轻松处理复杂的SQL语句。 功能全面,灵活便捷 可视化界面:直观的图形界面,让您无需编写繁琐的SQL代码,即可完成数据库设计。 数据同步:支持实时数据同步,确保您的数据库始终保持最新状态。 高度兼容,广泛适用 跨平台支持:适用于Windows、Mac和Linux等多种操作系统,满足不同开发环境的需求。 多语言集成:与C、C++等主流编程语言无缝对接,提高开发效率。 安全可靠,稳定运行 数据备份:内置数据备份与恢复功能,保障数据安全。 性能优化:优化数据库结构,提升查询速度和存储效率。

    小程序-滴滴作业.zip

    小程序-滴滴作业.zip 小程序-滴滴作业.zip 小程序-滴滴作业.zip

    地线贴标_复制.ezd

    地线贴标_复制.ezd

    Chrome 开阔绿地草地主题UrosDornik.zip

    Chrome主题-开阔绿地草地主题

    基于java校园兼职平台设计与实现.docx

    基于java校园兼职平台设计与实现.docx

    基于java的旅游管理系统设计与实现.docx

    基于java的旅游管理系统设计与实现.docx

    基于java的技术大健康综合咨询问诊平台的设计与实现.docx

    基于java的技术大健康综合咨询问诊平台的设计与实现.docx

    #_ssm_140_mysql_银发在线教育云平台_.zip

    均包含代码,文章,部分项目包含ppt

    基于SSM+Vue的计算机公共基础课程mooc教学平台的设计和实现.zip(毕设&课设&实训&大作业&竞赛&项目)

    项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。

    基于java的共享客栈管理系统设计与实现.docx

    基于java的共享客栈管理系统设计与实现.docx

    基于java的车库智能管理平台设计与实现.docx

    基于java的车库智能管理平台设计与实现.docx

Global site tag (gtag.js) - Google Analytics