wangeditor 富文本的使用

1.封装好组件

<template>
	<div ref="editorEl" class="editor-wrapper"></div>
</template>

<script>
import E from "wangeditor";
import { sessionRead, localReadObject } from "@/libs/utils";
import { getheadiconReq } from "@/api/organize-manager/user-manager";
import { getImageReq } from "@/api/system-manager/error-code-eap";

export default {
	name: "edit-custom",
	model: {
		prop: "value",
		event: "change",
	},
	props: {
		// 编辑器文本域内容
		value: {
			type: String,
			default: "",
		},
		// 文件上传地址
		uploadUrl: {
			type: String,
			default: "",
		},
		// 是否清除文本域内容
		isClear: {
			type: Boolean,
			default: false,
		},
		// 图片上传最大数量
		imgLength: {
			type: Number,
			default: 3,
		},
		// 图片上传大小 默认2M
		imgSize: {
			type: Number,
			default: 2 * 1024,
		},
		// 条形按钮数据
		menuData: {
			type: Array,
			default: () => [],
		},
		// 文本域层级
		editZIndex: {
			type: Number,
			default: 10000,
		},
		// 文本域层级
		height: {
			type: Number,
			default: 500,
		},
		//图片上传参数名
		uploadFileName: {
			type: String,
			default: "file",
		},
		type: {
			type: String,
			default: "icon",
		},
	},
	data() {
		return {
			editor: null,
			info_: null,
		};
	},
	watch: {
		isClear(newVal) {
			// 触发清除文本域内容
			if (newVal) {
				this.editor.txt.clear();
				this.info_ = null;
			}
		},
		value(newVal) {
			// 当父组件调用得时候,如果给value赋值了,子组件将会显示父组件赋给的值
			if (newVal !== this.editor.txt.html()) {
				this.editor.txt.html(this.value);
			}
		},
	},
	mounted() {
		this.setEditor();
		this.editor.txt.html(this.value);
	},
	methods: {
		setEditor() {
			this.editor = new E(this.$refs.editorEl);
			this.editor.config.uploadImgShowBase64 = false; // base 64 存储图片
			this.editor.config.showLinkImg = false; // 隐藏网络图片选项
			this.editor.config.uploadImgServer = this.uploadUrl; // 配置服务器端地址 上传图片
			const localObj = localReadObject(`${sessionRead("userName")}Obj`);
			this.editor.config.uploadImgHeaders = { Authorization: `Bearer ${localObj.token}` }; // 自定义 header
			this.editor.config.uploadImgMaxSize = this.imgSize * 1024; // 将图片大小限制为 2M
			this.editor.config.uploadImgMaxLength = this.imgLength; // 限制一次最多上传 3 张图片
			this.editor.config.uploadFileName = this.uploadFileName; // 后端接受上传文件的参数名
			this.editor.config.zIndex = this.editZIndex; // 文本域的层级
			this.editor.config.height = this.height; // 编辑器的高度

			// 配置菜单
			this.editor.config.menus =
				this.menuData.length > 0
					? this.menuData
					: [
							"head", // 标题
							"bold", // 粗体
							"fontSize", // 字号
							"fontName", // 字体
							"italic", // 斜体
							"underline", // 下划线
							"strikeThrough", // 删除线
							"indent", // 缩进
							"lineHeight", // 行高
							"foreColor", // 文字颜色
							"backColor", // 背景颜色
							"link", // 插入链接
							"list", // 列表
							"todo", // 代办事项
							"justify", // 对齐方式
							"quote", // 引用
							"emoticon", // 表情
							"image", // 插入图片
							"video", // 插入视频
							"table", // 表格
							"code", // 插入代码
							"splitLine", // 分割线
							"undo", // 撤销
							"redo", // 重复
							"fullscreen", // 全屏
					  ];

			// 请求结果
			this.editor.config.uploadImgHooks = {
				// fail: (xhr, editor, result) => {
				//   // 插入图片失败回调
				//   console.log('fail', xhr, editor, result);
				// },
				// success: (xhr, editor, result) => {
				//   // 图片上传成功回调
				//   console.log('success', xhr, editor, result);
				// },
				// timeout: (xhr, editor) => {
				//   // 网络超时的回调
				//   console.log('timeout', xhr, editor);
				// },
				// error: (xhr, editor) => {
				//   // 图片上传错误的回调
				//   console.log('error', xhr, editor);
				// },
				customInsert: (insertImg, result) => {
					console.log(result);
					// 图片上传成功,插入图片的回调
					//result为上传图片成功的时候返回的数据
					//insertImg(url)为插入图片的函数
					//editor为插入图片的函数
					// console.log('customInsert', result, editor);
					switch (this.type) {
						// 上传头像执行逻辑
						case "icon":
							getheadiconReq({ fileName: result.message }).then(async (res) => {
								const url = `data:image/png;base64,${btoa(new Uint8Array(res).reduce((data, byte) => data + String.fromCharCode(byte), ""))}`;
								insertImg(url);
							});
							break;
						// eap 错误代码 图片上传
						case "eap":
							getImageReq({ fileId: result.result }).then(async (res) => {
								const url = `data:image/png;base64,${btoa(new Uint8Array(res).reduce((data, byte) => data + String.fromCharCode(byte), ""))}`;
								insertImg(url);
							});
							break;
					}
				},
			};

			// 同步传入的文本域内容
			this.editor.config.onchange = (html) => {
				this.info_ = html; // 绑定当前逐渐地值
				this.$emit("change", this.info_); // 将内容同步到父组件中
			};

			// 创建富文本编辑器
			this.editor.create();
		},
	},
};
</script>

<style lang="less">
// 编辑器插件菜单栏样式修改
.w-e-toolbar .w-e-menu {
	width: 30px !important;
	height: 30px !important;
}
</style>

2.引用组件

<edit-custom
	v-model="submitData.zH_CN"
	:editZIndex="1"
	:height="200"
	:uploadUrl="uploadImage"
	uploadFileName="fileData"
	type="eap"
	@change="(html) => contentChange(html, 'zH_CN')"
></edit-custom>
// 编辑器内容改变触发
contentChange(html, type) {
	this.submitData[type] = html;
},

3.显示

<pre v-html="solutionContent"></pre>

注: solutionContent=

PPID值不存在

<img src=“”
contenteditable=“false” style=“font-size: 12px; max-width: 100%;”
width=“30%”/>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值