百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分析 > 正文

让编辑器支持word的复制黏贴,支持截屏的黏贴

liebian365 2024-10-22 15:41 19 浏览 0 评论

chrome有很多人性化的API,比如拖拽, 比如图片可以转化为base64等;

比如知乎上面的回复中可以直接黏贴图片, 就不需要手动点击图片上传按钮, 选择图片, 确认上传等等; 知乎参考地址:打开

让编辑器支持word的复制黏贴, 其中图片会转化为base64编码, 如果是通过远程打开这个静态页, 黏贴word文档的时候, 图片不会黏贴进来, 因为远程地址无法访问本地磁盘的绝对路径, 如果把下面代码保存成静态界面打开, 那么word中的图片都可以看见, 而且都会被转化为base64编码;

编辑器支持截屏的黏贴

让编辑器支持图片直接拖拽, 直接拖拽即可添加图片, 功能更加强大, 而且图片也是base64编码;

使用的话这new Edit, 参数为一个可编辑的元素, 比如有contenteditable属性的div或者iframe元素等:

<html>
    <head></head>
    <body>
    <script src="http://cdn.bootcss.com/jquery/1.9.0/jquery.js"></script>

        <div id="edit" contenteditable="true" style="width:400px;height:400px;border:1px solid #f00">

        </div>

    <script>
        function Edit( editEl ) {
 editEl = $(editEl);

 $(editEl).bind("paste", clipFn);

 function clipFn(ev) {

 //把剪贴板中的img通过canvas中专为base64字符串;
 var canvas = document.createElement("canvas");
 var context = canvas.getContext("2d");

 //从word拷贝时候会得到text/html数据;
 var html = $(ev.originalEvent.clipboardData.getData("text/html"));
 html.find("img").each(function  {

 var img = document.createElement("img");
 var src = $(this).attr("src"); //.replace(/\\/gi,"\/");
 var _this = this;
 img.src = src;

 img.onload = function  {
 canvas.width = img.width;
 canvas.height = img.height;
 context.drawImage(img, 0, 0, img.width, img.height);
 var dataBase64 = canvas.toDataURL("image/png").replace("image/png", "image/octet-stream");
 $("img").each(function (index, el) {
 //匹配图片;
 if ($(this).attr("src").replace(/[\/\\]/g,"") ===  src.replace(/[\/\\]/g,"")) {
 el.src = dataBase64;
 };
 });

 img.onerror = function {
 console.log("图片加载失败");
 };

 img.onload = null;
 };

 });

 //如果通过截图或者复制图片的方式会得到  type为"imgage"的图片;
 var ele = ev.originalEvent.clipboardData.items;
 for (var i = 0; i < ele.length; ++i) {
 if ( ele[i].kind == 'file' && ele[i].type.indexOf('image/') !== -1 ) {

 var blob = ele[i].getAsFile;
 readBlobAsDataURL(blob, function( base64 ) {

 var img= document.createElement('img');
 img.setAttribute('src', base64);

 editEl.append(img);;
 });
 //阻止默认事件, 避免重复添加;
 ev.originalEvent.preventDefault;
 };
 };
 };

 //绑定拖拽事件
 //要给个响应
 editEl.bind("dragover", function {
 return false;
 });

 //触发事件的响应
 editEl.bind("drop", function(ev) {
 loadImage( ev.originalEvent.dataTransfer.files[0] , function( result ) {
 editEl.append( "<img src="+result+" />" );
 });
 return false;
 });

 // 加载 图像文件(url路径)
 function loadImage(src, callback){
 // 过滤掉 非 image 类型的文件
 if(!src.type.match(/image.*/)){
 if(window.console){
 console.log("选择的文件类型不是图片: ", src.type);
 } else {
 window.confirm("只能选择图片文件");
 }
 return;
 }

 // 创建 FileReader 对象 并调用 render 函数来完成渲染.
 var reader = new FileReader;
 // 绑定load事件自动回调函数
 reader.onload = function(e){
 // 调用前面的 render 函数
 callback(e.target.result);
 };
 // 读取文件内容
 reader.readAsDataURL(src);
 };

 function readBlobAsDataURL(blob, callback) {
 var a = new FileReader;
 a.onload = function(e) {callback(e.target.result);};
 a.readAsDataURL(blob);
 };
        };
    </script>
    
    <script>
        new Edit("#edit");
    </script>
    </body>
</html>

很多网上的编辑器里 对图片的支持单一, 都会考虑IE6, IE7, ff, chrome, 各种兼容问题;

这个解决方案适合基于chrome内核的浏览器, FF的兼容没有处理, 因为所有的图片数据都是基于base64, 图片就没有上传这一说法了,图片都变成了字符串, 不过这个有个劣势就是每一次提交的数据都会比较大;

相关推荐

4万多吨豪华游轮遇险 竟是因为这个原因……

(观察者网讯)4.7万吨豪华游轮搁浅,竟是因为油量太低?据观察者网此前报道,挪威游轮“维京天空”号上周六(23日)在挪威近海发生引擎故障搁浅。船上载有1300多人,其中28人受伤住院。经过数天的调...

“菜鸟黑客”必用兵器之“渗透测试篇二”

"菜鸟黑客"必用兵器之"渗透测试篇二"上篇文章主要针对伙伴们对"渗透测试"应该如何学习?"渗透测试"的基本流程?本篇文章继续上次的分享,接着介绍一下黑客们常用的渗透测试工具有哪些?以及用实验环境让大家...

科幻春晚丨《震动羽翼说“Hello”》两万年星间飞行,探测器对地球的最终告白

作者|藤井太洋译者|祝力新【编者按】2021年科幻春晚的最后一篇小说,来自大家喜爱的日本科幻作家藤井太洋。小说将视角放在一颗太空探测器上,延续了他一贯的浪漫风格。...

麦子陪你做作业(二):KEGG通路数据库的正确打开姿势

作者:麦子KEGG是通路数据库中最庞大的,涵盖基因组网络信息,主要注释基因的功能和调控关系。当我们选到了合适的候选分子,单变量研究也已做完,接着研究机制的时便可使用到它。你需要了解你的分子目前已有哪些...

知存科技王绍迪:突破存储墙瓶颈,详解存算一体架构优势

智东西(公众号:zhidxcom)编辑|韦世玮智东西6月5日消息,近日,在落幕不久的GTIC2021嵌入式AI创新峰会上,知存科技CEO王绍迪博士以《存算一体AI芯片:AIoT设备的算力新选择》...

每日新闻播报(September 14)_每日新闻播报英文

AnOscarstatuestandscoveredwithplasticduringpreparationsleadinguptothe87thAcademyAward...

香港新巴城巴开放实时到站数据 供科技界研发使用

中新网3月22日电据香港《明报》报道,香港特区政府致力推动智慧城市,鼓励公私营机构开放数据,以便科技界研发使用。香港运输署21日与新巴及城巴(两巴)公司签署谅解备忘录,两巴将于2019年第3季度,开...

5款不容错过的APP: Red Bull Alert,Flipagram,WifiMapper

本周有不少非常出色的app推出,鸵鸟电台做了一个小合集。亮相本周榜单的有WifiMapper's安卓版的app,其中包含了RedBull的一款新型闹钟,还有一款可爱的怪物主题益智游戏。一起来看看我...

Qt动画效果展示_qt显示图片

今天在这篇博文中,主要实践Qt动画,做一个实例来讲解Qt动画使用,其界面如下图所示(由于没有录制为gif动画图片,所以请各位下载查看效果):该程序使用应用程序单窗口,主窗口继承于QMainWindow...

如何从0到1设计实现一门自己的脚本语言

作者:dong...

三年级语文上册 仿写句子 需要的直接下载打印吧

描写秋天的好句好段1.秋天来了,山野变成了美丽的图画。苹果露出红红的脸庞,梨树挂起金黄的灯笼,高粱举起了燃烧的火把。大雁在天空一会儿写“人”字,一会儿写“一”字。2.花园里,菊花争奇斗艳,红的似火,粉...

C++|那些一看就很简洁、优雅、经典的小代码段

目录0等概率随机洗牌:1大小写转换2字符串复制...

二年级上册语文必考句子仿写,家长打印,孩子照着练

二年级上册语文必考句子仿写,家长打印,孩子照着练。具体如下:...

一年级语文上 句子专项练习(可打印)

...

亲自上阵!C++ 大佬深度“剧透”:C++26 将如何在代码生成上对抗 Rust?

...

取消回复欢迎 发表评论: