1.使用wangeditor富文本编辑器
工具网站:https://www.wangeditor.com/v4/
下载安装命令:npm i wangeditor --save
成品如下图:
组件实现代码
<template> <div> <!-- 富文本编辑器 --> <div id="wangeditor"> </div> </div></template><script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script><script>import { uploadImage } from '@/api/api'; // 导入图片上传apiimport E from 'wangeditor';export default { name: 'richText', components: { }, props: { defaultDetails: { default: '请填写内容', type: String, }, }, watch: { htmlContent(val) { this.$emit('change', val); // 将改变同步到父组件 if (this.validateEvent) { this.dispatch('ElFormItem', 'el.form.change', [val]); } } }, data() { return { editor: null, htmlContent: '<p>hello</p>', firtherMethod: 'loadingCompleted', // 回调父组件,通知editor已经创建完成 }; }, methods: { // 获取text文本 getText() { const text = this.editor.txt.text(); console.log('text = ', text); return text; }, // 获取html getHtml() { const html = this.editor.txt.html(); console.log('thml = ', html); return html; }, // 图片上传自定义实现 async uploadImage(files) { const file = files[0]; console.log('Fuedit2-uploadImage file = ', file); const res = await uploadImage(obj); const path = SOCKET + (res.path || {}); console.log('完整path = ', path); return path; }, // 设置内容 setHtml(html) { this.editor.txt.html(html);// 重新设置编辑器内容 }, // 追加内容 appentHtml(html) { this.editor.txt.append(html);// 继续追加内容。 }, // 销毁编辑器 beforeDestroy() { // 销毁编辑器 console.log('销毁前'); this.editor.destroy() console.log('销毁后'); this.editor = null }, // 清空编辑器内容 clearText() { this.editor.txt.clear(); }, createEditor() { if(this.editor !== null) { return; } this.editor = new E('#wangeditor'); // 或者 const editor = new E( document.getElementById('div1') ) this.editor.config.height = 200; // 设置高度 // 内容发生改变时回调 // this.editor.config.onchange = function (html) { // this.htmlContent = html; // } this.editor.config.placeholder = this.defaultDetails; // 自定义初始文字提示 this.editor.config.focus = false;// 取消初始化时自动聚焦 this.editor.config.menus = [ // 定义显示哪些菜单和菜单的顺序。 'head', // 标题 'bold', // 粗体 'fontSize', // 字号 'fontName', // 字体 'italic', // 斜体 'underline', // 下划线 // 'strikeThrough', // 删除线 // 'indent', 'lineHeight', 'foreColor', // 文字颜色 'backColor', // 背景颜色 'link', // 插入链接 'list', // 列表 // 'todo', // 'justify', // 对齐方式 // 'quote', // 引用 // 'emoticon', // 表情 'image', // 插入图片 // 'table', // 表格 // 'video', // 插入视频 // 'code', // 插入代码 'splitLine', 'undo', // 撤销 'redo', // 重复 ]; // this.editor.config.uploadImgServer = '/upload-img'; // 配置上传server 接口地址 this.editor.config.uploadImgMaxSize = 2 * 1024 * 1024; // 图片上传max this.editor.config.uploadImgAccept = ['jpg', 'jpeg', 'png', 'gif', 'bmp', 'webp']; // 图片上传类型 this.editor.config.uploadImgMaxLength = 1; // 一次最多上传 1 个图片 this.editor.config.customUploadImg = async function (resultFiles, insertImgFn) { // 自定义图片上传实现 // resultFiles 是 input 中选中的文件列表;insertImgFn 是获取图片 url 后,插入到编辑器的方法 const file = resultFiles[0]; const path = await uploadImage(file);//返回图片地址 console.log('完整path = ', path); // 上传图片,返回结果,将图片插入到编辑器中 insertImgFn(path); } // 使用base64格式保存本地图片,不可与uploadImgServer同时使用 // this.editor.config.uploadImgShowBase64 = true; this.editor.create(); // this.editor.txt.html('<p>用 JS 设置的内容</p>');// 重新设置编辑器内容 // 第一步,初始化 textarea 的值 // text1.val(this.editor.txt.html()) console.log('this.editor = ', this.editor); // this.editor.txt.append('<p>追加的内容</p>');// 继续追加内容。 // 创建完成,回调父组件 try { this.$emit(this.firtherMethod, null); } catch (error) { console.log('editor 完成,回调父组件失败 error = ', error); } }, }, mounted() { this.createEditor(); },};</script><style lang="css" src="">/* @import '../css/Cnel.css';/* 使用style属性src引入外部css,仅在当前s组件有效 */</style>
组件使用方式
RichText: () => import('@/components/RichText.vue'),<rich-text v-model="details" ref="fueditModule" @loadingCompleted="loadingCompleted"></rich-text>export default Vue.extend({ name: 'UpdateText', components: { RichText: () => import('@/components/RichText.vue'), }, methods: { // 富文本组件加载完成回调 loadingCompleted() { try { console.log('editor加载完成,回调父组件'); // this.details = this.$refs.fueditModule.setHtml('<p><b>招商会详情!!</b></p>'); } catch (error) { console.log('打开弹窗 err =', error); } },// 调用子组件获取富文本内容this.details = this.$refs.fueditModule.getHtml();// 调用子组件设置富文本内容this.$refs.fueditModule.setHtml('<p><b>设置详情!!</b></p>');// 调用子组件销毁富文本编辑框this.$refs.fueditModule.beforeDestroy(); }})