wangEditor是基于javascript和css开发的 Web富文本编辑器, 轻量、简洁、易用、开源免费。
在我们实际项目上还是比较频繁应用到的,下面出个案例供大家参考学习…
wangEditor文档:https://www.wangeditor.com/
富文本编辑器截图:
<!--富文本编辑器。http://www.wangeditor.com/
使用示例:
<AppEditor v-model="content"></AppEditor>
-->
<template>
<article ref="editor" class="AppEditor-root"></article>
</template>
<script>
const E = require('wangeditor');
export default {
name: 'AppEditor',
model: {
prop: 'value',
event: 'update:value',
},
props: {
// value值,v-model绑定
value: {type: String, default: ''},
// 菜单选项
menus: {
type: Array,
default(){
return [
'bold', // 粗体
'italic',//斜体
'underline',//下划线
'fontSize', // 字号
'strikeThrough',//删除线
'image', // 插入图片
'undo', // 撤销
// 'fontName', // 字体
// 'italic', // 斜体
// 'underline', // 下划线
// 'strikeThrough', // 删除线
// 'foreColor', // 文字颜色
// 'backColor', // 背景颜色
// 'link', // 插入链接
// 'list', // 列表
// 'justify', // 对齐方式
// 'quote', // 引用
// 'emoticon', // 表情
// 'image', // 插入图片
// 'table', // 表格
// 'video', // 插入视频
// 'code', // 插入代码
// 'undo', // 撤销
// 'redo', // 重复
];
},
},
},
data(){
return {
editor: {}, // 编辑器对象
_value: '', // 内容备份,用于watch时候判断,只在编辑器输入时改变
};
},
computed: {},
mounted(){
this.initEditor();
},
watch: {
value(newValue, oldValue){
// 编辑器onchange更改的不处理,只处理父组件传来的,防止文字回退bug
if (newValue != this._value) {
this.editor.txt.html(newValue);
}
},
},
methods: {
initEditor(){
let editor = new E(this.$refs.editor);
Object.assign(editor.customConfig, {
menus: this.menus,
zIndex: 100,
height: 200,
pasteFilterStyle: false,
onchange: (html) => {
this._value = html; // 更新 _value
this.$emit('update:value', html); // 更新 value
},
customUploadImg:((file, insert)=> {
if(this.$utils.isEmpty(file)){
return;
}
const msg = this.$Message.loading({
content: '亲,图片正在拼命地上传中,请稍等...',
duration: 0
});
var params = new FormData();
params.append('img', file[0]);
this.$api.post('/synthesis/crm/picture/pictureUpload',params).then(res => {
insert(res.data.imgUrl)
setTimeout(msg, 0);
this.$Message.success('上传成功');
})
}),
uploadImgHooks:{
customInsert: function (insertImg, result, editor) {
insertImg(result.url)
}
}
});
editor.create();
editor.txt.html(this.value); // 针对数据异步获取的这里无法立即绑定,在watch判断处理
this.editor = editor;
},
},
};
</script>
<style scoped lang="scss">
.AppEditor-root{ border: 1px solid #f0f0f0; height: 400px !important;
/deep/ .w-e-toolbar{ border: none !important; border-bottom: 1px solid #f0f0f0 !important; background-color: #fff !important;
}
/deep/ .w-e-text-container{ height: calc(100% - 43px) !important; border: none !important; z-index:1 !important;
.w-e-text{ height: 100%; overflow-y: auto !important;}
}
}
</style>
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
桃源资源网 Design By www.nqtax.com
暂无“Vue中使用wangeditor富文本编辑的问题”评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。


