富文本编辑器(图片可以100%宽屏)
业务需求:
根据业务要求,需要能够上传图片,且上传的图片能在移动端中占满屏幕宽度,故需要能等比缩放上传的图片,还需要能拖拽、缩放、改变图片大小。尝试多个第三方富文本编辑器,很难找到一个完美符合自己要求的编辑器。经过多次尝试,最终选择了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";
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() {
const editor
= new WE("#w_view");
editor
.config
.showLinkImg
= false;
editor
.config
.onchangeTimeout
= 400;
editor
.config
.uploadImgMaxLength
= 1;
editor
.config
.menus
= [...this.menuItem
];
editor
.config
.customAlert = err
=> {
Message
.error(err
);
};
editor
.config
.onchange = newHtml
=> {
this.$emit("update:rich-text", newHtml
);
};
editor
.config
.customUploadImg = (resultFiles
, insertImgFn
) => {
this.$oss(resultFiles
[0], resultFiles
[0]["name"]).then(url
=> {
!!url
&& insertImgFn(url
);
});
};
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
>