首页 > 其他分享 >富文本编辑器:自己实现图片上传功能和图片粘贴上传(kindeditor)

富文本编辑器:自己实现图片上传功能和图片粘贴上传(kindeditor)

时间:2023-12-27 10:49:12浏览次数:35  
标签:文本编辑 cbd e5% items && 上传 图片

 在需要编写并保存带有各种格式,图片的文章内容时,往往需要用到富文本编辑器,这次使用到的富文本编辑器是kindeditor,使用下来功能基本足够,在这里记录下在使用时自己添加的功能。

 kindeditor自带有图片上传功能,由于几个原因我需要自己实现一下。

(一)用的vue,自然是写一个<kindeditor>组件和<uploadImg>组件;

(1)<uploadImg>:因为有用iview作为基础ui组件,所以上传用的也是iview的Upload组件,:action为服务器的图片上传地址,在这里:on-success里的方法imgUploadSuccess,在图片上传服务器 成功后,向uploadImg的父组件传递服务器回传的图片地址(这边我是再上传阿里云)。

 

  (2)在kindeditor组件中加入自己写的图片上传组件:<Uploadimg @getOssImg='addImgToKindeditor' :uploadByPaste='pasteData'></Uploadimg>

引入npm install下来的内容,并添加textarea标签:

<textarea class="form-control" id='kindeditor' ref="kindeditor" v-model="localValue" name="content" v-loaded-callback='initKindeditor'></textarea> 

  initKindeditor函数是对kindeditor的初始化,

 

 

 

appendHtml方法追加内容,addImgToKindeditor (data) { this.appendHtml('<img src='+data+' style="width:auto;">')  }实现将uploadImg返回的图片地址拼接后,追加到编辑器内容后面; 

 

(二)图片粘贴上传

 粘贴功能通过监听“paste”事件,获取clipboardData对象,取得剪贴板的内容。在这里将监听写在initKindeditor初始化方法的options中,options有个afterCreate,定义创建后执行的内容,如图:

 

 代码段:

            this.edit.doc.body.addEventListener("paste", function (e) { 

                let cbd = e.clipboardData;

                let ua = window.navigator.userAgent;  

                // 如果是 Safari 直接 return

                if ( !(e.clipboardData && e.clipboardData.items) ) {

                    return;

                }

                // Mac平台下Chrome49版本以下 复制Finder中的文件的Bug Hack掉

                if(cbd.items && cbd.items.length === 2 && cbd.items[0].kind === "string" && cbd.items[1].kind === "file" &&

                    cbd.types && cbd.types.length === 2 && cbd.types[0] === "text/plain" && cbd.types[1] === "Files" &&

                    ua.match(/Macintosh/i) && Number(ua.match(/Chrome\/(\d{2})/i)[1]) < 49){

                    return;

                } 

                if(cbd.items.length == 0){

                    _this.$Message.warning('本地图片请使用图片上传功能!');

                }

                for(let i = 0; i < cbd.items.length; i++) {

                    let item = cbd.items[i]; 

                    if(item.kind == "file"){   //循环获得kind为file的,并用getASFile转化赋值给blob

                        let blob = item.getAsFile();

                        if (blob.size === 0) {

                            return;

                        }

                        //console.log(blob)// blob 就是从剪切板获得的文件 可以进行上传或其他操作

                        _this.pasteData = blob; 

                    }

                }

                e.preventDefault();  //阻止默认动作

            }, false);

            在我的代码中,最后将图片对象赋值给一个pasteData,作为Uploadimg的prop参数,监听到pasteData的变化后,发起图片上传

            uploadImg组件中:

             watch: {

                uploadByPaste () { //监听粘贴内容

                    this.$refs.upload.post(this.uploadByPaste);  //发送表单

                }

            }

            注意:粘贴功能的图片来源只能是非本地图片,现在试过微信截图,文档中图片单独复制,网页图片复制都可以实现复制粘贴的效果。

 

参考文章:http://blog.ncmem.com/wordpress/2023/12/27/%e5%af%8c%e6%96%87%e6%9c%ac%e7%bc%96%e8%be%91%e5%99%a8%ef%bc%9a%e8%87%aa%e5%b7%b1%e5%ae%9e%e7%8e%b0%e5%9b%be%e7%89%87%e4%b8%8a%e4%bc%a0%e5%8a%9f%e8%83%bd%e5%92%8c%e5%9b%be%e7%89%87%e7%b2%98%e8%b4%b4/

欢迎入群一起讨论

 

 

标签:文本编辑,cbd,e5%,items,&&,上传,图片
From: https://www.cnblogs.com/songsu/p/17929996.html

相关文章

  • geoserver中styles引用外部图片
    使用geoserver发布图层,需要显示指定的图标从geoserver用户手册——PointSymbolizer中可以了解到只需在PointSymbolizer时候使用ExternalGraphic标签,其使用说明如下:<PointSymbolizer><Graphic><ExternalGraphic><OnlineResourcexlink:type="simple"......
  • Sftp日常使用(上传和下载)
    SftpSFTP是SecureFileTransferProtocol的缩写,安全文件传送协议。可以为传输文件提供一种安全的网络的加密方法。SFTP与FTP有着几乎一样的语法和功能。SFTP为SSH的其中一部分,是一种传输档案至Blogger伺服器的安全方式。其实在SSH软件包中,已经包含了一个叫作SFTP(SecureFileTr......
  • 在Go语言中处理HTTP文件上传
    大家好,我是你们可爱又迷人的编程小助手,今天要带你们一起探讨在Go语言中如何处理HTTP文件上传,让我们把这场技术之旅变得轻松有趣吧!首先,想象一下这个场景:你是一个网站的开发者,用户们急切地想要上传他们的照片、文档或者其他类型的文件到你的服务器上。文件上传,听起来就像是一个神秘的......
  • ai 图片消除工具, lama-cleaner,安装
    如何使用这是一款开源工具,访问以下网页可供体验。https://huggingface.co/spaces/Sanster/Lama-Cleaner-lama如果你打不开上方的网址,可以尝试自行在电脑上部署。本机部署此功能安装python并确保python被加入到环境变量这一步不多讲解,关于python的安装网络上有特别多文字和......
  • wireshark 捕获 C# 上传的图片
    如何通过wireshark捕获C#上传的图片 一:背景1.讲故事这些天计划好好研究下tcp/ip,以及socket套接字,毕竟工控中设计到各种交互协议,如果只是模模糊糊的了解,对分析此类dump还是非常不利的,而研究协议最好的入手点就是用抓包工具wireshark,废话不多说,这篇通过wireshark提取......
  • Flutter获取大文件MD5值的方法以及大文件实现分块上传和断点续传
    Flutter获取大文件MD5值的方法最近一直在搞flutter,有一个需求是将一个不到1G的大文件从App端上传到服务器,为了做文件校验所以要获取到文件的MD5。1.第一步首先获取到文件,并计算出文件大小和分快的数目Filefile=File(path);intfileSize=file.lengthSync();inttotalPart=......
  • 前端上传文件或者上传文件夹
    文档https://developer.mozilla.org/zh-CN/docs/Web/HTML/Element/input上传文件夹,主要的参数webkitdirectory浏览器上传文件夹,浏览器会弹出询问窗口 兼容性https://caniuse.com/?search=webkitdirectory 代码如下<!--选择文件--><div><labelfor="upload-file">点......
  • iview 表格列自定义样式 & public.css 公共样式里面引用图片方式
    {title:'操作',key:'action',align:'center',renderHead:()=>{},//自定义表头样式className:'col_oper',width:120,render:(h,params)=&g......
  • 前端实现文件上传(点击+拖拽)
    一、简介之前在Vue项目中使用过element的上传组件,实现了点击上传+拖拽上传的两种上传功能。然后我就在想是否可以通过原生的html+js来实现文件的点击上传和拖拽上传,说干就干。首先是点击获取上传文件自然没的说,只需要借助input标签即可,但原生的点击上传按钮,实在是过于简陋,所以我的......
  • canvas操作图片像素点保证你看的明明白白
    开场白今天遇到一个场景;就是更改一个图片的颜色;当听到这个。我直呼好家伙;这个是要上天了呀。但是仔细一思考;借助canvas好像也能实现;于是下来研究了一下,并不难;我们下面来看看怎么实现的基本思路主要是获取图片的像素点;ctx.getImageData()然后去更改图片的像素点;最后绘制在画布......