【分享】JS如何为复制的Web文本添加其他信息
看到了两篇关于这题的讨论,简单的记录一下!o(* ̄▽ ̄*)ブ
1. stackoverflow , How to add extra info to copied web text
2. 黑客派,https://hacpai.com/article/1510544423932
第一条使用两种方法对文章进行粘贴追加信息~~~
方法一:
①监听copy事件,然后将隐藏盒子中的信息添加到其中;
②结合window.selection()方法;
③浏览器兼容情况是主流浏览器IE8以上;
④线上demo http://jsfiddle.net/jp6nhmxf/ ;
⑤使用:复制一段文本再粘贴就会出现 pagelink中的内容 。
主要JS code
- function addLink() {
- //Get the selected text and append the extra info
- var selection = window.getSelection(),
- pagelink = '\n\n Read more at: ' + document.location.href,
- copytext = selection + pagelink,
- newdiv = document.createElement('div');
- //hide the newly created container
- newdiv.style.position = 'absolute';
- newdiv.style.left = '-99999px';
- //insert the container, fill it with the extended text, and define the new selection
- document.body.appendChild(newdiv);
- newdiv.innerHTML = copytext;
- selection.selectAllChildren(newdiv);
- window.setTimeout(function () {
- document.body.removeChild(newdiv);
- }, 100);
- }
- document.addEventListener('copy', addLink);
方法二:
①监听copy事件,然后修改剪贴板中的内容,也就是clipboard使用;
②结合window.clipboardData.
setData()方法;
③浏览器兼容情况是IE4以上(换言之只针对于IE);
④线上demo http://jsfiddle.net/m56af0je/ (IE模式下起效);
主要JS code
- function addLink(event) {
- event.preventDefault();
- var pagelink = '\n\n Read more at: ' + document.location.href,
- copytext = window.getSelection() + pagelink;
- if (window.clipboardData) {
- window.clipboardData.setData('Text', copytext);
- }
- }
- document.addEventListener('copy', addLink);
⑤另外疑问点来了,使用clipboard能在其他浏览器(比如谷歌/火狐/safari)中工作吗?
主要JS code
- function addLink(event) {
- event.preventDefault();
- var pagelink = '\n\n Read more at: ' + document.location.href,
- copytext = window.getSelection() + pagelink;
- (event.clipboardData || window.clipboardData).setData('Text', copytext);
- }
- document.addEventListener('copy', addLink);
区别在 window.clipboarddata <--> event.clipboardData
亲测在兼容模式、极速模式、谷歌、火狐、IE等浏览器中均测有效!
第二条使用的方法跟第一条类似~~~
主要JS code
- /**
- * @description 添加版权
- */
- const addCopyright = () => {
- const genCopy = () => {
- return [
- '',
- '',
- '作者:Vanessa',
- '链接 [文章复制添加版权](https://hacpai.com/article/1510544423932) ',
- '来源:黑客派',
- '著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。',
- ]
- }
- $('.content-reset').on('copy', function (event) {
- if (!window.getSelection) {
- return
- }
- let copyString = window.getSelection().toString()
- if (copyString.length < 128) {
- return
- }
- if ('object' === typeof event.originalEvent.clipboardData) {
- event.originalEvent.clipboardData.setData('text/html', copyString + genCopy().join(''))
- event.originalEvent.clipboardData.setData('text/plain', copyString + genCopy().join('\n'))
- event.preventDefault()
- return
- }
- $('body').append(`${copyString}${genCopy().join('')}`)
- window.getSelection().selectAllChildren($('#pipeFixCopy')[0])
- setTimeout(function() {
- $('#pipeFixCopy').remove()
- }, 200)
- })
- }
找一个空白地方复制粘贴测试,~~本人只在极速模式下测通过,其他未测~~
敬请留意~~
~~~抱拳撒花*★,°*:.☆( ̄▽ ̄)/$:*.°★* 。~~~
【分享】JS如何为复制的Web文本添加其他信息的更多相关文章
- JS代码格式化排版工具,web文本编辑器
js格式化代码工具:http://www.cnblogs.com/blodfox777/archive/2008/10/09/1307462.html web文本编辑器 :http://www.div ...
- web文本划线的极简实现
开篇 文本划线是目前逐渐流行的一个功能,不管你是小说阅读网站,还是卖教程的的网站,一般都会有记笔记或者评论的功能,传统的做法都是在文章底部加一个评论区,优点是简单,统一,缺点是不方便对文章的某一段或一 ...
- Slideout.js – 触摸滑出式 Web App 导航菜单
Slideout.js 是为您的移动 Web 应用开发的触摸滑出式的导航菜单.它没有依赖,自由搭配简单的标记,支持原生的滚动,您可以轻松地定制它.它支持不同的 CSS3 转换和过渡.最重要的是,它只是 ...
- Heatmap.js v2.0 – 最强大的 Web 动态热图
Heatmap 是用来呈现一定区域内的统计度量,最常见的网站访问热力图就是以特殊高亮的形式显示访客热衷的页面区域和访客所在的地理区域的图示.Heatmap.js 这个 JavaScript 库可以实现 ...
- js 对象深复制,创建对象和继承
js 对象深复制,创建对象和继承.主要参考高级编程第三版,总结网上部分资料和自己的代码测试心得.每走一小步,就做一个小结. 1.对象/数组深复制 一般的=号传递的都是对象/数组的引用,如在控制台输入 ...
- 通过Web Api 和 Angular.js 构建单页面的web 程序
通过Web Api 和 Angular.js 构建单页面的web 程序 在传统的web 应用程序中,浏览器端通过向服务器端发送请求,然后服务器端根据这个请求发送HTML到浏览器,这个响应将会影响整个的 ...
- 前端分享----JS异步编程+ES6箭头函数
前端分享----JS异步编程+ES6箭头函数 ##概述Javascript语言的执行环境是"单线程"(single thread).所谓"单线程",就是指一次只 ...
- 微信分享JS接口失效说明及解决方案
关键字:微信分享 JS 失效 分享到朋友圈 微信分享JS接口目前已失效,以前可以自定义分享的标题.描述.图片.链接地址在微信6.0.2版本中失效. 官方回复如下: 旧版的获取分享状态及设置分享内容的 ...
- c#调用js,以及js调用C#里的函数, c#自己生成js代码,实现对web的控制
using mshtml;using System;using System.Collections.Generic;using System.Linq;using System.Security.P ...
随机推荐
- XPosed 示例
https://blog.csdn.net/fmc088/article/details/80535894
- -bash: belts.awk: command not found
执行awk命令时,没有问题.可是执行awk脚本时,出现这个问题:-bash: belts.awk: command not found. 既然之前直接执行awk命令没有问题,说明awk已经装了,本身是 ...
- leetcode 1——两数之和
问题描述 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,你不能重复利用这个数组 ...
- Maven Webapp项目web.xml版本记录
web.xml 2.0版本 <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3// ...
- centos 7 rabbitmq 3.7.12 erlang 20.3源码安装
1.下载erlang 官网地址 http://www.erlang.org/download 挑选合适的版本 然后 建议20.3运行命令 wget http://erlang.org/download ...
- Linux命令-cut篇
Cut 命令是常用的 Linux 命令,在这里总结一下平时常用的参数和用法,方便查证. 常用参数: -b:以字节为单位进行分割: -c:以字符为单位进行分割: -d:自定义分割符进行分割,默认为制表符 ...
- 踩坑之路---JWT验证
使用JWT验证客户的携带的token 客户端在请求接口时,需要在request的head中携带一个token令牌 服务器拿到这个token解析获取用户资源,这里的资源是非重要的用户信息 目前我的理解, ...
- 使用Travis CI自动部署博客到github pages和coding pages
每次换系统或换电脑之后重新部署博客总是很苦恼?想像jekyll那样,一次性部署完成后,以后本地不用安装环境直接 git push 就能生成博客?那推荐你应该使用使用 Travis CI了. 这篇文章我 ...
- bzoj2131 免费的馅饼——树状数组优化dp
中文题目,问你最后能最多够得到多少价值的馅饼.因为宽度10^8且个数为10^5.所以不可以用dp[x][y]表示某时间某地点的最大权值. 假设你在x点处接到饼后想去y点接饼.那么需要满足的条件是t[y ...
- Qt对象树
Qt提供了一种机制,能够自动.有效的组织和管理继承自QObject的Qt对象,这种机制就是对象树.子对象动态分配空间不需要释放.