分享js粘帖屏幕截图到web页面插件screenshot-paste


Posted in Javascript onAugust 21, 2020

在很多场合下,我们可能有这样的需求:提供个屏幕截图上传到系统,作为一个凭证。传统的操作方式是:屏幕截图,保存文件到本地,在web页面上选择本地文件并上传,这里至少需要三步。有没有可能直接将截图粘帖到web页面上,然后上传?答案是:可以的。这就是本文要介绍的内容了。

由于我的项目有上传屏幕截图这样的需求,为了用户体验更佳,减少操作步骤,我在网上搜了一遍之后,找到了一些眉目。为了便于复用和共享,我又对该功能做了一些封装,于是便有了这个插件 screenshot-paste。运行效果如下图:

分享js粘帖屏幕截图到web页面插件screenshot-paste

插件调用示例:

<html>
<head>
 <title>screenshot paste example</title>
 <meta charset='utf-8'>
</head>
<body>
 <input type="text" id="demo" placeholder="ctrl+v 粘帖到这里"/>
 <div>
 <div id="imgPreview" style="border:1px solid #e0e0e0;margin-top:10px;display:inline;"></div>
 </div> 
 <script type="text/javascript" src="jquery.min.js"></script>
 <script type="text/javascript" src="js/screenshot-paste.js"></script>
 <script type="text/javascript">
 $('#demo').screenshotPaste({
 imgContainer:'#imgPreview'
 });
 </script>
</body>
</html>

插件依赖:

从调用示例中,我们可以看到,这个插件依赖如下:

1)需要引用jquery

2)插件本身screenshot-paste.js

3)需要一个textbox和图片预览div

插件可配置项:

var options = {
 imgContainer: '#imgPreview', //预览图片的容器 
 imgHeight:200 //预览图片的默认高度 
};

插件方法:

该插件目前只有一个方法 getImgData,调用示例如下:

var imgData = $('#demo').screenshotPaste('getImgData');
值得一提的是,该方法返回的是img的src属性里面的内容,即base64编码的图片数据内容。

分享js粘帖屏幕截图到web页面插件screenshot-paste

这样的数据上传到服务器之后,需要用base64解码,解码示例代码如下(C#版):

private string UploadImage(string imageData)
 {
 imageData = imageData.Remove(0, imageData.IndexOf(',') + 1);//字符串中截图base64编码数据

 var bytes = Convert.FromBase64String(imageData);//base64解码
 var url = BLLOrderImg.UploadImg(bytes);//本行及以下代码行的内容可忽略

 return url;
 }

插件源码:

(function ($) {
 $.fn.screenshotPaste=function(options){
 var me = this;

 if(typeof options =='string'){
 var method = $.fn.screenshotPaste.methods[options];

 if (method) {
 return method();
 } else {
 return;
 }
 }

 var defaults = {
 imgContainer: '', //预览图片的容器
 imgHeight:200 //预览图片的默认高度
 };
 
 options = $.extend(defaults,options);

 var imgReader = function( item ){
 var file = item.getAsFile();
 var reader = new FileReader();
 
 reader.readAsDataURL( file );
 reader.onload = function( e ){
 var img = new Image();

 img.src = e.target.result;

 $(img).css({ height: options.imgHeight });
 $(document).find(options.imgContainer)
 .html('')
 .show()
 .append(img);
 };
 };
 //事件注册
 $(me).on('paste',function(e){
 var clipboardData = e.originalEvent.clipboardData;
 var items, item, types;

 if( clipboardData ){
 items = clipboardData.items;

 if( !items ){
  return;
 }

 item = items[0];
 types = clipboardData.types || [];

 for(var i=0 ; i < types.length; i++ ){
  if( types[i] === 'Files' ){
  item = items[i];
  break;
  }
 }

 if( item && item.kind === 'file' && item.type.match(/^image\//i) ){
  imgReader( item );
 }
 }
 });

 $.fn.screenshotPaste.methods = {
 getImgData: function () {
 var src = $(document).find(options.imgContainer).find('img').attr('src');

 if(src==undefined){
  src='';
 }

 return src;
 }
 };
 };
})(jQuery);

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
jquery模拟按下回车实现代码
Sep 20 Javascript
理解JS绑定事件
Jan 19 Javascript
jQuery异步提交表单的两种方式
Sep 13 Javascript
JavaScript基础——使用Canvas绘图
Nov 02 Javascript
Vue 2.0+Vue-router构建一个简单的单页应用(附源码)
Mar 14 Javascript
JavaScript数据结构之二叉树的遍历算法示例
Apr 13 Javascript
Angular.js指令学习中一些重要属性的用法教程
May 24 Javascript
利用Angular.js编写公共提示模块的方法教程
May 28 Javascript
从零开始学习搭建React脚手架项目
Aug 23 Javascript
vue-cli脚手架的安装教程图解
Sep 02 Javascript
vue中$refs, $emit, $on, $once, $off的使用详解
May 26 Javascript
Vue页面切换和a链接的本质区别详解
Nov 12 Javascript
JQuery用户名校验的具体实现
Mar 18 #Javascript
基于javascript实现页面加载loading效果
Sep 15 #Javascript
JQuery fileupload插件实现文件上传功能
Mar 18 #Javascript
javascript移动开发中touch触摸事件详解
Mar 18 #Javascript
使用JavaScript为Kindeditor自定义按钮增加Audio标签
Mar 18 #Javascript
基于jQuery实现收缩展开功能
Mar 18 #Javascript
基于javascript显示当前时间以及倒计时功能
Mar 18 #Javascript
You might like
windows下升级PHP到5.3.3的过程及注意事项
2010/10/12 PHP
PHP读取mssql json数据中文乱码的解决办法
2016/04/11 PHP
PHP中set_include_path()函数相关用法分析
2016/07/18 PHP
PHP flush 函数使用注意事项
2016/08/26 PHP
Laravel 集成微信用户登录和绑定的实现
2019/12/27 PHP
改善用户体验的五款jQuery插件分享
2011/05/22 Javascript
JS判断表单输入是否为空(示例代码)
2013/12/23 Javascript
浅谈JavaScript中运算符的优先级
2015/07/07 Javascript
jQuery Easyui实现左右布局
2016/01/26 Javascript
js实现的简单图片浮动效果完整实例
2016/05/10 Javascript
Asp.Net之JS生成分页条的方法
2016/11/23 Javascript
js实现交通灯效果
2017/01/13 Javascript
原生JS中slice()方法和splice()区别
2017/03/06 Javascript
JavaScript事件方法(实例讲解)
2017/06/27 Javascript
nodejs中sleep功能实现暂停几秒的方法
2017/07/12 NodeJs
Vue编写多地区选择组件
2017/08/21 Javascript
Vue父子组件之间的通信实例详解
2018/09/28 Javascript
浅谈js中的bind
2019/03/18 Javascript
vue keep-alive列表页缓存 详情页返回上一页不刷新,定位到之前位置
2019/11/26 Javascript
js的Object.assign用法示例分析
2020/03/05 Javascript
JS异步宏队列微队列原理详解
2020/09/09 Javascript
ant-design-vue中的select选择器,对输入值的进行筛选操作
2020/10/24 Javascript
[02:40]DOTA2英雄基础教程 巨牙海民
2013/12/23 DOTA
[01:14:10]2014 DOTA2国际邀请赛中国区预选赛 SPD-GAMING VS Orenda
2014/05/22 DOTA
Python基于tkinter模块实现的改名小工具示例
2017/07/27 Python
对python中的six.moves模块的下载函数urlretrieve详解
2018/12/19 Python
python获取栅格点和面值的实现
2020/03/10 Python
python使用梯度下降算法实现一个多线性回归
2020/03/24 Python
Python发起请求提示UnicodeEncodeError错误代码解决方法
2020/04/21 Python
浅谈python opencv对图像颜色通道进行加减操作溢出
2020/06/03 Python
python属于跨平台语言码
2020/06/09 Python
linux centos 7.x 安装 python3.x 替换 python2.x的过程解析
2020/12/14 Python
KIEHL’S科颜氏官方旗舰店:源自美国的顶级护肤品牌
2018/06/07 全球购物
优秀学生干部推荐材料
2014/02/03 职场文书
2021年pycharm的最新安装教程及基本使用图文详解
2021/04/03 Python
flex弹性布局详解
2022/03/20 HTML / CSS