zoukankan      html  css  js  c++  java
  • vue3+ts添加公共富文本组件

    vue3+ts添加公共富文本组件

    下载

    npm install wangeditor --save-dev
    复制代码

    新建一个editor.vue 的组件

    <style scoped>
    .part_right {
         100%;
        background: #f2f2f2;
        min-height: 100vh;
    }
    .list {
        96%;
        margin: 0 auto;
    
    /* background: gray; */
    padding-top: 50px;
    

    }
    .list ul li{
    list-style-type: none;
    display: flex;
    border-bottom: 1px solid #e6e5e5;
    min-height: 50px;
    background: #d5d5d5;
    }
    .list ul li>div{
    flex: 1;
    line-height: 50px;
    }
    .list ol li{
    list-style-type: none;
    display: flex;
    border-bottom: 1px solid #e6e5e5;
    min-height: 30px;
    }
    .list ol li>div{
    flex: 1;
    line-height: 30px;
    }
    .flright {
    float: right;
    margin-right: 2%;
    }
    </style>
    <template>
    <div>
    <div className="shop">
    <div className="text-area" >
    <div ref="editorElemMenu"
    style="backgroundColor: '#f1f1f1'; border:'1px solid #ccc'"
    className="editorElem-menu">
    </div>
    <div style="height: 300;border: '1px solid #ccc',borderTop: 'none'" ref="editorElemBody" className="editorElem-body">
    </div>
    </div>
    </div>
    </div>

    </template>

    <script lang="ts">

    import { onMounted ,reactive,toRefs,defineComponent,ref} from 'vue'
    import E from 'wangeditor'

    interface DataProps {
    editor: any;
    editorContent: string
    getContent:(ref?: any) => void
    }

    export default defineComponent({
    name:'Editor',
    components: {
    },
    props: {
    options: Object,
    value: String,
    },
    setup(props, { emit }) {
    const editorElemMenu = ref();
    const editorElemBody = ref();
    const data: DataProps = reactive({
    editorContent: '',
    editor:{},
    getContent:() => {
    console.log("111",props)
    data.editor.txt.html(props.value)
    }
    })
    onMounted(() => {
    let _this = this;
    const elemMenu = editorElemMenu.value;
    const elemBody = editorElemBody.value;
    data.editor = new E(elemMenu, elemBody)
    // 使用 onchange 函数监听内容的变化,并实时更新到 state 中
    data.editor.config.onchange = (html: any) => {
    console.log(data.editor.txt.html())
    data.editorContent = data.editor.txt.html()
    // 向外部返回一个处理过的值
    emit('onEditor', data.editor.txt.html())
    emit('update:value', data.editor.txt.html())
    }
    data.editor.config.customUploadImg = function (files: any, insert: any ) {
    // files 是 input 中选中的文件列表insert 是获取图片 url 后,插入到编辑器的方法
    // let file;
    // if (files && files.length) {
    // file = files[0];
    // } else {
    // return
    // }
    // 图片上传
    console.log("files1",files)

                          const formData = new FormData();
                          formData.append('file', files[0]);
                          console.log("files",files,insert)
                          // formData.append('Banners',{id:editorinfo.id,naviChildId:editorinfo.naviChildId})
                      }
    
                    data.editor.config.menus = [
                        'head',  // 标题
                        'bold',  // 粗体
                        'fontSize',  // 字号
                        'fontName',  // 字体
                        'italic',  // 斜体
                        'underline',  // 下划线
                        'strikeThrough',  // 删除线
                        'foreColor',  // 文字颜色
                        'backColor',  // 背景颜色
                        'link',  // 插入链接
                        'list',  // 列表
                        'justify',  // 对齐方式
                        'quote',  // 引用
                        'emoticon',  // 表情
                        'image',  // 插入图片
                        'table',  // 表格
                        'video',  // 插入视频
                        'code',  // 插入代码
                        'undo',  // 撤销
                        'redo'  // 重复
                    ]
                    data.editor.config.uploadImgShowBase64 = true
                    data.editor.create()
    
                    // data.getContent()
        })
        const refData = toRefs(data);
        return {
            ...refData,
            editorElemMenu,
            editorElemBody
        }
    }
    

    })
    </script>

    复制代码

    调用的组件

    <style scoped>
    

    </style>

    <template>
    <div class="part_right">
    <Editor ref="Editor" :value="content" @onEditor="onEditor"/>
    </div>
    </template>
    <script lang="ts">

    import { onMounted ,reactive,toRefs,defineComponent,ref} from 'vue'
    import Editor from '@/components/tool/editor.vue'

    interface DataProps {
    content: string;
    showBack:(ref?: any) => void
    }

    export default defineComponent({
    name:'about',
    components: {
    Editor
    },
    setup() {
    const Editor = ref();
    const data: DataProps = reactive({
    content:'1',
    //获取富文本中的内容
    onEditor:(value: string) => {
    console.log("父组件",value)
    },
    // 富文本回显
    showBack:() => {
    data.content = '回显内容公众号qdleader'
    console.log(" data.content", data.content)
    setTimeout(() =>{
    Editor.value.getContent()
    })

            }
        })
    
        onMounted(() =&gt; {
            data.showBack()
        })
        const refData = toRefs(data);
        return {
            ...refData,
            Editor
        }
    }
    

    })
    </script>

    复制代码

    这样就完成可以在vue3加ts中使用 富文本啦

    拓展。。

    有的同学需要自定义上传图片的接口

    ```

    data.editor.config.customUploadImg = function (files: any, insert: any ) {
            // files 是 input 中选中的文件列表insert 是获取图片 url 后,插入到编辑器的方法
            // let file;
            // if (files && files.length) {
            //     file = files[0];
            // } else {
            //     return
            // }
            // 图片上传
            console.log("files1",files)
    
        const formData = new FormData();
        formData.append('file', files[0]);
        console.log("files",files,insert)
        // formData.append('Banners',{id:editorinfo.id,naviChildId:editorinfo.naviChildId})
    
        // 把请求你们服务器地址获得的图片链接,替换到下面src里面即可
      data.editor.txt.append("&lt;img src='https://rmxgh-1305579889.cos.ap-beijing.myqcloud.com/img/64bec1a86509170772c19fc5f88d84e1.jpg' /&gt;")
    
    }
    

    ```

    扫码加群或领资料

    微信图片_20200331101947.png



  • 相关阅读:
    论程序员的自我修养
    设计模式之:行为型设计模式(11种)
    设计模式之:结构型设计模式(7种)
    @import "../style/lines.scss" 导致background: url()路径无效问题
    node express 设置重定向
    png8和png24的区别
    vue scss 使用 及 踩坑
    js 防抖 节流
    js 次方 开方 对数
    css 修改placeholder样式
  • 原文地址:https://www.cnblogs.com/bbqq1314/p/15030736.html
Copyright © 2011-2022 走看看