久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術(shù)文章
文章詳情頁

vue集成一個支持圖片縮放拖拽的富文本編輯器

瀏覽:3日期:2022-10-07 18:12:16
需求:

根據(jù)業(yè)務(wù)要求,需要能夠上傳圖片,且上傳的圖片能在移動端中占滿屏幕寬度,故需要能等比縮放上傳的圖片,還需要能拖拽、縮放、改變圖片大小。嘗試多個第三方富文本編輯器,很難找到一個完美符合自己要求的編輯器。經(jīng)過多次嘗試,最終選擇了wangEditor富文本編輯器。 最初使用的是vue2Editor富文本編輯器,vue2Editor本身是不支持圖片拖拽的,但是提供了可配置圖片拖拽的方法,需要借助Quill.js來實現(xiàn)圖片拖拽。雖然滿足了業(yè)務(wù)需求,但是在移動端展示的效果不是很理想。 此次編輯器主要是上傳的富文本需要在移動端進(jìn)行展示,為了達(dá)到理想效果,需要能修改圖片百分比,當(dāng)設(shè)置img標(biāo)簽的width屬性為100% 時,就可以滿足需求。最近發(fā)新版本(第四版 v4)的wangEditor可以滿足需求,最終選擇了它用于實際開發(fā)中。

效果圖:

vue集成一個支持圖片縮放拖拽的富文本編輯器

代碼案例及相關(guān)配置如下:

安裝插件

npm i wangeditor --save// oryarn 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: {// 默認(rèn)值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: {// 監(jiān)聽默認(rèn)值defaultText(nv, ov) {if (nv != '') {this.editor.txt.html(nv);this.$emit('update:rich-text', nv);}}},mounted() {this.initEditor();},methods: {// 初始化編輯器initEditor() {// 獲取編輯器dom節(jié)點const editor = new WE('#w_view');// 配置編輯器editor.config.showLinkImg = false; /* 隱藏插入網(wǎng)絡(luò)圖片的功能 */editor.config.onchangeTimeout = 400; /* 配置觸發(fā) onchange 的時間頻率,默認(rèn)為 200ms */editor.config.uploadImgMaxLength = 1; /* 限制一次最多能傳幾張圖片 */// editor.config.showFullScreen = false; /* 配置全屏功能按鈕是否展示 */editor.config.menus = [...this.menuItem]; /* 自定義系統(tǒng)菜單 */// editor.config.uploadImgMaxSize = 5 * 1024 * 1024 /* 限制圖片大小 */;editor.config.customAlert = err => {Message.error(err);};// 監(jiān)控變化,同步更新數(shù)據(jù)editor.config.onchange = newHtml => {// 異步更新組件富文本值的變化this.$emit('update:rich-text', newHtml);};// 自定義上傳圖片editor.config.customUploadImg = (resultFiles, insertImgFn) => {/** * resultFiles:圖片上傳文件流 * insertImgFn:插入圖片到富文本 * 返回結(jié)果為生成的圖片URL地址 * */// 此方法為自己封賺改寫的阿里云圖片OSS直傳插件。this.$oss(resultFiles[0], resultFiles[0]['name']).then(url => {!!url && insertImgFn(url); /* oss圖片上傳,將圖片插入到編輯器中 */});};// 創(chuàng)建編輯器editor.create();this.editor = editor;}},beforeDestroy() {// 銷毀編輯器this.editor.destroy();this.editor = null;}};</script>

注: 具體參數(shù)配置請參考編輯器文檔使用說明。

組件中使用抽離的編輯器:

<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 {// 默認(rèn)值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' style='text-align: center; max-width: 100%;'></p>`;});}};</script>

以上就是vue集成一個支持圖片縮放拖拽的富文本編輯器的詳細(xì)內(nèi)容,更多關(guān)于vue 富文本編輯器的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 国产精品毛片一区二区在线看 | 国产欧美日韩在线观看 | 亚洲一区中文字幕 | 伊人久久国产 | 黄在线免费观看 | 亚洲免费视频一区二区 | 一区二区日韩 | 久久久久久黄 | 久久久久中文字幕 | 视频一区中文字幕 | 免费观看毛片 | 国产日产精品一区二区三区四区 | 狠狠插天天干 | 精品久| 欧美在线视频网 | 91精品国产乱码久久久久久久久 | 1区2区免费视频 | 97精品视频在线 | 精品国产区 | 1级毛片| 欧美精品免费在线观看 | 亚洲婷婷综合网 | 国产免费自拍 | 一级黄色影片在线观看 | 深夜福利1000 | 成人精品一区二区三区 | 亚洲精品专区 | 国产精品久久久久久久久久久久久久久久 | 一区二区精品视频 | 蜜桃视频网站在线观看 | 国产精品18hdxxxⅹ在线 | 久久久久在线 | 亚洲综合激情网 | 欧美日韩精品一区二区在线播放 | 精品久久久久一区二区三区 | 久久一区二区三区四区 | 99精品欧美一区二区蜜桃免费 | 国产97在线 | 免费 | 国产精品视频导航 | 欧美一级特黄aaaaaaa在线观看 | 国产精品久久免费视频在线 |