vue3 使用wangEditor

  1. 创建wangEditor.vue文件。

<template>
    <div style="border: 1px solid #ccc">
    <!-- 工具栏 -->
    <!-- :defaultConfig="toolbarConfig" -->
    <Toolbar
        :editor="editorRef"
        style="border-bottom: 1px solid #ccc"
    />
    <!-- 编辑器 -->
    <Editor
        v-model="valueHtml"
        :defaultConfig="editorConfig"
        :style="`height:${props.height}px;overflow-y: hidden;`"
        @onCreated="handleCreated"
        @onChange="handleChange"
    />
</div>
</template>
<script setup>
import { onBeforeUnmount, ref, shallowRef, onMounted ,defineProps,defineEmits} from 'vue'
import { Editor, Toolbar } from '@wangeditor/editor-for-vue'
const props = defineProps({
    height:{
        type:String,
        default:'400'
    },
    data:{
        type:String,
        default:'<p>模拟 Ajax 异步设置内容</p>'
    }
})
const emit = defineEmits(['valueHtmlChange'])
// change事件,通知父页面事件
const handleChange = (editor) => {
    emit('valueHtmlChange',valueHtml)
}
// 编辑器实例,必须用 shallowRef,重要!
const editorRef = shallowRef()

// 内容 HTML
const valueHtml = ref('<p>hello</p>')

// 模拟 ajax 异步获取内容
onMounted(() => {
setTimeout(() => {
    valueHtml.value = props.data
}, 1500)
})

// 编辑器配置
const editorConfig = {
placeholder: '请输入内容...',
/* 菜单配置 */
MENU_CONF: {  }
}

const handleCreated = (editor) => {
editorRef.value = editor // 记录 editor 实例,重要!
}

// 组件销毁时,及时销毁编辑器
onBeforeUnmount(() => {
const editor = editorRef.value
if (editor == null) return
editor.destroy()
})
</script>

记得引入css。

<style src="@wangeditor/editor/dist/css/style.css">
</style>
  1. 父页面调用:

<template>
        <div>
            <WangEditor height="500" @valueHtmlChange="valueHtmlChange"></WangEditor>
        </div>
</template>
<script setup>
import WangEditor from '../../components/wangEditor.vue';
const valueHtmlChange = (val)=>{
 console.log(val)
}
</script>
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值