1.深入浅出QuillJS 第二节-Parchment抽象文档
2.html编辑器(html编辑器有哪些)
3.现代富文本编辑器Quill的模块化机制
4.å
¬å¼ç¼è¾å¨çç 究ç°ç¶
5.深入浅出QuillJS 第一节-QuillJS架构介绍
深入浅出QuillJS 第二节-Parchment抽象文档
Parchment是Quill的核心概念,其核心代码不在Quill的源码中,而位于另一个GitHub地址。通过架构图展示Parchment的结构,接下来解析其主要组成部分。
Blot大致分为两类:一类是csgo菠菜源码继承ParentBlot的ContainerBlot、ScrollBlot、BlockBlot和InlineBlot,另一类是继承LeafBlot的EmbedBlot和TextBlot。其中,ContainerBlot作为容器节点,用于包裹其他节点。ContainerBlot不允许单独使用updateContents方法插入,每次插入的是其子节点。ScrollBlot作为文档的根节点,用于外层插入和修改操作。ShadowBlot是所有Blot的核心类,提供大部分公用属性和方法。
介绍几个关键的Blot特性:
ParentBlot用于父节点的管理,可对子节点进行增删改移和查找操作。ContainerBlot作为容器节点,用于包裹其他节点。ScrollBlot作为文档的根节点,用于最外层的插入和修改操作。ParentBlot具有optimize方法,用于自动寻找容器节点,形成嵌套。
讨论Parchment的生命周期:
Create阶段:Blot提供静态create()函数,用于创建DOM节点,swat源码解读并设置初始值。此阶段Blot未实例化,仅返回新创建的DOM Node。
Constructor阶段:通过DOM Node实例化Blot,进行事件绑定、变量初始化等操作。
Build阶段:Blot内部自动调用构建子节点关系的操作,维护在Blot中,Leaf节点无此操作。
Update阶段:Blot发生改变时调用,记录改变并保存。Leaf节点无此操作。
Optimize阶段:Blot发生任何变动时调用,用于最后校验或限定操作,如表格插入数据后计算格子大小或更新完成后实时保存数据。该方法适合降低document复杂度。
总结:下一节将深入探讨Quill中的另一个重要概念——delta,包括delta的常用基本操作、如何实现嵌套、Quill解析delta的过程以及delta与HTML的互转等。
html编辑器(html编辑器有哪些)
常用的HTML编辑器有哪些?最好用的又有哪几个?
1、软件有Dreamweaver、Frontpage、Frontpage、eclipse、UltraEdit。
2、w3schools:w3schools是板块涨跌 源码一个免费的在线编程学习网站,它提供了很多关于HTML、CSS、JavaScript、SQL、PHP、Python、jQuery等的入门教程和参考手册,非常适合初学者学习。
3、我推荐3个代码编辑器吧:EditPlus小巧、稳定、几乎支持所有编程语言的颜色区别(因为它能安装特定代码语言的插件),由于没有代码输入提示,比较适合高手使用。
4、Notepadnotepad(记事本)是代码编辑器或WINDOWS中的小程序,用于文本编辑,在文字编辑方面与Windows写字板功能相当。是一款开源、小巧、免费的纯文本编辑器。
HTML富文本编辑器Quill的使用quill取消了getHtml()的API,getContents()返回的是Delta对象,一种JSON数组,getText()返回文本域里对应字符串。
基于以下原因,笔者决定使用Quill来开发团队的编辑器组件:Delta和APIQuill返回json结构的数据,有API操作编辑器内部元素。linux源码语言也可以通过innerHtml获取dom。
刚一开始,我用了项目原本使用的富文本编辑器vue-html5-editor,但发现并不能实现不编辑文字又能改样式,这时的我还没有意识到事情的严重性,以为只是个例,于是我又找了另一款富文本编辑器。
最近工作中需求使用一款富文本编辑器,经过再三比较选择了vue-quill-editor,之所以选择vue-quill-editor,是看上了它的轻量以及外观简洁的优势。
下面推荐几个免费的:HTMLBox跨浏览器、交互性非常好、开源的Jquery富文本编辑器,在MozillaFirefox,InrernetExplorer,Opera,NetscapeandSafari等常用浏览器下测试通过。
可以通过纯文本粘贴功能,将复制的标签转换成纯文本格式,再根据需要添加格式和样式。另外,也可以使用html清理工具,将复制的标签中的不必要的元素和样式进行过滤和清理,保留必要的内容和样式。
html编辑器哪个好用?1、AdobeDreamweaverMicrosoftExpressionWebCoffeeCupHTMLEditor不过,我们同事推荐使用文本编辑器来学习HTML,抓妖 源码比如Notepad(PC)或TextEdit(Mac)。我们相信,使用一款简单的文本编辑器是学习HTML的好方法。
2、HBuilder是当前最快的HTML开发工具,强大的代码助手帮你快速完成开发,最全的语法库和浏览器兼容性数据让浏览器碎片化不再头痛。
3、EditPlus小巧、稳定、几乎支持所有编程语言的颜色区别(因为它能安装特定代码语言的插件),由于没有代码输入提示,比较适合高手使用。
4、通过专用的浏览器来识别,并将这些HTML文件“翻译”成可以识别的信息,即现在所见到的网页。HTML文件的编辑比较简单,使用文本编辑器就可以直接编辑。当然使用dreamweaver等编辑器会更加专业一点,所以推荐使用dreamweaver。
5、代码编辑器有很多种,至于那个是最好用的HTML代码编辑器,每个人的观点不一样,个人认为HBuilder是最好用的HTML编辑器。
HTML怎么样需要什么样的编辑器呀?
新手建议用editplus编写html。最开始学html的话,推荐使用editplus,没有代码补全功能,提高你代码能力,菜单栏有许多组件帮助你开发出一个页面,熟悉了各种标签后推荐使用sublimetext或者vscode。以上就是html的编译器的推荐。
SublimeTextSublimeText是一个跨平台的代码编辑器,同时支持Windows、Linux、MacOSX等操作系统,也是HTML和散文先进的文本编辑器。
第一步,当然是要建立一个新的文本文件(记住,如果你在使用比较复杂的文字处理器,就应该用“纯文本”或“普通文本”来保存),将它命名为“xxxx.html”。
编辑可以使用专业的HTML编辑器来编辑HTMLAdobeDreamweaverMicrosoftExpressionWebCoffeeCupHTMLEditor不过,我们同事推荐使用文本编辑器来学习HTML,比如Notepad(PC)或TextEdit(Mac)。
静态代码扫描工具有哪些1、工具非常多,各个工具通常会以插件的形式嵌入在各种IDE中,本人目前最偏爱cpplint,其实是就一个python脚本,帮助检查是否符合GoogleC++Style的标准规范。
2、都是用MicroFocus的Fortify来做代码扫描的,用这个软件扫描出来的结果比较准确,而且操作简单。都是用MicroFocus的Fortify来做代码扫描的,用这个软件扫描出来的结果比较准确,而且操作简单。
3、tree.modifiers().firstToken().trivias()上面的可以获取注释的一个集合,遍历这个集合,如果不为null就说明代码有注释。集合中的对象调用comment方法可获取到注释内容,然后既可以哦安短注释是否是不是有效的。
4、据行内客户推荐,端玛科技和都有类似这方面的工具,端玛科技专门做应用安全咨询的,有自己的源代码扫描工具,在安全方面,有很产品,包含代码扫描。
现代富文本编辑器Quill的模块化机制
现代富文本编辑器Quill的模块化机制
Quill是一款API驱动、支持格式和模块定制的开源Web富文本编辑器,广泛应用于Web开发中。通过阅读本文,你将深入了解Quill的模块化机制,如何使用它来扩展编辑器的能力,以及如何创建和配置自定义模块。
本文基于DevUI的富文本编辑器开发实践和Quill源码写成,通过具体实例带你了解Quill模块的基本概念和使用方法。
首先,让我们从了解Quill模块开始。Quill模块实质上是一个普通的JavaScript类,具有构造函数、成员变量和方法。通过配置模块,你能够扩展编辑器的功能,实现所需功能。
Quill模块的配置方式主要通过`modules`参数完成,如工具栏模块的配置示例:
toolbar: [
['bold', 'italic', 'underline', 'strike'],
[{ 'list': 'ordered' }, { 'list': 'bullet' }],
[{ 'header': [1, 2, 3, 4, 5, 6] }],
[{ 'color': [] }, { 'background': [] }],
[{ 'align': [] }],
[{ 'script': 'sub'}, { 'script': 'super' }],
[{ 'indent': '-1'}, { 'indent': '+1' }],
[{ 'direction': 'rtl' }],
[{ 'size': [] }],
[{ 'font': [] }],
[{ 'hiliteColor': [] }],
[{ 'link': [] }],
[{ 'clean': [] }]
]
通过配置工具栏模块,你能够创建一个包含4个工具栏按钮的编辑器。
Quill模块是一个普通的JS类,其构造函数接收Quill实例和配置参数,允许你对编辑器进行控制和操作。通过工具栏模块的配置,你能够实现编辑器内元素格式的设置,或在编辑器中插入新元素。
Quill内置了多个模块,包括Clipboard、History、Keyboard等,为编辑器提供了基本功能。此外,还有一系列实用模块,如Syntax用于代码语法高亮。
Quill模块配置示例,以键盘事件模块为例:
keyboard: {
shortcuts: {
'Ctrl+S': 'insert/image',
'Ctrl+Shift+S': 'toggle-styles'
}
}
通过配置键盘事件模块,你能够为编辑器添加自定义快捷键。
创建自定义模块是Quill的强大功能之一。以Counter模块为例,用于统计编辑器当前字数。自定义模块的创建分为三步:创建模块类、配置模块参数和注册模块。
通过Quill的API,你能够实现统计功能,如实时更新字数信息,提供更丰富的编辑器体验。
Quill的模块加载机制通过其初始化过程实现。在初始化编辑器时,Quill会加载并配置内置模块和自定义模块。以工具栏模块为例,Quill通过遍历`modules`参数中的配置项,执行相应的模块初始化和配置工作,最终将模块加载并渲染到编辑器中。
本文通过具体的例子和解析Quill源码,深入探讨了Quill模块的基本概念、配置方法和模块加载机制。通过理解这些机制,你将能够灵活地使用Quill扩展编辑器功能,满足不同场景的需求。
加入DevUI团队,与我们一起打造优雅高效的人机设计/研发体系。欢迎联系招聘邮箱:muyang2@huawei.com。
å ¬å¼ç¼è¾å¨çç 究ç°ç¶
éçäºèç½çè¿ éåå±ï¼éè¿ç½ç»è·åãåå¸åå ±äº«ä¿¡æ¯èµæºå·²æ为人们工ä½ãå¦ä¹ ãç 究å交æµçåºæ¬æ段ãæ°å¦æ¯ç§å¦ææ¯çåºæ¬è¯è¨ï¼å è对äºæè²åç§ç é¢åæ¥è¯´ï¼è§£å³åºäºç½é¡µçæ°å¦å ¬å¼ç¼è¾é®é¢æ¾å¾æ´ä¸ºè¿«åãäºå®ä¸ï¼å®ä¸ç´ä»¥æ¥é½æ¯äººä»¬è´å解å³çé大é®é¢ï¼åå½åè¡ä¹å åç»åºäºä¸äºææ¯è§£å³æ¹æ¡ï¼ç»¼åèµ·æ¥ï¼å¯ä»¥å为ä¸å¤§ç±»ï¼ç¬¬ä¸ç±»æ¯åºäºå¾çæ¾ç¤ºï¼ç¬¬äºç±»æ¯åºäºæ°å¦å ¬å¼æ è®°è¯è¨MathML (Mathematical Markup Language)æ¥æ è®°æ°å¦å ¬å¼ï¼ç¬¬ä¸ç±»æ¯åºäºHTMLè¯è¨ç¼è¾åæ¾ç¤ºãåºäºå¾çæ¾ç¤º
第ä¸ç±»æ¹å¼åå为æ®ééæå¾çæ¾ç¤ºåå¨æçæå¾çæ¾ç¤ºä¸¤ç§ï¼åè æ¯ç´æ¥å©ç¨æäºè½¯ä»¶ï¼å¦Wordçï¼å¶ä½æ°å¦å ¬å¼å¾çä¸ä¼ å°ç½ç»æå¡å¨ï¼è¿ç§æ¹æ³ç主è¦ç¼ºé·æ¯å ç¨ç½ç»èµæºè¾å¤§ï¼ä¸å ¬å¼æ°æ®æ æ³éç¨ï¼åè æ¯æå¡å¨æ¥æ¶å°å ¬å¼å¤æ³¨ä¿¡æ¯ååå¨æçæå¾çåéè³ç½ç»ç»ç«¯ï¼ä½å ¶ä¸çå ¬å¼å¤æ³¨ä¿¡æ¯éè¦éè¿æ·±å ¥å¦ä¹ æè½ç解å使ç¨ï¼å¯¹äºç½ç»äº¤äºä½¿ç¨ååä¸ä¾¿ï¼å ¶å ç¨ç½ç»æå¡å¨åç½ç»ä¼ è¾èµæºè¾å¤§ï¼ä¸è½éåºå¤§å¹¶åæ°çç½ç»äº¤äºåºç¨ãæ¤å¤ï¼ä½¿ç¨å¾çè¿ä¼å¸¦æ¥å¦ä¸äºé®é¢ï¼å¦é«è´¨éçå¾çè½ç¶æå°æ¯è¾æ¸ æ°ï¼ä½æ¯ä¼å½±åå°ç½ç»ä¼ è¾ï¼èä½è´¨éçå¾çæ¾ç¤ºåæå°é½ä¸æ¸ æ°ã
åºäºæ°å¦å ¬å¼æ è®°è¯è¨
第äºç±»æ¹å¼åéè¦å¨æ¯æMathMLçæµè§å¨ä¸æå¯ä»¥æ¾ç¤ºï¼ä½å å¸åºä¸»æµçIEæµè§å¨çé½ä¸æ¯æMathMLãä»å½é äºèç½åä¼ï¼W3Cï¼ç½ç«æ¶å½çæ åµæ¥çï¼å®ç°å¨ä¸»æµçIEæµè§å¨ä¸æ¾ç¤ºåç¼è¾æ°å¦å ¬å¼çæ¹æ¡ï¼æ ä¸ä¾å¤å°éè¦å®è£ é¢å¤ç软件ææ件ã
åºäºHTMLè¯è¨
ç±äºMathMLéè¦å®è£ æ件ï¼æ以åºç¨å¹¶ä¸å¹¿æ³ãé£ä¹æ éå®è£ æ件çå¨çº¿å ¬å¼ç¼è¾å¨ï¼åºè¿èçãè¿ç±»ç¼è¾å¨ä»¥JMEditor为代表ã
JMEditorï¼JavaScript Math Editorï¼æ¯åºäºCKEditorãjQueryãMathQuillçç»ä»¶å¼åçï¼è½»é级ãå¼æ¾æºä»£ç ãæè§å³æå¾ãæ ä»»ä½æ件çå¨çº¿å ¬å¼ç¼è¾å¨ãCKEditorä¸jQueryåºç¨çåå广æ³ï¼ä¸åè¿å¤ä»ç»ãéè¦æåºçæ¯MathQuillï¼ä½¿ç¨HTML+CSS+JSå®ç°å ¬å¼ç¼è¾çææï¼ä»ædomçåéåæ¥å°äºæè´ã
ç¶èMathQuill并ä¸ååå®ç¾ï¼ä»ä¾æ®LaTeXçè¯æ³å®ç°ï¼ä½ä¸äºè¾å¤æçææå°æªå®ç°ï¼å¦ç©éµçã
深入浅出QuillJS 第一节-QuillJS架构介绍
在寻找一款适合复杂需求的富文本编辑器时,经过比较draftjs和slatejs,QuillJS因其清晰的代码结构和良好的扩展性脱颖而出。虽然初次接触QuillJS时可能遇到如detla和blot等概念的困惑,但通过深入阅读源码,我逐渐理解和掌握。虽然Quill并非完美,但仍不失为一个值得信赖的选择。本文将从源码深度解析QuillJS,包括其架构构成和模块开发,如自定义Module和Blot,React组件的整合,以及子编辑区域的构建。下文将详细介绍Parchment抽象文档模型、Blots的使用和Delta数据结构,以帮助大家避免初期的困扰。敬请期待下一部分的深入讲解。
QuillJS的架构由五个核心组件构成:核心类处理光标和模块管理,emitter用于事件处理;Parchment是Quill自定义的文档模型,由Blot构成,包含文本、块级、内联和嵌入等不同类型的节点;Modules提供了基础模块,如工具栏和剪贴板,可直接使用;Blots负责文档的抽象实现,通过操作Blot而非DOM进行操作;Delta则维护用户操作的json数据,用于回退和保存数据。文章后续将深入探讨Parchment和Blot的生命周期,以及如何跟踪Blot的结构。