[技术博客]WEB实现划词右键操作

一、功能解释

简单地对题目中描述的功能进行解释:在浏览器中,通过拖动鼠标选中一个词(或一段文字),右键弹出菜单,且菜单为自定义菜单,而非浏览器本身的菜单。类似的功能有:网页版百度文库中的鼠标选中复制。

二、功能拆解

上述功能较为复杂,便于理解与实现,可以拆分为以下几部分:

  • 获取鼠标划词的内容
  • 实现自定义右键菜单(并为自定义右键菜单中的每个选项绑定合适的行为)
  • 划词与右键菜单的绑定

三、技术实现

(一)获取鼠标划词的内容

简单地搜索之后,了解到这一功能可以通过JavaScript中的Selection来实现。

  • Selection是对当前激活选中区(即高亮文本)进行操作。在非IE浏览器(Firefox、Safari、Chrome、Opera)下可以使用window.getSelection()获得selection对象
  • range是一个fragment,可以理解成一个或多个range组成了一个selection(使用Ctrl键可以进行多选高亮区域),但由于兼容性较差(IE, Chrome均不支持),很少有人使用。
  • 对于获取到的selection对象,可以通过一些JS方法转化为可以处理的对象,常用的方法是通过toString()获得一份selection对象的字符串copy,进行其他操作。
  • 其他的高级用法暂时没有用到,有兴趣的话可以查看官方API这篇博客
  • 在我们的项目中,需要将选中的区域显示在HTML页面中,还要传给后端,概括来说,操作如下:
var rg = window.getSelection(); //获取鼠标选中的区域
document.getElementById("some_html_element").innerText=rg.toString();//将该区域以字符串的形式显示在某个html元素中
$.ajax({//采用ajax提交内容
//其他内容略去
data:JSON.stringify({
"action":"some_action",
"data":{
"name":rg.toString();
}
})
})

当然也不是像上面展示的那么直白,显示在HTML中与传给后端有不同的Trigger。

(二)实现自定义右键菜单

  • 关于自定义右键菜单,JQuery给出了非常实用的API——contextmenu。几乎所有的HTML自定义菜单都是用它来实现的。

下面是JQuery官方API的一个小例子,效果是右键点击p区域的HTML元素,就会出现Hello World!的弹窗。

$("p").contextmenu(function(){
alert("Hello World!");
});

实际上,在contextmenu中,有很多可选的参数,下面以项目中的例子来进行简单介绍。

$.contextMenu({
selector: '.context-menu-one',
// callback: function(key, options) {
// var m = "clicked: " + key + "\n" + rg.toString();
// console.log(m);
// },
items: {
"relation":{
name: "添加关系:",
disabled: true},
"entity1": {
name: "作为实体1",
callback: function(key, options){
document.getElementById("div2").innerText=rg.toString();
e1 = rg.toString();
}},
"entity2": {
name: "作为实体2",
callback: function(key, options){
document.getElementById("div4").innerText=rg.toString();
e2 = rg.toString();
}},
"sep1": "---------",
"添加实体": {
name: "添加实体",
callback: function(key, options){
e = rg.toString();
sendEntityBeta();
location.reload();
}
}
}
});
  • selector指定了应用自定义右键菜单的区域,效果与官方demo中的$("p")相同。值得注意的是,selection必须是一个HTML元素(在页面中实际存在的某一区域),而不是某个JS对象。自定义菜单将作用于整个HTML元素中,替换浏览器原有的右键菜单。
  • callback是该菜单的总回调函数,当选中菜单中的某个选项时,如果该选项没有额外定义回调函数callback,那么将调用总回调函数。
  • items定义了菜单中的各个选项。每个item的基本结构为"item":{},大括号中是该item的描述信息,包括name,disabled等,以及刚刚提到的callback可以每个选项绑定合适的行为。其中值得一提的是,如果令disabled: true,将会禁用该选项,在菜单中,该项显示为灰色且无法点击,可以用此方法来在菜单内设置一些提示信息。
  • 除此之外,items也可以进行嵌套,实现子菜单的功能。(禁止套娃)

除上述参数外,还有许多高级的功能,在官方Plugin中,还有很多一看就懂的有启发性的demo。

(三)划词与右键菜单的绑定

  • 在熟悉了selectioncontextmenu的使用后,上面这个问题也就迎刃而解了,只需要将contextmenu中的selector设置在需要getSelection()的区域即可。
  • 当然要是不了解上面两个工具的话,还是会踩到很多坑的。比如selection的兼容性问题、contextmenu只能作用在HTML元素上等等。

四、总结

  • 没做过是真的不知道,前端没那么好做T_T

[技术博客]WEB实现划词右键操作的更多相关文章

  1. 【技术博客】MySQL和Django常用操作

    MySQL和Django是搭建网站常用的配置之一,在此记录一下在Windows系统搭建网站时MySQL以及Django常用的操作. MySQL MySQL的SQL语句不区分大小写,推荐将保留字大写,数 ...

  2. 【软工】[技术博客] 用Monaco Editor打造接近vscode体验的浏览器IDE

    [技术博客] 用Monaco Editor打造接近vscode体验的浏览器IDE 官方文档与重要参考资料 官方demo 官方API调用样例 Playground 官方API Doc,但其搜索框不支持模 ...

  3. 各大IT公司 技术博客汇总

    来自:http://www.cnblogs.com/IT-Bear/p/3191423.html 腾讯系列(13)  阿里系列(18)  百度系列(3)  搜狐系列(3)  新浪系列(2)  360系 ...

  4. 在Ubuntu14.04上安装WordPress4搭建技术博客

    1.安装LAMP环境 1.1 安装Apache2 1.2 安装MySQL5 1.3 安装PHP5 1.4 安装phpMyAdmin 2.初始化数据库 3.下载并配置WordPress 4.配置Apac ...

  5. 技术人如何利用 github+Jekyll ,搭建一个独立免费的技术博客

    上次有人留言说,技术博客是程序员的标配,但据我所知绝大部分技术同学到现在仍然没有自己的技术博客.原因有很多,有的是懒的写,有的是怕写不好,还有的是一直想憋个大招,幻想做到完美再发出来,结果一直胎死腹中 ...

  6. 【转】【技术博客】Spark性能优化指南——高级篇

    http://mp.weixin.qq.com/s?__biz=MjM5NjQ5MTI5OA==&mid=2651745207&idx=1&sn=3d70d59cede236e ...

  7. [转]有哪些值得关注的技术博客(Java篇)

    有哪些值得关注的技术博客(Java篇)   大部分程序员在自学的道路上不知道走了多少坑,这个视频那个网站搞得自己晕头转向.对我个人来说我平常在学习的过程中喜欢看一些教程式的博客.这些博客的特点: 1. ...

  8. 最值得收藏的java技术博客(Java篇)

    第一个:java_my_life 作者介绍:找不到原作者信息.大概做了翻阅全部是2012年的博客. 博客主要内容:主要内容是关于Java设计模式的一些讲解和学习笔记,在相信对学习设计模式的同学帮助很大 ...

  9. 一文搞定scrapy爬取众多知名技术博客文章保存到本地数据库,包含:cnblog、csdn、51cto、itpub、jobbole、oschina等

    本文旨在通过爬取一系列博客网站技术文章的实践,介绍一下scrapy这个python语言中强大的整站爬虫框架的使用.各位童鞋可不要用来干坏事哦,这些技术博客平台也是为了让我们大家更方便的交流.学习.提高 ...

随机推荐

  1. Spring5(七)——AOP注解

    一.AOP注解 1.介绍 上一节介绍了 AspectJ 框架如何实现 AOP,具体的实现方式是通过 xml 来进行配置的.xml 方式思路清晰,便于理解,但是书写过于麻烦.这一节介绍注解的方式来进行 ...

  2. hadoop集群搭建详细教程

    本文针对hadoop集群的搭建过程给予一个详细的介绍. 参考视频教程:https://www.bilibili.com/video/BV1tz4y127hX?p=1&share_medium= ...

  3. 用java代码遍历excel文件并回显

    今天需要完成282个指标,分析后发现好多都是可复用的字段和方法,生成的dao类也是很多重复的代码,所以写下了简单的自动化遍历excel的test方法, excel业务逻辑如下,用了 HSSFSheet ...

  4. linux停止进程

    $ kill -QUIT 主进程号 例如:kill -QUIT 1708 这种方式相对来说会有一个停止的过程,先将子进程停止掉,然后再停掉主进程. 快速停止Nginx: $ kill -TERM 主进 ...

  5. 『Python』进程同步

    1. Lock(互斥锁) 是可用的最低级的同步指令.Lock处于锁定状态时,不被其他的线程拥有. from multiprocessing import Process, Value, Lock de ...

  6. java基础面试题(一)

    1.java中的数据类型,各占多少个字节? 2.面向对象的特性 1-封装:简单来说,封装就是把数据和操作数据的方法绑定起来,如果需要访问,可以使用已定义的接口进行访问 2-继承:从已有的类得到继承信息 ...

  7. HTML 网页开发、CSS 基础语法——十二.CSS选择器

    选择器 基础选择器:标签选择器,id选择器,类选择器,通配符选择器 高级选择器:后代选择器,交集选择器,并集选择器 1. 标签选择器: • 优点:可以选中所有的同名标签,设置所有同名标签的公共样式. ...

  8. P4457-[BJOI2018]治疗之雨【期望dp,高斯消元】

    正题 题目链接:https://www.luogu.com.cn/problem/P4457 题目大意 开始一个人最大生命值为\(n\),剩余\(hp\)点生命,然后每个时刻如果生命值没有满那么有\( ...

  9. EasyExcel无法用转换器或者注解将java字段写入为excel的数值格式

    需求: 在用easyExcel导出报表时,碰到需要将数据转换为数值or货币格式的需求 过程: 1.首先采取转换器的形式 @Override public CellData convertToExcel ...

  10. k8s负载资源StatefulSet工作解析

    在k8s中工作负载资源StatefulSet用于管理有状态应用. 什么是无状态? 组成一个应用的pod是对等的,它们之前没有关联和依赖关系,不依赖外部存储. 即我们上篇小作文中deployment创建 ...