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

芯片制造企业如何解决CAD图纸粘贴到TinyMCE的矢量输出?

关于Vue内使用tinymce图片上传粘贴相关问题最近因为工作需要用到了富文本编辑器让用户填写反馈上传图片等功能经过一些对比选择了tinymce,记录下图片相关问题。完整版封装的组件代码放到最后。环境vue2.xtinymce 5.10.3tinymce-vue 2.1.0这里由于开发环境是vue2,所以目前这个时间点需要选择版本的去安装引用官方文档的一句话Version 4 of the tinymce-vue package supports Vue.js 3.x, but does not support Vue.js 2.x. For Vue.js 2.x applications, use tinymce-vue version 3.图片上传这个比较简单在init的配置中配置images_upload_handler...data(){init{images_upload_handlerthis.handleImageUpload}},methods:{handleImageUpload(blobInfo,success,failure){// 将图片上传到服务器.let formdatanewFormData()formdata.append(file,blobInfo.blob(),blobInfo.filename())this.uploadImage(formdata).then(success).catch(failure)},uploadImage(formdata){returnnewPromise((resolve,reject){Axios({url:https://xxxx.xx.com/xxx/xxx,method:post,data:formdata,headers:{Content-Type:multipart/form-data}}).then(result{console.log(result)if(result.status!200||result.data.code!200){constmsg上传失败reject(msg)}else{resolve(result.data.data)}})})}}图片粘贴刚开始是想到的直接监听document的paste事件去获取剪切板的图片代码如下// 代码引用至张鑫旭的个人网站文章// https://www.zhangxinxu.com/wordpress/2018/09/ajax-upload-image-from-clipboard/document.addEventListener(paste,function(event){varitemsevent.clipboardDataevent.clipboardData.items;varfilenull;if(itemsitems.length){// 检索剪切板itemsfor(vari0;iitems.length;i){if(items[i].type.indexOf(image)!-1){fileitems[i].getAsFile();break;}}}// 此时file就是剪切板中的图片文件});后来发现不生效检查一下元素得知tinymce是通过iframe使用的所以在tinymce输入框内paste事件无法触发后来找到了init_instance_callback配置项返回的实例可以监听粘贴事件init{init_instance_callback:editor{editor.on(paste,e{})}}粘贴监听算是解决了接下来要处理的是粘贴后如何如何替换图片。因为默认粘贴进去的图片是以base64存在的这样直接存进数据库不好所以需要将base64替换。刚开始想到的是将base64删除然后替换新的img标签进去这样存在一个问题就是如果上传图片的网络慢用户多次粘贴或者输入文字图片的位置就会错位.最后这里选择了在用户一粘贴拿到base64,上传成功后替换即可。代码如下methods:{listenImgPaste(event){returnnewPromise(resolve{constitemsevent.clipboardDataevent.clipboardData.itemsletfilenullif(itemsitems.length){for(leti0;iitems.length;i){if(items[i].type.indexOf(image)!-1){fileitems[i].getAsFile()break}}}if(file){setTimeout((){// 获取当前图片的base64constbase64this.myValue.match(/srcdata:image.*?/g)letformdatanewFormData()formdata.append(file,file)this.uploadImage(formdata).then(url{// 成功后将base64替换this.myValuethis.myValue.replace(base64,src${url})resolve()})})}})},}成功实现。最后一个问题替换修改值以后tinymce会默认将光标定位到最前面体验不是很好最后的解决方法也是加配置init:{init_instance_callback:editor{// 初始化后移动光标到最后this.moveCursorToLast(editor)console.log(editor)editor.on(paste,asyncevent{awaitthis.listenImgPaste(event)this.moveCursorToLast(editor)})}}methods:{// 移动光标到最后moveCursorToLast(editor){editor.selection.select(editor.getBody(),true)editor.selection.collapse(false)}}最后的完整组件代码// word导入插件(function(){use strict;varglobaltinymce.util.Tools.resolve(tinymce.PluginManager);functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor).importWord()}varregister$1function(editor){editor.ui.registry.addButton(wordimport,{text:,tooltip:导入Word文档,onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem(wordimport,{text:,tooltip:导入Word文档,onAction:function(){selectLocalImages(editor)}});};varButtons{register:register$1};functionPlugin(){global.add(wordimport,function(editor){Buttons.register(editor);});}Plugin();}());// word粘贴插件(function(){use strict;varglobaltinymce.util.Tools.resolve(tinymce.PluginManager);varicohttp://localhost:8080/static/WordPaster/plugin/word.pngfunctionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor).PasteManual()}varregister$1function(editor){editor.ui.registry.addButton(wordpaster,{text:,tooltip:Word一键粘贴,onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem(wordpaster,{text:,tooltip:Word一键粘贴,onAction:function(){selectLocalImages(editor)}});};varButtons{register:register$1};functionPlugin(){global.add(wordpaster,function(editor){Buttons.register(editor);});}Plugin();}());// ppt导入插件(function(){use strict;varglobaltinymce.util.Tools.resolve(tinymce.PluginManager);functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor);WordPaster.getInstance().importPPT()}varregister$1function(editor){editor.ui.registry.addButton(pptimport,{text:,tooltip:导入PowerPoint文档,onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem(pptimport,{text:,tooltip:导入PowerPoint文档,onAction:function(){selectLocalImages(editor)}});};varButtons{register:register$1};functionPlugin(){global.add(pptimport,function(editor){Buttons.register(editor);});}Plugin();}());// pdf导入插件(function(){use strict;varglobaltinymce.util.Tools.resolve(tinymce.PluginManager);functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor);WordPaster.getInstance().ImportPDF()}varregister$1function(editor){editor.ui.registry.addButton(pdfimport,{text:,tooltip:导入pdf文档,onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem(pdfimport,{text:,tooltip:导入pdf文档,onAction:function(){selectLocalImages(editor)}});};varButtons{register:register$1};functionPlugin(){global.add(pdfimport,function(editor){Buttons.register(editor);});}Plugin();}());// 网络图片上传插件(function(){use strict;varglobaltinymce.util.Tools.resolve(tinymce.PluginManager);functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor);WordPaster.getInstance().UploadNetImg()}varregister$1function(editor){editor.ui.registry.addButton(netpaster,{text:,tooltip:网络图片一键上传,onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem(netpaster,{text:,tooltip:网络图片一键上传,onAction:function(){selectLocalImages(editor)}});};varButtons{register:register$1};functionPlugin(){global.add(netpaster,function(editor){Buttons.register(editor);});}Plugin();}());// excel导入插件(function(){use strict;varglobaltinymce.util.Tools.resolve(tinymce.PluginManager);functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor).importExcel()}varregister$1function(editor){editor.ui.registry.addButton(excelimport,{text:,tooltip:导入Excel文档,onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem(excelimport,{text:,tooltip:导入Excel文档,onAction:function(){selectLocalImages(editor)}});};varButtons{register:register$1};functionPlugin(){global.add(excelimport,function(editor){Buttons.register(editor);});}Plugin();}());// word转图片插件(function(){use strict;varglobaltinymce.util.Tools.resolve(tinymce.PluginManager);functionselectLocalImages(editor){WordPaster.getInstance().SetEditor(editor);WordPaster.getInstance().importWordToImg()}varregister$1function(editor){editor.ui.registry.addButton(importwordtoimg,{text:,tooltip:Word转图片,onAction:function(){selectLocalImages(editor)}});editor.ui.registry.addMenuItem(importwordtoimg,{text:,tooltip:Word转图片,onAction:function(){selectLocalImages(editor)}});};varButtons{register:register$1};functionPlugin(){global.add(importwordtoimg,function(editor){Buttons.register(editor);});}Plugin();}());引用import tinymce from ../../../common/tinymce export default { name: createFeedback, components: { tinymce }, data () { return { form: { des: } } }下载插件下载插件

相关文章:

芯片制造企业如何解决CAD图纸粘贴到TinyMCE的矢量输出?

关于Vue内使用tinymce图片上传粘贴相关问题 最近因为工作需要,用到了富文本编辑器让用户填写反馈,上传图片等功能,经过一些对比选择了tinymce,记录下图片相关问题。 完整版封装的组件代码,放到最后。 环境 vue2.x tinymce 5.10…...

从漏洞复现到防御:手把手教你理解CVE-2021-4034(含POC分析)

深入解析CVE-2021-4034:从漏洞原理到实战防御 在Linux系统安全领域,权限提升漏洞一直是攻击者最青睐的攻击向量之一。2021年曝光的CVE-2021-4034漏洞因其影响范围广、利用难度低而备受关注。这个存在于Polkit的pkexec组件中的漏洞,允许普通用…...

金融系统如何优化Excel表格到TinyMCE5的跨平台渲染?

tinymce富文本,如何保留从word中粘贴的内容格式(vue2后台项目) 今天办公室里弥漫着一股“岁月静好”的错觉,键盘声稀疏得像老式挂钟的滴答声,同事们或对着屏幕发呆,或偷偷刷着手机,连平日里最爱…...

前端开发必备:用proj4.js搞定地图坐标转换(附完整代码示例)

前端开发必备:用proj4.js搞定地图坐标转换(附完整代码示例) 地图数据可视化是前端开发中常见的需求,但不同地图服务使用的坐标系可能各不相同。比如百度地图使用BD09坐标系,高德地图使用GCJ02坐标系,而国际…...

TinyMCE如何完美兼容Word公式粘贴并保留原始样式?

如何在富文本中插入表情,word文档,及数学公式? 前言 校外培训迎来下岗潮,教育行业的小伙伴,大家过的还好吗?不过话说回来,技术过硬,你在哪里都是最靓的仔。今天就给大家补充一点弹…...

R星服务器又抽风?从‘Social Club初始化失败’聊聊国内玩家玩外服游戏的网络生存指南

海外游戏网络连接优化指南:从Social Club故障到全局解决方案 每次打开心爱的海外游戏,却看到"Social Club初始化失败"的提示,那种烦躁感想必每个玩家都深有体会。这背后反映的不仅是某个游戏平台的临时故障,更是国内玩家…...

Nanbeige 4.1-3B一文详解:Streamlit Theming API深度定制像素UI主题方案

Nanbeige 4.1-3B一文详解:Streamlit Theming API深度定制像素UI主题方案 1. 项目背景与设计理念 Nanbeige 4.1-3B像素冒险聊天终端是一款专为对话AI设计的独特前端界面。它突破了传统聊天界面的设计范式,将现代AI交互体验与复古游戏美学完美融合。 1.…...

OpenClaw定时任务实践:GLM-4.7-Flash实现24/7自动化监控

OpenClaw定时任务实践:GLM-4.7-Flash实现24/7自动化监控 1. 为什么需要自动化监控? 去年接手一个数据采集项目时,我每天要手动检查十几个网页的数据更新情况。这种重复性工作不仅耗时,还经常因为时间差错过关键信息。直到发现Op…...

从CTF靶场到实战:手把手复现EasyCMS后台弱口令与主题导出漏洞(附POC)

从CTF靶场到实战:手把手复现EasyCMS后台弱口令与主题导出漏洞 在企业级CMS系统的安全评估中,弱口令和文件操作漏洞往往是最容易被忽视却危害极大的安全隐患。本文将基于真实渗透测试经验,详细拆解EasyCMS(及类似迅睿CMS系统&#…...

Hunyuan-MT-7B模型日志分析:ELK堆栈实战

Hunyuan-MT-7B模型日志分析:ELK堆栈实战 1. 引言 当你运行Hunyuan-MT-7B这样的翻译模型时,有没有遇到过这样的情况:模型突然变慢,却不知道问题出在哪里?或者想知道哪些翻译请求最耗时,但面对一堆杂乱的日…...

用数据说话 10个降AIGC平台测评:论文写作全流程降AI率全解析

在论文写作的全过程中,AI生成内容(AIGC)已经成为学术界和教育界关注的焦点。随着AI技术的广泛应用,许多学生和研究者发现,使用AI辅助写作虽然提升了效率,但也带来了AIGC率偏高、查重率不达标等问题。如何在…...

实测才敢推!降AI率工具 千笔·降AI率助手 VS Checkjie,开源免费首选

在AI技术快速发展的今天,越来越多的学生和研究者开始借助AI工具进行论文写作,以提高效率、优化内容结构。然而,随着学术审查标准的不断升级,AI生成内容的痕迹越来越容易被查重系统识别,导致论文AI率超标,甚…...

亲测好用 10个降AIGC工具:论文写作全流程降AI率必备神器

在学术写作日益依赖AI辅助的当下,如何有效降低论文中的AIGC率、去除明显的AI痕迹,同时保持内容的逻辑性和原创性,已成为众多学生和研究者面临的共同难题。随着各大高校和期刊对AI生成内容的审查日趋严格,传统的“复制粘贴”式写作…...

天地图JavaScript API实战:多边形面积计算与交互式绘制

1. 天地图JavaScript API基础入门 第一次接触天地图JavaScript API的开发者可能会觉得有点懵,其实它和我们常用的百度地图、高德地图API类似,都是用来在网页上展示地图和实现地理信息功能的工具链。我刚开始用的时候也踩过不少坑,后来发现只要…...

Vue3项目实战:如何用@vitejs/plugin-legacy搞定老旧浏览器兼容?

Vue3工程化实践:基于vitejs/plugin-legacy的渐进式兼容方案 当我们在现代前端工程中采用Vue3和Vite的组合时,往往会遇到一个现实矛盾:开发时享受的ES模块原生导入、闪电般的HMR,与生产环境需要支持的旧版浏览器之间的技术代沟。这…...

Qwen3.5-9B长文档理解:PDF解析+关键信息抽取+摘要生成端到端部署

Qwen3.5-9B长文档理解:PDF解析关键信息抽取摘要生成端到端部署 1. 项目概述与核心价值 Qwen3.5-9B是阿里云推出的新一代多模态大语言模型,特别针对长文档处理场景进行了优化。本文将带您从零开始部署一个完整的端到端解决方案,实现PDF文档解…...

实战指南:基于Windows Server构建企业级AAA认证体系

1. 为什么企业需要AAA认证体系 在企业IT环境中,网络设备管理一直是个头疼的问题。想象一下,公司有几十台交换机、路由器,每个设备都要单独维护账号密码,管理员得记住上百组凭证。更可怕的是,当有员工离职时&#xff0c…...

告别托管依赖:用.NET 8 Native AOT把C#代码打包成纯原生DLL,让C++项目轻松调用

告别托管依赖:用.NET 8 Native AOT把C#代码打包成纯原生DLL,让C项目轻松调用 在跨语言开发的世界里,C#和C的协作一直是个既诱人又充满挑战的话题。想象一下,你有一个用C#精心打磨的高性能算法库,或者一个成熟的业务逻辑…...

ESP32 SD卡固件更新库:DSTIKE OLED图形化OTA引导方案

1. 项目概述DstikeUpdater 是一个专为 DSTIKE 系列 ESP32 开发板设计的嵌入式固件在线更新(Over-the-Air, OTA)辅助库,其核心定位并非替代 ESP-IDF 或 Arduino-ESP32 原生 OTA 机制,而是构建一套面向终端用户的、具备图形化交互能…...

UniApp多主题切换实战:从SCSS变量到require动态引入的完整指南

UniApp多主题切换实战:从SCSS变量到require动态引入的完整指南 在移动应用开发中,多主题切换功能已经成为提升用户体验的重要特性。无论是为了适配用户偏好、实现夜间模式,还是满足品牌定制需求,灵活的主题切换机制都能显著提升产…...

PyTorch梯度累积超快

💓 博客主页:瑕疵的CSDN主页 📝 Gitee主页:瑕疵的gitee主页 ⏩ 文章专栏:《热点资讯》 PyTorch梯度累积的极致加速:从理论瓶颈到实战突破目录PyTorch梯度累积的极致加速:从理论瓶颈到实战突破 …...

【实战指南】解决Qt平台插件加载失败:从环境变量配置到PyQt5重装全流程

1. 问题现象与初步诊断 最近在Windows系统下运行labelimg这类基于Qt开发的工具时,不少开发者都遇到了这样的报错提示: qt.qpa.plugin: Could not load the Qt platform plugin "windows" in "" even though it was found. This appl…...

解决高版本VisualStudio编译低版本Unreal源码的常见问题与技巧

1. 环境配置的坑与填坑指南 第一次用Visual Studio 2022打开老版本Unreal工程时,我直接被满屏的报错整懵了。最典型的就是那个"Windows SDK v8.1 must be installed"错误,明明系统里装着最新SDK,它偏要旧版本。后来发现Unreal引擎的…...

前端组件库——shadcn/ui:轻量、自由、可拥有,解锁前端组件库的AI时代未来

从 Element Plus 到 shadcn/ui:前端组件库的进化之路与架构选型思考 ![ 从 Element Plus 到 shadcn/ui:前端组件库的进化之路与架构选型思考摘要 前端组件库作为前端工程化的核心基础设施,历经十余年演进,已从全量安装、强依赖、黑…...

htop安装不了怎么解决

1 安装报错提示[rootjxzn200 log]# yum install htop 上次元数据过期检查:3:54:25 前,执行于 2024年05月29日 星期三 11时56分08秒。 未找到匹配的参数: htop 错误:没有任何匹配: htop 这是因为在你的系统中,默认的软件源中没有ht…...

5分钟搞定串口设备联网:用USR-K5模块搭建TCP通讯的保姆级教程

5分钟搞定串口设备联网:用USR-K5模块搭建TCP通讯的保姆级教程 当你需要将老旧的串口设备接入现代网络时,USR-K5模块就像一位精通双语的翻译官,能在RS-232和TCP/IP协议之间架起无缝桥梁。作为一款即插即用的串口转以太网模块,它特别…...

MMD Ray打光全攻略:从SpotLight设置到阴影优化,让你的模型更立体

MMD Ray打光全攻略:从SpotLight设置到阴影优化,让你的模型更立体 在MMD创作中,光线是赋予模型生命的关键要素。Ray渲染引擎的强大之处在于它能够模拟真实世界的光照行为,而掌握SpotLight的精细调节与阴影优化技巧,则是…...

java毕业设计基于springboot头条文章管理系统-编号:project44558

前言 该系统旨在提供一个高效、可靠的文章发布和管理解决方案,使用户能够轻松地发布、编辑和管理自己的文章,并与其他用户进行评论和互动。通过系统提供的文章分类与标签、搜索与过滤等功能,用户能够快速找到感兴趣的文章并参与讨论。一、项目…...

java毕业设计基于springboot图书管理系统-编号:project64080

前言 随着信息技术的不断发展和图书馆规模的不断扩大,传统的图书管理方式已经难以满足现代图书馆的需求。为了提高图书管理的效率和准确性,开发一个基于Spring Boot的图书管理系统显得尤为重要。该系统能够实现对图书的增删改查(CRUD&#xf…...

java毕业设计基于springboot网上问卷调查系统-编号:project25765

前言 随着互联网的快速发展,人们对于在线服务的需求越来越高,这促使了各种在线调查系统的蓬勃发展。其中,在线问卷调查系统因其操作简便、数据统计快速、受访者覆盖范围广等特点,逐渐成为一种主流的调查方式。传统的问卷调查方式由…...