前端培训-初级阶段-场景实战(2019-05-09)-聊天框-发送框

栏目: Html · 发布时间: 5年前

内容简介:前端最基础的就是 HTML+CSS+Javascript。掌握了这三门技术就算入门,但也仅仅是入门,现在前端开发的定义已经远远不止这些。前端小课堂(HTML/CSS/JS),本着提升技术水平,打牢基础知识的中心思想,我们开课啦(每周四)。初级阶段已经完结,之后会针对之前提到过的内容,对实际场景进行分享。正好前段时间我不是一直在加班做聊天的功能嘛。今天我们就来说一说其中遇到的东西。

前端最基础的就是 HTML+CSS+Javascript。掌握了这三门技术就算入门,但也仅仅是入门,现在前端开发的定义已经远远不止这些。前端小课堂(HTML/CSS/JS),本着提升技术水平,打牢基础知识的中心思想,我们开课啦(每周四)。

初级阶段已经完结,之后会针对之前提到过的内容,对实际场景进行分享。正好前段时间我不是一直在加班做聊天的功能嘛。今天我们就来说一说其中遇到的东西。

我们要讲什么?

  1. contentEditable
  2. Node 与 Element
  3. 插入功能(表情、截图等等)
  4. 粘贴功能
  5. 拖入功能

测试地址-测试下面的特性

关键词 文字 换行 图片
input × ×
textarea ×
contentEditable

contentEditable

你会说这东西我知道,给元素加上就可以编辑内容。老铁,这么简单当然不行了。

  1. 当你按下Enter/Return键在可编辑区域中创建一个新的文本行时,不同主流浏览器对此有不同处理(Firefox 插入
    、IE/Opera将使用<p>、 Chrome/Safari 将使用 <div>)
  2. css 也可以支持同样的功能 -webkit-user-modify ,值有

    1. inherit(继承);
    2. initial(默认);
    3. read-only(只读);
    4. read-write(读写);
    5. read-write-plaintext-only(读写、非富文本);
    6. unset(未设置);当一个属性定义了unset值,如果该属性是默认继承属性,该值等同于inherit,如果该属性是非继承属性,该值等同于initial
  3. 同上 contentEditable 属性支持的也不是逻辑值。plaintext-only 就是其中最亮的仔。
    最早还是在 张鑫旭大佬-小tip: 如何让contenteditable元素只能输入纯文本 哪里看的到的

当然我们用的还是富文本的样式。因为我们里面需要表情

Node 与 Element

Node

Node 是一个接口,许多 DOM API 对象的类型会从这个接口继承。它允许我们使用相似的方式对待这些不同类型的对象;比如, 继承同一组方法,或者用同样的方式测试。

以下接口都从 Node 继承其方法和属性:

Document, Element, Attr, CharacterData (which Text, Comment, and CDATASection inherit), ProcessingInstruction, DocumentFragment, DocumentType, Notation, Entity, EntityReference

----------------- https://developer.mozilla.org...

  1. Node.nodeName
    返回一个包含该节点名字的DOMString。节点的名字的结构和节点类型不同。
    HTMLElement 的名字跟它所关联的标签对应,比如 HTMLAudioElement 对应的是 'audio'
    Text 节点对应 '#text'
    Document 节点对应 '#document'
  2. Node.nodeType

    Name Value status
    ELEMENT_NODE 1
    ATTRIBUTE_NODE 2 warn
    TEXT_NODE 3
    CDATA_SECTION_NODE 4
    ENTITY_REFERENCE_NODE 5 warn
    ENTITY_NODE 6 warn
    PROCESSING_INSTRUCTION_NODE 7
    COMMENT_NODE 8
    DOCUMENT_NODE 9
    DOCUMENT_TYPE_NODE 10
    DOCUMENT_FRAGMENT_NODE 11
    NOTATION_NODE 12 warn

上面两个属于比较重要的

Element

Element是非常通用的基类,所有 Document对象下的对象都继承它. 这个接口描述了所有相同种类的元素所普遍具有的方法和属性。 这些继承自Element并且增加了一些额外功能的接口描述了具体的行为. 例如, HTMLElement 接口是所有HTML元素的基础接口, 而 SVGElement 接口是所有SVG元素的基本接口.大多数功能在类的层次中进一步制定.

Node 与 Element 差别

Node 中是会包含文本节点的。比如Text。

而 Element 包含的都是标签节点。

插入功能

如果换成 DOM 操作,好像功能还蛮简单的 appendChildinsertBeforereplaceChild 好像就基本可以搞定了。但是换到富文本中呢?我们需要解决几个问题

  1. 获取当前焦点位置
  2. 在文本内容中插入内容
  3. 在节点内容中插入内容
  4. 其实还有一点,插入的时候会单击其他位置,导致焦点丢失,所以我们需要记住,然后设置到指定位置。

获取当前的焦点位置

window.getSelection(); 这个可以用来获取焦点位置。

anchorNode 指向用户 开始选择(按下鼠标键) 的地方,而 focusNode 指向用户 结束选择(松开鼠标键) 的地方。

注意不能与选区的起始位置和终止位置混淆,因为开始选择的位置可能在结束选择位置的前面,也可能在结束选择位置的后面,这取于选择文本时鼠标移动的方向(也就是按下鼠标键和松开鼠标键的位置)。

isCollapsed 布尔值,用于判断选区的起始点和终点是否在同一个位置。

//可以用这段代码来观察
setInterval(()=>{
    var selection=window.getSelection();
    console.log(selection)
},1000)

前端培训-初级阶段-场景实战(2019-05-09)-聊天框-发送框

文本内容中插入内容

从上面的内容中,我们可以看到,在文本中是一个 Node 节点,那我应该如何插入节点呢?这其实就是调用 insertData 这个api就好了。但是,怎么能如此简单呢?我们插入的是 DOM 而不是简单的文本,所以这个操作不能用。

前端培训-初级阶段-场景实战(2019-05-09)-聊天框-发送框

这里我们要用的其实是 splitText ,用于在焦点处分割开内容。然后再 after 增加内容。

前端培训-初级阶段-场景实战(2019-05-09)-聊天框-发送框

前端培训-初级阶段-场景实战(2019-05-09)-聊天框-发送框

在节点中插入内容

这个就比较简单了。节点的话,直接加入进去就好了。因为节点不存在说中间插入。但是呢,当你在节点之后的时候,你需要获取其中所有的 nodes 然后根据 offset 找到点。 childNodeschildren 该使用那个呢?这个就涉及到上面说到的 NodeElement 的区别,留个小作业,自己试一下吧。 友情提示,报错的时候记得看是不是 anchorNodeText 节点

前端培训-初级阶段-场景实战(2019-05-09)-聊天框-发送框

记录焦点位置&整合应用

既然点击会失去焦点,那么我们在blur的时候记录。然后给显示回去就OK了。

测试地址 ,其实还有一个效果没处理,那就是选区处理。可以当做一个课后作业。

粘贴功能

这个功能很坑,因为还是富文本。所以粘贴进来的是有样式的。但是我们不需要样式,所以我们要过滤掉所有的标签。但是又因为我们可以复制粘贴图片。所以我们需要过滤出来我们的图片。

方案有两种

  1. 获取文本,图片会变成alt属性标识的值(我用的是这个)
  2. 获取HTML,需要自己去过滤处理。

粘贴进来的内容,我们需要处理 paste 事件。 e.clipboardData 是获取剪贴板对象。提供了 getData 来获取剪贴板内容。比如 getData('text'); 获取文字内容。 getData('text/html'); 获取html格式内容。

tips:

files
e.preventDefault();

拖拽功能

这个功能没实现,感觉上很难,达不到原生的那种感觉,也有可能是我api没找到, 希望会的人告我一下

说一下我能给出的方案,因为不能 setData 所以方案还是考虑阻止默认的

  1. 分开处理,内部拖拽使用系统操作。外部拖拽禁止。
  2. 都使用自己的处理但是拿不到焦点,针对这个问题,可以做到增加提示,然后追加。
  3. 拖拽的话,可以有文件级别的。判断如果是文本文件之类的,可以读取文件内容。

后记

主讲人文章-浏览器科普


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

大数据系统构建

大数据系统构建

Nathan Marz、James Warren / 马延辉、向磊、魏东琦 / 机械工业出版社 / 2017-1 / 79.00

随着社交网络、网络分析和智能型电子商务的兴起,传统的数据库系统显然已无法满足海量数据的管理需求。 作为一种新的处理模式,大数据系统应运而生,它使用多台机器并行工作,能够对海量数据进行存储、处理、分析,进而帮助用户从中提取对优化流程、实现高增长率的有用信息,做更为精准有效的决策。 但不可忽略的是,它也引入了大多数开发者并不熟悉的、困扰传统架构的复杂性问题。 本书将教你充分利用集群硬件优势的La......一起来看看 《大数据系统构建》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具