ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

基于CodeMirror 10分钟打造一个记事本应用(真的能使用,非demo)

2021-03-04 17:33:21  阅读:284  来源: 互联网

标签:function 10 插件 cm text 代码 editor demo CodeMirror


直接看最终效果

在浏览器里面可以随时调出记事本,而且内容自动保存不怕丢失
在这里插入图片描述

再来看怎么做的

原理其实很简单

  1. 主要使用了codeMirror来做编辑器
  2. 数据保存在本地存储,编辑器内容变化时会自动存储,再次打开时会从本地存储里面读取并恢复
  3. 在标签页直接打开、从工具栏打开记事本,需要安装chrome插件 https://plugin.csdn.net/

最后来看看代码怎么写

1. 创建扩展应用

  1. 从桌面的插件扩展图标进入扩展后台
  2. 点击添加插件,填写名称,选择本地代码后确定即可
  3. 在插件信息页面填写插件描述信息,上传插件图标
    这里的触发词选项需要说明下,可以简单理解为插件的唯一标识,输入这个词后就会调用插件。建议英文+数字
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

2. 添加代码

代码分为html、css、js三部分,和平时写前端代码基本一样。
不过有几点需要说明下:

  1. css、js不要和html混在一块,要不然会报错
  2. jqury、codeMirror已经有内置的了,可以使用相对路径,这样就不用走网络了,具体可以看下面代码

html代码

<html>
  <head>
    <title>记事本</title>
		<script src="/vendor/codemirror/lib/codemirror.min.js"></script>
		<script src="/js/jquery-3.5.1.min.js"></script>
		<link rel="stylesheet" href="/vendor/codemirror/lib/codemirror.css">
		<script src="/vendor/codemirror/keymap/sublime.js"></script>
  </head>
  <body>
		<textarea id="code" name="code" 
							style="width:100%;height:calc(100vh - 50px);background:#f5f5f5;border: 1px solid #f0f0f5"></textarea>
	</body>
</html>

js代码

js代码重点有2部分

重点一:codeMirror编辑器使用

创建codeMirror编辑器并添加change事件监听

editor = CodeMirror.fromTextArea(document.getElementById("code"), {
  		lineNumbers: true,
      	lineWrapping: true,
		extraKeys: {"Ctrl-Q": function(cm){ cm.foldCode(cm.getCursor()); }},
		mode: "markdown",
		keyMap: "sublime",
	});
editor.on("change",function(instance, changeObj){
	textChangeHandler(instance.getValue())
});
重点二:本地存储的使用
var storageKey = 'note_storage'
var value = 'test'
// 写入本地存储
localStorage[storageKey] = value
// 从本地存储读取数据
value = localStorage[storageKey]

完整的js代码如下


var storageKey = 'note_storage'
var editor
var default_text = 
              '1. 每次输入内容后会自动保存的,下次打开内容不会丢失的\n' +
              '2. 内容只保存在本地,插件备份功能不会备份该内容,请不要存储重要信息\n' +
							'3. 编辑器支持sublime快捷键' 
function textChangeHandler(text){
	if(typeof text === undefined || text === null){
		text = ''
	}
	localStorage[storageKey] = text
}

function init(){

	var text = localStorage[storageKey]
	//console.info('get ' + text)
	if(typeof text != undefined && text != null && text != ''){
		editor.setValue(text)
	}else{
		editor.setValue(default_text)
	}
}

(function(){  
	  editor = CodeMirror.fromTextArea(document.getElementById("code"), {
    		lineNumbers: true,
        lineWrapping: true,
				extraKeys: {"Ctrl-Q": function(cm){ cm.foldCode(cm.getCursor()); }},
				mode: "markdown",
				keyMap: "sublime",
			});
	
		init()
	
		editor.on("change",function(instance, changeObj){
			textChangeHandler(instance.getValue())
		});

})()

3. 添加到桌面

  1. 在桌面点击右上角图标进入到添加界面
  2. 选择系统分类,添加记事本即可

在这里插入图片描述

总结

最后总结下,写个真的可以使用的浏览器记事本还是很简单的。当然了这主要还是得益于codeMirror的强大功能。大家都可以来试试吧

标签:function,10,插件,cm,text,代码,editor,demo,CodeMirror
来源: https://blog.csdn.net/weixin_44463441/article/details/114372159

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有