利用剪切板JS API优化输入框的粘贴体验 « 张鑫旭

发布时间:2024-11-18 19:56

如何使用笔记本电脑的触控板优化输入体验 #生活技巧# #数码产品使用技巧# #科技资讯与评测#

by zhangxinxu from https://www.zhangxinxu.com/wordpress/?p=8003
本文可全文转载,但需得到原作者书面许可,同时保留原作者和出处,摘要引流则随意。

一、目前现在的体验问题

剪切板粘贴优化缩略图

输入框输入内容我们有时候为了方便,会直接粘贴内容,例如IP,网址,或者陌生人的手机号。但是,有时候我们复制的内容包含冗余信息,或者格式不准确,还需要重新编辑,体验就不好了。

举两个真实案例:

1. 阿里云域名解析,结果粘贴后下面这这样:

粘贴后前面有空格

从网页中复制内容的时候,不小心前面多复制了一个长空格,结果出现了格式报错,我们还需要重新删除前面空格,如果我们粘贴的时候直接过滤前后空格,体验岂不更好!

2. 简历中的手机号码,候选人经常会空格或者短横线进行3-4-4分隔,复制后粘贴,结果也失败了:

简历代码复制

粘贴的手机号码报错

如果直接剪切板中过滤到手机号以外乱七八糟的字符,岂不是少去重新编辑的烦恼,用户体验大大提升,用户一看,我明明复制的是不合法的手机号,粘贴进来进来变成合法11位数字,好神奇,体验好好,对这个产品刮目相看,微博,朋友圈,同事圈大肆宣传,其价值就不可估量了。

二、JS改变剪切板内容

我们可以利用Clipboard API改变剪切板内容,从而提高输入框粘贴信息的交互体验。

大体上,该API浏览器都有所支持,但都是部分支持,不过,本来就是增强体验的东西,就算只有一个浏览器支持,也是可以用起来的。

剪切板API兼容性

一段简易的处理代码
下面这段JavaScript代码实现的是针对输入框的的粘贴处理(IE9+支持)。然后演示了邮箱,手机号剪切板数据的简单过滤处理,其他场景大家可以自行补充。

MIT协议,大家可以随意复制粘贴,只要前面一段版权溯源注释代码保留即可。

[].slice.call(document.querySelectorAll('input, textarea')).forEach(function (ele) { ele.addEventListener('paste', function (event) { var type = this.getAttribute('type') || this.type; var clipboardData = event.clipboardData || window.clipboardData; var paste = ''; if (!clipboardData) { return; } var textSelected = ''; if (window.getSelection) { textSelected = this.value.slice(ele.selectionStart, ele.selectionEnd); } else if (document.selection) { textSelected = document.selection.createRange().text; } if (this.value.trim() == '' || textSelected === this.value) { event.preventDefault(); event.stopPropagation(); paste = clipboardData.getData('text') || ''; if (type != 'password') { paste = paste.trim(); } if (type == 'email') { paste = paste.replace('#', '@'); } else if (type == 'tel') { paste = paste.replace(/^\+86/, ''); if (paste.match(/\d/) && paste.match(/\d/g).length == 11) { paste = paste.replace(/\D/g, ''); } } this.value = paste; } }); });

实现效果如下demo,您可以狠狠地点击这里:输入框粘贴文本优化demo

例如,复制demo页面手机输入框后面的手机号码,然后粘贴到输入框中,会看到中间的短横线自动被过滤了。

手机号复制粘贴自动过滤截图

其它
上面代码对剪切板内容的处理比较简单,就是过滤前后空格,邮箱#替换成@,手机号11位标准格式化。大家可以根据实际需求进行更好的处理,例如,XSS过滤可以直接在剪切板中进行等。

补充于2018-09-30 拖拽输入优化
当我们拖拽文本进入输入框的时候,也可以做类似的优化,效果如下GIF:

手机号拖拽优化

相关JavaScript代码如下:

input.addEventListener('drop', function (event) { var text = event.dataTransfer.getData('text'); if (this.value == '' && text.match(/\d/g) && text.match(/\d/g).length == 11) { event.preventDefault(); input.value = text.replace(/\D/g, ''); input.select(); } });

您可以狠狠地点击这里:优化手机号拖拽输入体验demo

三、临了说说copy与剪切板

基于剪切板JS API可以做的事情不仅仅是粘贴,复制的时候也可以做些事情,例如,我可以在我的网站页面上绑定一个copy事件,当你复制文章内容的时候,自动在剪切板文字后面加上一段版权声明。

代码示意:

document.addEventListener('copy', function (event) { var clipboardData = event.clipboardData || window.clipboardData; if (!clipboardData) { return; } var text = window.getSelection().toString(); if (text) { event.preventDefault(); clipboardData.setData('text/plain', text + '\n\n鑫空间版权所有'); } });

您可以狠狠地点击这里:复制页面文字内容自动携带版本声明demo

复制demo页面任意一段文字,然后粘贴到输入框中,可以看到粘贴内容最后附有“鑫空间版权所有”这样的信息,如下截图:

复制内容自带版权信息

不少技术博客有这样的处理,不过放心,我这边是不会加这个的,代码什么的想复制就复制好了。大家都是靠代码技能吃饭的,可以体会写代码的不易,相信一定会尊重知识劳动成果——保留出处等版权信息的。

白云飘飘,天气甚好,总能唤起年少时候同样天气里的那些美好记忆。

最近把《CSS世界》配套网站迁移到了国内,之前用的是美国的服务器(不用备案),但经常会响应迟钝。因为有论坛,备案还花了不少功夫。顺便升级成https协议了。

做垂直站点也是个不错的路数,可惜精力有限,等以后时机成熟,自己出来搞事情的时候,可以找些人一起弄弄。

算了算了,不再唠叨了,唠叨的话可以写在“生活与创作”专栏中,就这些。

小而美的小知识,希望可以对你的工作有所启发。

感谢阅读!

(本篇完) 是不是学到了很多?可以分享到微信!
有话要说?点击这里。

网址:利用剪切板JS API优化输入框的粘贴体验 « 张鑫旭 https://www.yuejiaxmz.com/news/view/124449

相关内容

巧用两个type=range input实现区域范围选择 « 张鑫旭
内容loading加载后高度变化CSS3 transition体验优化 « 张鑫旭
妙法攻略:渐变虚框及边框滚动动画的纯CSS实现 « 张鑫旭
如何优化网页运行JS脚本性能提高用户体验和加载速度的有效方法
实时沟通利器:沟通工具类API助力高效沟通
select2
免打孔挂钩强力无痕钉粘贴式螺丝厨房浴室防水胶粘免钉贴粘钩钉相框螺丝杆贴片挂件挂架 螺丝贴10个+相框贴10个 16.9元(需用券)
生活中的软件专用的语言开发
剪辑视频怎么快速入手?7个剪辑技巧很实用!
剪辑视频怎么快速入手?7个剪辑技巧很实用

随便看看