文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

CodeMirror 基础配置指南

2023-08-31 15:52

关注

CodeMirror 基础配置指南

需求背景

这里为什么会用到在线编辑功能呢?有这样的一个文件管理系统,实时上传js、css、html、shtml、txt等格式文件及文件夹,但是有时候发现上传的文件内容上有不对的地方,如果按传统的下载文件到本地,打开文件编辑保存,再次上传文件到对应路径这样一套操作下来的话会比较麻烦,耽误时间,而如果可以在线编辑有内容问题的文件的话,就可以省去很多步骤,直接在线修改并保存文件就可以了,是不是很方便,于是就产生了在线编辑的需求。

在线编辑

对于文件在线编辑,如果自行通过普通的html元素来加载并编辑的话,操作难度和代码识别度都很差劲,与其说是编辑代码,不如说是编译一堆字母,完全没有任何代码格式可言,这时就考虑到引用在线编辑插件来实现这一功能,通过网上搜索找到了应用的比较广泛比较稳定的CodeMirror在线编辑插件,CodeMirror插件官网地址:https://codemirror.net/

这里我准备了我已经下载好的codemirror的插件包:https://download.csdn.net/download/csdn565973850/87410467,如果你没有积分又不愿意去官网下载的话可以私聊我,我这里给你提供codemirror插件包。

项目引入

这里首先说在线编辑页面,然后再说后台在线编辑处理的逻辑代码,所有代码仅供提供思路,勿要全盘拿过去复用,毕竟不同的代码架构跳转方式会有不同。

列表页面


在线编辑按钮对应的跳转代码

    //在线编辑    function codeonline(fileName){        var title = $("#title").val();        var platform = $("#platform").val();        var url = prefix + "/codeOnline?path="+title+"&name="+fileName+"&platform="+platform;        $.modal.openTab('在线编辑',url);    }

加载页面内容

codeOnline方法下载腾讯云文件并读取文件内容返回到在线编辑页面

        @RequestMapping("/codeOnline")    @RequiresPermissions("project:publishCosFiles:codeOnline")    public String codeOnline(HttpServletRequest request,ModelMap mmap){        //获取存储路径        String path = request.getParameter("path");        mmap.put("path",path);        //获取文件名称        String name = request.getParameter("name");        mmap.put("name",name);        //获取平台        String platform = request.getParameter("platform");        mmap.put("platform",platform);        String text1path = null;        try {            //临时文件存放目录            String profile = ConfigConstant.cosTempPath;            //版本库没有  原始文件地址            String versionkey = path + name;            if (Constants.Platform.COS.getValue().equals(Integer.valueOf(platform))) {                CosClientUtil cosClientUtil = new CosClientUtil();                try {                    //下载到服务器临时目录的文件路径及名称                    text1path = profile + name;                    //开始下载                    cosClientUtil.download(versionkey, text1path);                } catch (InterruptedException e) {                    e.printStackTrace();                }            }else {                text1path = path+ "/"+name;            }            //逐行读取文件内容            BufferedReader reader;            StringBuffer sb = new StringBuffer();            mmap.put("filearea","");            try {                reader = new BufferedReader(new InputStreamReader(                        new FileInputStream(text1path), "utf-8"));                while (reader.ready()) {                    sb.append(reader.readLine()+"\r\n");                }                reader.close();                mmap.put("filearea",sb.toString());            } catch (IOException e) {                e.printStackTrace();            }        }catch (Exception e) {            e.printStackTrace();        }finally {            if (Constants.Platform.COS.getValue().equals(Integer.valueOf(platform))) {                //删除下载的临时文件                if (StringUtils.isNotEmpty(text1path)) {                    boolean delete = new File(text1path).delete();                }            }        }        return prefix + "/codeOnline";    }

在线编辑页面

在线编辑页面样式及js代码如下

                

来源地址:https://blog.csdn.net/csdn565973850/article/details/128938027

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯