用 js 的 selection range 操作选择区域内容和图片


Posted in Javascript onApril 18, 2017

先放上最后的效果,这是点击图片以前:

用 js 的 selection range 操作选择区域内容和图片

这是点击图片以后:

用 js 的 selection range 操作选择区域内容和图片

非常清晰,一目了然,就算是小白用户也明白发生了什么。挺好的。

最近在做编辑器相关的东西,遇到一个需求,用户在编辑器中插入或者粘贴的图片要支持点击以后,可以按 Backspace 键或者 Delete 键删除掉。

刚开始拿到这个需求的想法是调用编辑器自带的删除图片方法删掉图片,但后来查看源码发现这个方法是编辑器内部方法,并没有暴露出来,于是第一个思路走不通了。

第二个思路是在编辑器的顶层容器里监听 keyup 事件,然后判断是否是两个删除键,如果是就拦截,然后找到当前点击的图片,手动删掉。

实际上这也是行不通的,原因有二。首先,这个删除是没法阻止的,因为事件的监听是在顶层父元素里,这时候阻止其实是阻止掉事件在顶层容器上的效果,而不是在发生元素上的效果。所有涉及到事件冒泡的地方,在父容器上阻止效果都是不能达到目的的,只能在事件最开始发生的元素上阻止。 

然后,当按下删除键的时候,之前点击的图片已经不是点击状态了,已经拿不到了。因为取消选择在前,删除在后。

后来忽然意识到,想要的效果其实就是点击图片的时候选中图片,就像用户自己选中网页中一段内容那样选中那张图片就好了。页面上点击一个图片默认是没有效果的,我要做的仅仅是点击时候选中这个图片就可以了。这样做的好处是,当用户点击图片选中以后,如果点删除键,无论是 Backspace 还是 Delete 键都可以删除;而且如果用户不像删除,直接点击别的地方,或者按下上下左右箭头就可以取消选择,这和用户平时的操作体验是一样的,根本没有什么副作用。

selection 是 HTML5 的新接口,是 window 的一个方法,用法是 window.getSelection().

取得 selection 以后,要把当前图片加入到选取中,selection 有一个 Selection.selectAllChildren() 方法,但这个方法只能选中元素的全部子元素,而我们要选中的是 img 元素自身,img 元素也没有子元素。于是继续在 selection 的方法中看看有没有别的长的像的方法,果然,找到了 Selection.addRange() 看这长相一看就很像我们要找的人。addRange 方法需要传入一个 range 对象,range是啥呢?

平时在页面上选择东西都是鼠标咔一下框一大片,但如果在编辑器里,其实是可以选择好几个片段的,一般按住 Ctrl / Control 键就可以多处选择。我猜这个 selection 就类似于选中的所有区域,range 就类似于每一个单独的选中的片段,先这么理解。

继续往下看,发现 range 有一个 Range.selectNode() 方法,这不正是我要找的人吗?先创建一个 range 对象,let range = document.createRange()  createRange 是 document 的方法,然后讲当前图片插入 range,再把 range 插入 selection 中即可。代码如下:

let checkClickImg = function(e) {
 let target = e.target;
 if (target.nodeName.toLowerCase() === 'img') {
  // 删除之前所有的选区
  window.getSelection().removeAllRanges();
  let selection = window.getSelection();
  let range = document.createRange();
  range.selectNode(target);
  selection.addRange(range);
 }
}

这个实现方法的最大优点在于利用浏览器原生自带的功能,这样就和用户的操作习惯保持一致,不会有任何的突兀。选中的效果很明显,而且选中以后无论是删除,还是取消,都跟之前习惯一致,都很容易,更要的是这些操作不用再写代码了啊,因为是浏览器原生自带的功能。

嗯,算是比较完美了。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
为JavaScript类型增加方法的实现代码(增加功能)
Dec 29 Javascript
JQuery入门——移除绑定事件unbind方法概述及应用
Feb 05 Javascript
JavaScript中读取和保存文件实例
May 08 Javascript
JavaScript中连接操作Oracle数据库实例
Apr 02 Javascript
AngularJs  unit-testing(单元测试)详解
Sep 02 Javascript
Angularjs使用指令做表单校验的方法
Mar 31 Javascript
JavaScript基于replace+正则实现ES6的字符串模版功能
Apr 25 Javascript
Cpage.js给组件绑定事件的实现代码
Aug 31 Javascript
requireJS模块化实现返回顶部功能的方法详解
Oct 16 Javascript
JS实现的图片选择顺序切换和循环切换功能示例【测试可用】
Dec 28 Javascript
Angular单元测试之事件触发的实现
Jan 20 Javascript
js实现无缝轮播图效果
Mar 09 Javascript
jacascript DOM节点——元素节点、属性节点、文本节点
Apr 18 #Javascript
Angularjs根据json文件动态生成路由状态的实现方法
Apr 17 #Javascript
微信小程序实战之轮播图(3)
Apr 17 #Javascript
微信小程序实战之顶部导航栏(选项卡)(1)
Jun 19 #Javascript
微信小程序实战之上拉(分页加载)效果(2)
Apr 17 #Javascript
微信小程序教程系列之新建页面(4)
Apr 17 #Javascript
微信小程序商城项目之淘宝分类入口(2)
Apr 17 #Javascript
You might like
php读取msn上的用户信息类
2008/12/05 PHP
php插入中文到sqlserver 2008里出现乱码的解决办法分享
2012/07/19 PHP
Yii2汉字转拼音类的实例代码
2017/04/18 PHP
PHP Trait功能与用法实例分析
2020/06/03 PHP
从新浪弄下来的全屏广告代码 与使用说明
2007/03/15 Javascript
Javascript中Eval函数的使用说明
2008/10/11 Javascript
jQuery阻止事件冒泡具体实现
2013/10/11 Javascript
js获取浏览器基本信息大全
2014/11/27 Javascript
jquery显示loading图片直到网页加载完成的方法
2015/06/25 Javascript
js html css实现复选框全选与反选
2016/10/09 Javascript
jQuery使用ajax方法解析返回的json数据功能示例
2017/01/10 Javascript
angularjs中使用ng-bind-html和ng-include的实例
2017/04/28 Javascript
node版本管理工具n包使用教程详解
2018/11/09 Javascript
JS实现的贪吃蛇游戏案例详解
2019/05/01 Javascript
vue 使用 canvas 实现手写电子签名
2020/03/06 Javascript
JavaScript装箱及拆箱boxing及unBoxing用法解析
2020/06/15 Javascript
原生js实现购物车
2020/09/23 Javascript
SpringBoot+Vue 前后端合并部署的配置方法
2020/12/30 Vue.js
详解Python中time()方法的使用的教程
2015/05/22 Python
Python实现基于KNN算法的笔迹识别功能详解
2018/07/09 Python
pyqt5 tablewidget 利用线程动态刷新数据的方法
2019/06/17 Python
python设置环境变量的作用和实例
2019/07/09 Python
用Pytorch训练CNN(数据集MNIST,使用GPU的方法)
2019/08/19 Python
python实现字符串和数字拼接
2020/03/02 Python
Python利用Faiss库实现ANN近邻搜索的方法详解
2020/08/03 Python
Python基于Socket实现简易多人聊天室的示例代码
2020/11/29 Python
一款CSS3实现多功能下拉菜单(带分享按)的教程
2014/11/05 HTML / CSS
HTML5页面中尝试调起APP功能
2017/09/12 HTML / CSS
Lenox官网:精美的瓷器&独特的礼品
2017/02/12 全球购物
芭比波朗加拿大官方网站:Bobbi Brown Cosmetics CA
2020/11/05 全球购物
韩语专业职业生涯规划范文:成功之路就在我们脚下
2014/09/11 职场文书
践行党的群众路线心得体会
2014/11/05 职场文书
员工辞退通知书
2015/04/17 职场文书
健康证明
2015/06/19 职场文书
2015年学校总务工作总结
2015/07/20 职场文书
Python 恐龙跑跑小游戏实现流程
2022/02/15 Python