根据业务要求,需要能够上传图片,且上传的图片能在移动端中占满屏幕宽度,故需要能等比缩放上传的图片,还需要能拖拽、缩放、改变图片大小。尝试多个第三方富文本编辑器,很难找到一个完美符合自己要求的编辑器。经过多次尝试,最终选择了wangEditor富文本编辑器。 最初使用的是vue2Editor富文本编辑器,vue2Editor本身是不支持图片拖拽的,但是提供了可配置图片拖拽的方法,需要借助Quill.js来实现图片拖拽。虽然满足了业务需求,但是在移动端展示的效果不是很理想。 此次编辑器主要是上传的富文本需要在移动端进行展示,为了达到理想效果,需要能修改图片百分比,当设置img标签的width属性为100% 时,就可以满足需求。最近发新版本(第四版 v4)的wangEditor可以满足需求,最终选择了它用于实际开发中。
安装插件
npm i wangeditor --save // or yarn add wangeditor
编辑器配置
<template> <div class="w_editor"> <!-- 富文本编辑器 --> <div id="w_view"></div> </div> </template> <script> // 引入富文本 import WE from "wangeditor"; // 引入elementUI Message模块(用于提示信息) import { Message } from "element-ui"; export default { name: "WEditor", props: { // 默认值 defaultText: { type: String, default: "" }, // 富文本更新的值 richText: { type: String, default: "" } }, data() { return { // 编辑器实例 editor: null, // 富文本菜单选项配置 menuItem: [ "head", "bold", "fontSize", "fontName", "italic", "underline", "indent", "lineHeight", "foreColor", "backColor", "link", "list", "justify", "image", "video" ] }; }, watch: { // 监听默认值 defaultText(nv, ov) { if (nv != "") { this.editor.txt.html(nv); this.$emit("update:rich-text", nv); } } }, mounted() { this.initEditor(); }, methods: { // 初始化编辑器 initEditor() { // 获取编辑器dom节点 const editor = new WE("#w_view"); // 配置编辑器 editor.config.showLinkImg = false; /* 隐藏插入网络图片的功能 */ editor.config.onchangeTimeout = 400; /* 配置触发 onchange 的时间频率,默认为 200ms */ editor.config.uploadImgMaxLength = 1; /* 限制一次最多能传几张图片 */ // editor.config.showFullScreen = false; /* 配置全屏功能按钮是否展示 */ editor.config.menus = [...this.menuItem]; /* 自定义系统菜单 */ // editor.config.uploadImgMaxSize = 5 * 1024 * 1024 /* 限制图片大小 */; editor.config.customAlert = err => { Message.error(err); }; // 监控变化,同步更新数据 editor.config.onchange = newHtml => { // 异步更新组件富文本值的变化 this.$emit("update:rich-text", newHtml); }; // 自定义上传图片 editor.config.customUploadImg = (resultFiles, insertImgFn) => { /** * resultFiles:图片上传文件流 * insertImgFn:插入图片到富文本 * 返回结果为生成的图片URL地址 * */ // 此方法为自己封赚改写的阿里云图片OSS直传插件。 this.$oss(resultFiles[0], resultFiles[0]["name"]).then(url => { !!url && insertImgFn(url); /* oss图片上传,将图片插入到编辑器中 */ }); }; // 创建编辑器 editor.create(); this.editor = editor; } }, beforeDestroy() { // 销毁编辑器 this.editor.destroy(); this.editor = null; } }; </script>
注: 具体参数配置请参考编辑器文档使用说明。
<template> <div class="editor"> <el-card shadow="never"> <div slot="header" class="clearfix"> <span>富文本编辑器</span> </div> <div class="card_center"> <WEditor :defaultText="defaultText" :richText.sync="richText" /> </div> </el-card> </div> </template> <script> // 引入封装好的编辑器 import WEditor from "@/components/WEditor"; export default { name: "Editor", components: { WEditor }, data() { return { // 默认值 defaultText: "", // 富文本更新的值 richText: "" }; }, created() { // 等待组件加载完毕赋值 this.$nextTick(() => { this.defaultText = `<p style="text-align: center; "><img src="https://tr-mba.oss-cn-beijing.aliyuncs.com/picture/202010/20_222430_8011.png" width="30%" style="text-align: center; max-width: 100%;"></p>`; }); } }; </script>
以上就是vue集成一个支持图片缩放拖拽的富文本编辑器的详细内容,更多关于vue 富文本编辑器的资料请关注小牛知识库其它相关文章!
本文向大家介绍javascript实现表格排序 编辑 拖拽 缩放,包括了javascript实现表格排序 编辑 拖拽 缩放的使用技巧和注意事项,需要的朋友参考一下 简单表格排序 可以双击编辑 自定义编辑后的 规则 可拖动列进行列替换 可推动边框进行列宽度的缩放 已知BUG: ie6下 中文不自动换行 非ie下字母和数字也不自动换行确实让人恼火 chrome浏览器下点击运行好像问题
本文向大家介绍vue集成百度UEditor富文本编辑器使用教程,包括了vue集成百度UEditor富文本编辑器使用教程的使用技巧和注意事项,需要的朋友参考一下 在前端开发的项目中,难免会遇到需要在页面上集成一个富文本编辑器。那么,如果你有这个需求,希望可以帮助到你。 vue是前端开发者所追捧的框架,简单易上手,但是基于vue的富文本编辑器大多数太过于精简。于是我将百度富文本编辑器放到vue项目中使
Django集成UEditor (封装成应用) 百度富文本编辑器 http://ueditor.baidu.com/website/ 使用效果 测试环境 ubuntu 16.04 python3.5.2 django1.11.7 目前测试解决了出现的以下两个问题,都是python版本问题 error1 # name 'file' is not defined controller.py 68行
本文向大家介绍nodejs后台集成ueditor富文本编辑器的实例,包括了nodejs后台集成ueditor富文本编辑器的实例的使用技巧和注意事项,需要的朋友参考一下 UEditor是由百度web前端研发部开发所见即所得富文本web编辑器,具有轻量,可定制,注重用户体验等特点,开源基于MIT协议,允许自由使用和修改代码.. 1 下载ueditor nodejs版本 2 复制public目录下面的文
本文向大家介绍Django集成百度富文本编辑器uEditor攻略,包括了Django集成百度富文本编辑器uEditor攻略的使用技巧和注意事项,需要的朋友参考一下 首先从 ueEditor官网 下载最新版本的包,目前官网上提供了ASP、.NET、PHP、JSP版本的,django版本只有一个第三方个人开发的,但看上出配置起来稍微复杂一点。 这里不介绍uEditor的使用方法,也不过多解释uEdit
富文本编辑,又称为WYSIWYG(What You See Is What You Get,所见即所得)。在网页中编辑富文本内容,是人们对Web 应用程序最大的期待之一。虽然也没有规范,但在IE 最早引入的这一功能基础上,已经出现了事实标准。而且,Opera、Safari、Chrome 和Firefox 都已经支持这一功能。这一技术的本质,就是在页面中嵌入一个包含空HTML 页面的iframe。通