Vue实战【基于wangEditor富文本编辑器+拖拽实现一个自定义打印模版】

目录

  • 🌟前言
  • 🌟需求
  • 🌟效果预览
  • 🌟安装wangEditor富文本编辑器
  • 🌟拖拽API
  • 🌟wangEditor富文本编辑器所用到的API
  • 🌟写在最后
  • 🌟JSON包里写函数,关注博主不迷路

🌟前言

哈喽小伙伴们,本期文章为大家说一下最近项目里实现的一个自定义打印模版的功能;一起来看下吧。

🌟需求

  1. 打印的内容后端可配置;
  2. 可以拖拽任意标签;
  3. 样式可自定义,并内置相对应模本
  4. 最终数据传给后端,后端通过特定字符去获取数据,并返回给前端显示

通过以上需求,我最终确定了富文本编辑器的方式,配合拖拽API 来实现

🌟效果预览

vue实现基于富文本编辑器的打印模版设置功能(支持拖拽)

🌟安装wangEditor富文本编辑器

wangEditor富文本编辑器-官网

官网里有详细介绍,大家自行翻阅

🌟拖拽API

想实现拖拽有几个问题需要考虑:

  1. 谁可以拖拽(拖拽目标);
  2. 拖拽区域(哪里可以放下拖拽目标);
  3. 拿到拖拽目标的一些数据。
  • draggable=“true”–可以拖拽

在你需要拖拽的目标上写上写个。即可实现拖拽

   <el-tag size="small" style="margin: 2px;cursor: move" draggable="true">拖拽目标</el-tag>
  • @dragstart–开始拖拽

本事件可以监听到开始拖拽的事件,并且可以拿到目标物里的信息

   <el-tag size="small" style="margin: 2px;cursor: move" draggable="true" @dragstart.native="(event) => onDragStart(event,others)">拖拽目标</el-tag>
    onDragStart(event, item) {console.log('开始拖拽', event, item)// 获取目标物let draggableItem = event.target;draggableItem.key = item.key// 设置内容 视频当中为例:价格: ${价格}event.dataTransfer.setData("text/plain", draggableItem.innerText+ ':'+ '    ' +'${' +draggableItem.innerText + '}');},

把文本处理成 $ {} 这样,是为了传给后端,后端方便处理数据,后端通过 $ {} 来截取并查询正确的数据,并在打印的时候拼接好模版和真实数据。

  • @dragover–方法将表明在该位置允许放置

本事件可以指定一个位置,表明该位置可以放置拖拽的元素
如果你想要允许放置,你必须取消 dragenter 和 dragover 事件来阻止默认的处理。你可以在属性定义的事件监听程序返回 false,或者调用事件的 preventDefault() 方法来实现这一点。在一个独立脚本中的定义的函数里,可能后者更可行。

   <div  @dragover.native="$event.preventDefault()" />
  • @drop-方法将处理放下以后得一些逻辑
	 <div @drop.native="drop" />drop(event) {// 在这里处理放下的逻辑console.log('进入放下', event)event.preventDefault();},

🌟wangEditor富文本编辑器所用到的API

  • dangerouslyInsertHtml()

向编辑器里插入html

          this.editor.dangerouslyInsertHtml(`<h3 style="text-align: center">模版信息</h3><p style="width: 100%;display: flex;justify-content: space-between;align-items: center">请将左侧菜单拖至此处...</p>`)

注:只有在编辑器聚焦的时候才可以插入HTML

🌟写在最后

以上就是实现本功能的一些重点了;大家也可以去试试。喜欢的小伙伴们可以支持一下博主;你们的支持就是我创作的动力。各位小伙伴让我们 let’s be prepared at all times!

🌟JSON包里写函数,关注博主不迷路

原创不易,还希望各位大佬支持一下!
👍 点赞,你的认可是我创作的动力!
⭐️ 收藏,你的青睐是我努力的方向!
✏️ 评论,你的意见是我进步的财富!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/44811.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

7.11 cf div3 C

Problem - C - Codeforces 操作 根据给定的索引数组ind和字符串c&#xff0c;按照一定的顺序修改字符串s中对应位置的字符。具体来说&#xff0c;第i次操作会修改s中索引为indi的位置的字符&#xff0c;将其设置为ci。 将c字符串按照从小到大排序&#xff0c;替换ind数组所表…

可观察性优势:掌握当代编程技术

反馈循环是我们开发人员工作的关键。它们为我们提供信息&#xff0c;并让我们从用户过去和现在的行为中学习。这意味着我们可以根据过去的反应进行主动开发。 TestComplete 是一款自动化UI测试工具&#xff0c;这款工具目前在全球范围内被广泛应用于进行桌面、移动和Web应用的…

vue项目实现路由按需加载(路由懒加载)的三种方式

使用异步组件 在使用vue-router配置路由时&#xff0c;可以使用异步组件来实现路由的按需加载。异步组件会在路由被访问时才进行加载&#xff0c;从而实现按需加载的效果。需要注意的是&#xff0c;使用异步组件需要借助webpack的动态import语法来实现。例如&#xff1a; cons…

【DRAM存储器三十三】LPDDR4介绍--寻址、pin定义、命令真值表

👉个人主页:highman110 👉作者简介:一名硬件工程师,持续学习,不断记录,保持思考,输出干货内容 参考资料:《镁光LPDDR4数据手册》 、《JESD209-4B》 目录 LPDDR4的寻址 LPDDR4的pin脚定义 命令真值表 LPDDR4的寻址

【深度学习入门篇 ②】Pytorch完成线性回归!

&#x1f34a;嗨&#xff0c;大家好&#xff0c;我是小森( &#xfe61;ˆoˆ&#xfe61; )&#xff01; 易编橙终身成长社群创始团队嘉宾&#xff0c;橙似锦计划领衔成员、阿里云专家博主、腾讯云内容共创官、CSDN人工智能领域优质创作者 。 易编橙&#xff1a;一个帮助编程小…

邦芒攻略:8条建议让你在大学毕业五年内蜕变

大学毕业后很多人都有了翻天覆地的变化&#xff0c;有些人有了自己的事业&#xff0c;进了国企&#xff0c;考上了公务员。有的人呢&#xff0c;自己创业成了一个小老板。 有的人还在苦苦地读研&#xff0c;为了自己的理想而奋斗。但是&#xff0c;总有一些人会停滞不前&#x…

第三方支付平台如何完美契合游戏行业?

在数字经济的浪潮中&#xff0c;游戏行业以其独特的魅力和创新能力&#xff0c;成为全球文化和经济交流的重要桥梁。然而&#xff0c;海外游戏商在进军中国市场时&#xff0c;常面临一系列难题。本文将通过一个故事案例&#xff0c;揭示第三方支付平台PASSTO PAY如何帮助海外游…

vue3中antd上传图片组件及回显

实现效果&#xff1a; 调用后端接口后&#xff0c;后端返回的数据&#xff1a; 1.在项目components/base下新建UploadNew.vue文件&#xff08;上传图片公共组件&#xff09; <template><div class"clearfix"><a-uploadv-model:file-list"fileL…

发挥储能系统领域优势,海博思创坚定不移推动能源消费革命

随着新发展理念的深入贯彻&#xff0c;我国正全面落实“双碳”目标任务&#xff0c;通过积极转变能源消费方式&#xff0c;大幅提升能源利用效率&#xff0c;实现了以年均约3.3%的能源消费增长支撑了年均超过6%的国民经济增长。这一成就的背后&#xff0c;是我国能源结构的持续…

龙蜥Anolis OS基于开源项目制作openssh 9.8p1 rpm包 —— 筑梦之路

环境信息 制作过程和centos 7几乎没有区别&#xff0c;此处就不再赘述。 CentOS 7基于开源项目制作openssh9.8p1 rpm二进制包修复安全漏洞CVE-2024-6387 —— 筑梦之路_cve-2024-6387修复-CSDN博客 制作成果展示 tree RPMS/ RPMS/ └── x86_64├── openssh-9.8p1-1.an7.…

springboot3整合SpringSecurity实现登录校验与权限认证(万字超详细讲解)

目录 身份认证&#xff1a; 1、创建一个spring boot项目&#xff0c;并导入一些初始依赖&#xff1a; 2、由于我们加入了spring-boot-starter-security的依赖&#xff0c;所以security就会自动生效了。这时直接编写一个controller控制器&#xff0c;并编写一个接口进行测试&…

【面试题】防火墙的部署模式有哪些?

防火墙的部署模式多种多样&#xff0c;每种模式都有其特定的应用场景和优缺点。以下是防火墙的主要部署模式&#xff1a; 一、按工作模式分类 路由模式 定义&#xff1a;当防火墙位于内部网络和外部网络之间时&#xff0c;需要将防火墙与内部网络、外部网络以及DMZ&#xff0…

【Jenkins持续集成持续部署】

目录 docker下安装gitlab一、安装docker二、使用容器安装gitlab三、Jenkins安装 Maven安装3测试服务器安装docker安装jenkens安装mavenJenkins Git Maven自动化部署配置 docker下安装gitlab redhat&#xff1a;9 内存建议6个G&#xff1b; 系统内核至少在3.10以上uname -r命…

事半功倍大法!财务数据API让企业工作智能化

在快速变化的商业环境中&#xff0c;财务管理的自动化已成为企业提升效率、降低成本和增强决策质量的关键。财务API&#xff0c;作为现代企业架构中不可或缺的一部分&#xff0c;提供了一种强大的工具&#xff0c;使得企业能够无缝集成各种财务服务和应用&#xff0c;实现数据的…

数据分析理论

数据分析的概念 数据分析是指通过恰当的统计方法和分析手段&#xff0c;对数据进行收集汇总&#xff0c;并进行加工处理。对处理过后的有效数据进行分析&#xff0c;发现存在的问题&#xff0c;制定可行的方案、从而帮助人们采取更科学的行动 数据分析4个层次 著名咨询公司Gart…

HandlerThread的使用

private void initHandler() { HandlerThread thread new HandlerThread("MainCamHandler"); thread.start(); workHandler new Handler(thread.getLooper()); } 在Android开发中&#xff0c;HandlerThread是用来创建一个在独立线…

【WEB前端2024】3D智体编程:乔布斯3D纪念馆-第59-agent自动获取喵星人资讯并保存至云文件夹

【WEB前端2024】3D智体编程&#xff1a;乔布斯3D纪念馆-第59-agent自动获取喵星人资讯并保存至云文件夹 使用dtns.network德塔世界&#xff08;开源的智体世界引擎&#xff09;&#xff0c;策划和设计《乔布斯超大型的开源3D纪念馆》的系列教程。dtns.network是一款主要由Java…

Oracle执行一条SQL的内部过程

一、SQL语句根据其功能主要可以分为以下几大类&#xff1a; 1. 数据查询语言&#xff08;DQL, Data Query Language&#xff09; 功能&#xff1a;用于从数据库中检索数据&#xff0c;常用于查询表中的记录。基本结构&#xff1a;主要由SELECT子句、FROM子句、WHERE子句等组成…

stm32h743 阿波罗v2 NetXduo http server CubeIDE+CubeMX

在这边要设置mpu的大小&#xff0c;要用到http server&#xff0c;mpu得设置的大一些 我是这么设置的&#xff0c;做一个参考 同样&#xff0c;在FLASH.ld里面也要对应修改&#xff0c;SECTIONS里增加.tcp_sec和 .nx_data两个区&#xff0c;我们用ram_d2区域去做网络&#xff…

生产英特尔CPU处理器繁忙的一天

早晨&#xff1a;准备与检查 7:00 AM - 起床与准备 工厂员工们早早起床&#xff0c;快速洗漱并享用早餐。为了在一天的工作中保持高效&#xff0c;他们会进行一些晨间锻炼&#xff0c;保持头脑清醒和身体活力。 8:00 AM - 到达工厂 员工们到达英特尔的半导体制造工厂&#…