可以拖拽的富文本编辑器(VueDragResize,quill-editor)

该功能实现一个帮助文档的展示和编辑功能,默认进去只能查看帮助文档的内容,点击编辑可以进行富文本编辑器的编辑功能。

  • 出现的问题
  • 1.如何隐藏富文本编辑的工具栏并且禁止编辑
javascript 复制代码
  //隐藏工具栏
    this.toolbar = this.$refs.myTextEditor.quill.getModule('toolbar');
        this.toolbar.container.style.display = 'none';
        
  //禁止富文本编辑器编辑
   onEditorFocus(event) {
            if(this.isEdit){
                event.enable(true);
            }else{
                event.enable(false);
            }
        }, //       
  • ●控制只有顶部可以进拖拽

    ●由于控制了只有头部可以拖拽当点击富文本编辑后VueDragResize失去焦点,无法进行四周的拉伸与收缩
javascript 复制代码
   this.$refs.moveContainer.active=true;
   //每当离开编辑器的时候手动给VueDragResiz赋予可拖拽

完整代码:

javascript 复制代码
<template>
    <div class="container">
        <!--//缩放功能主要是缩放VueDrangResize标签-->
        <VueDragResize class="move-container" :isActive="true" :w="490" :h="690"  :isResizable="true"
            v-on:resizing="resize"    :drag-handle="'.title'" v-on:dragging="resize" ref="moveContainer">
                <div class="title">
                    <div class="text">
                        <span>帮助文档</span>
                    </div>
                    <div class="action-panel" style="text-align: right;height: 30px;">
                        <template v-if="isEdit">
                            <gf-button type="primary" @click="save"> 保存 </gf-button>
                        </template>
                        <gf-button v-else type="primary" @click="handleEdit"> 编辑</gf-button>
                        <gf-button type="primary" @click="cancel"> 取消 </gf-button>
                    </div>
                </div>
                <div class="body" @mouseleave="handleMouseLeave">
                    <slot name="content">
                        <quill-editor ref="myTextEditor" :options="editorOption" v-model="content" :config="editorOption"
                            @focus="onEditorFocus($event)" class="quill-container"></quill-editor>
                    </slot>
                </div>
        </VueDragResize>

    </div>

</template>

<script>
import VueDragResize from 'vue-drag-resize'

export default {
    components: {
        VueDragResize
    },
    props: {
        compTitle: {
            type: String,
            default: ''
        },
        data: {
            type: String,
            default: "<p>每个人都有一份属于自己的责任,需要自己去担当,去完成。只有我们担当起了自己的责任时,才能把事情做好。就像我们学生的'责任主要是抓好学习,教师的责任主要是给学生传授知识,警察的责任主要是维护社会治安,而清洁工人的责任主要是打扫卫生...孙中山先生说过:"我辈既以担当中国改革发展为己任,虽石烂海枯,而此身尚存,此心不死。既不可以失败而灰心,亦不能以困难而缩步。全神贯注,猛力向前,应付世界进步之潮流,合乎善长恶消之天理,则终有最后成功之一日。"孙先生的一席话告诉我:做一件事<img src=\""
        }
    },

    data() {
        return {
            vw: 0,
            vh: 0,
            top: 0,
            left: 0,
            editorOption: {
            },
            isEdit:false,
            helpContent:'',
            toolbar,
            content:''
        }
    },
    created() {
        this.vw = 290 + 'px'
        this.vh = 300 + 'px'
    },
    mounted() {
        this.content = this.data;
        // this.$refs.myTextEditor.quill.enable(false);//解决富文本自动聚焦问题
        this.toolbar = this.$refs.myTextEditor.quill.getModule('toolbar');
        this.toolbar.container.style.display = 'none';
    },
    methods: {
        // 缩小
        resize(newRect) {
            this.vw = newRect.width
            this.vh = newRect.height
            this.top = newRect.top
            this.left = newRect.left

        },
        async save(){
            this.$emit("cancelHelp");
        },
        cancel(){
            this.$emit("cancelHelp");
        },
        onEditorFocus(event) {
            if(this.isEdit){
                event.enable(true);
            }else{
                event.enable(false);
            }
        }, // 获得焦点事件
        handleEdit() {
            this.isEdit = true; // 切换到编辑模式
            this.toolbar.container.style.display = 'block'; // 显示工具栏
        },
        handleMouseLeave(){
            // 使拖拽组件重新获取焦点
            this.$refs.moveContainer.active=true;
        }
    }

}
</script>

<style lang="less" scoped>
.container {
    position: absolute;
    top: 26px; 
    right: 500px; 
    z-index: 9999;
}

.move-container {
    border: 1px solid #A8AED3;
    border-radius: 14px;
    background: #fff;

}
.content-container{
    width: 100%;
    height: 100%;
}

.title{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    height: 40px;
    padding: 4px;
    background: #EFF2FB; 
    cursor: move;
}
.text{
    padding-left:8px;
}
.body {
    width: 100%;
    height: calc(100% - 40px);
    overflow: auto;
}
.quill-container{
    height: 100%;
}

</style>
<style>
.vdr-stick {
    display: none;
    /* 默认隐藏拖拉点 */
}

.move-container:hover .vdr-stick {
    display: block;
    /* 鼠标移入时显示拖拉点 */
}
</style>

效果:

相关推荐
开心工作室_kaic1 小时前
ssm161基于web的资源共享平台的共享与开发+jsp(论文+源码)_kaic
java·开发语言·前端
刚刚好ā1 小时前
js作用域超全介绍--全局作用域、局部作用、块级作用域
前端·javascript·vue.js·vue
沉默璇年2 小时前
react中useMemo的使用场景
前端·react.js·前端框架
yqcoder2 小时前
reactflow 中 useNodesState 模块作用
开发语言·前端·javascript
2401_882727573 小时前
BY组态-低代码web可视化组件
前端·后端·物联网·低代码·数学建模·前端框架
SoaringHeart3 小时前
Flutter进阶:基于 MLKit 的 OCR 文字识别
前端·flutter
会发光的猪。3 小时前
css使用弹性盒,让每个子元素平均等分父元素的4/1大小
前端·javascript·vue.js
天下代码客3 小时前
【vue】vue中.sync修饰符如何使用--详细代码对比
前端·javascript·vue.js
猫爪笔记3 小时前
前端:HTML (学习笔记)【1】
前端·笔记·学习·html
前端李易安4 小时前
Webpack 热更新(HMR)详解:原理与实现
前端·webpack·node.js