当前位置: 首页 > ai >正文

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

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

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

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

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

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

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

initKindeditor函数是对kindeditor的初始化,
在这里插入图片描述

appendHtml方法追加内容,addImgToKindeditor (data) { this.appendHtml(‘’) }实现将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 直接 returnif ( !(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转化赋值给bloblet 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/
欢迎入群一起讨论

在这里插入图片描述

http://www.xdnf.cn/news/10960.html

相关文章:

  • 电脑蓝屏代码0x00000050怎么解决?3种方法快速解决
  • 【小程序】微信开发者工具——盘古开天
  • python怎么写二进制文件需要更新_Python文件迭代器对二进制文件的更新
  • Android系统的开机画面显示过程分析
  • ubuntu软件更新源,更改,可提高更新的速度
  • [经验技巧] 小米 MIUI V4 系统精简列表
  • mysql虚拟主机_远程连接mysql要点 虚拟主机定义与分类
  • QQ技术全攻略(原来简单的QQ,还隐藏着这么多秘密!)
  • 四个福利性在线网站分享,每一个都让你欲罢不能……
  • 单词学习-Unit2Text4-1(15年8月10日,第20天)
  • HTML5 文件上传的2种方式
  • 中国石油大学《大学英语(三)统考》第七套模拟题
  • FreeTextBox使用方法
  • 面试时最经常被问到的问题(Frenquently asked interview questions)(I)
  • cmos和ccd区别对比
  • 魔兽世界经典旧世私服搭建教程
  • Linux 网络通信瑞士军刀 nc 命令使用
  • rails + devise 用户注册登录及权限判断
  • 解析网页的request header
  • A站、B站、C站、D站、E站、F站、G站、H站、I站、J站、K站、L站、M站、N站、O站、P站、Q站、R站、S站、T站、U站、V站、W站、X站、Y站、Z站都是什么网站?Q站是什么?
  • Quality Center介绍
  • centos7安装dzzoffice和OnlyOffice 安装过程和踩坑出坑!
  • c语言中 5.1lf什么意思,期货股指lf_中金所期货指数IF、IH、IC分别是什么英文单词的缩写_期货攻略网...
  • awk从放弃到入门(9):awk数组详解
  • C#获取文件路径或者文件夹路径的方法
  • 谷歌离线地图FTP下载
  • IIS配置问题 Directory Listing Denied
  • MSDTC不可用解决办法
  • 个人博客搭建指南
  • 网吧游戏服务器虚拟机,用虚拟机亲自体验网咖无盘系统,终于知道网咖系统快的原因了...