应用场景

在这里插入图片描述
如上图,在form表单中 任务名称、任务类型 都可以通过 :rules=“rules” 设置必填和校验格式。但是当任务内容作为子组件 被当前form(父组件)调用时,我们该如何验证 “任务内容” 为必填项。

思路

涉及到父子组件通信就要考虑到通过 this.$emit(event,args)方式。并且要实时校验 文本编辑器中是否有值,如果有值我们需要给出异常提示。并可以根据具体场景:是继续向上给父组件 发出event还是 阻塞表单提交。

子组件代码示例:

<template>
    <div class="editor">
        <div style="border: 1px solid #ccc; margin-bottom: 20px; text-align: left">
            <!-- 工具栏 -->
            <toolbar
                style="border-bottom: 1px solid #ccc"
                :editor="editor"
                :default-config="toolbarConfig"
            />
            <!-- 编辑器 -->
            <editor
                v-model="handle.form.content"
                style="height: 280px; overflow-y: hidden;"
                :default-config="editorConfig"
                @onCreated="onCreated"
                @onChange="onChange"
            />
        </div>
    </div>
</template>

<script>
import axios from 'axios';
import {Editor, Toolbar} from '@wangeditor/editor-for-vue';

export default {
    name: 'NewTaskEditor',
    components: {Editor, Toolbar},
    data() {
        return {
            editor: null,
            toolbarConfig: {
                excludeKeys: [
                    // 上传视频
                    'group-video',
                    'fullScreen'
                ]
            },
            editorConfig: {
            },
            isFirstLoad: true
        };
    },
    props: {
        handle: {
            type: Object,
            default: function () {
                return {};
            }
        }
    },
    created() {
    },
    methods: {
        onCreated(editor) {
            editor.enable();
            this.editor = Object.seal(editor);
        },

        onChange(val) {
        	// 第一次加载
            if (this.isFirstLoad) {
                this.isFirstLoad = false;
            }
            else {
                let text = this.getText(this.handle.form.content);
                console.log(this.isNull(text)); // true表示判空  false表示不为空
                // this.editor.getText() 获取富文本编辑器的内容 .trim() 去掉空格
                if (!this.isNull(text)) {// 如果编辑框有内容
                    this.$emit('changeContent', this.handle.form.content);
                }
                else {// 如果编辑框没有内容
                    this.$emit('changeContent', null);
                }
            }
        },
        // 判断富文本编辑器输入是否为空或回车
        getText(str) {
            return str
                .replace(/<[^<p>]+>/g, '') // 将所有<p>标签 replace ''
                .replace(/<[</p>$]+>/g, '') // 将所有</p>标签 replace ''
                .replace(/&nbsp;/gi, '') // 将所有 空格 replace ''
                .replace(/<[^<br/>]+>/g, ''); // 将所有 换行符 replace ''
        },
        isNull(str) {
            if (str == '') {
                return true;
            }
            let regu = '^[ ]+$';
            let re = new RegExp(regu);
            return re.test(str);
        }
    }
};
</script>

<style src="@wangeditor/editor/dist/css/style.css"></style>

父组件调用示例:

<template>
    <div style="margin-left: 20px; margin-right: 20px">
        <el-form
            ref="ruleFormRef"
            size="mini"
            :model="handle.form"
            label-width="100px"
            label-position="left"
            :rules="rules"
            @open="open"
        >
            <!-- 其他表单信息-->

            <el-form-item label="任务内容" prop="content">
                <new-task-editor
                    :handle="handle"
                    @changeContent="changeContent"
                ></new-task-editor>
                <!-- 错误信息显示-->
                <div v-if="errorMessage" class="el-form-item__error">{{ errorMessage }}</div>
            </el-form-item>
        </el-form>
    </div>
</template>

<script>
import Editor from '@/Editor';

export default {
    name: 'NewTaskStepOneContent',
    components: {Editor},
    watch: {},
    created() {
    },
    data() {
        return {
            current: 0,
            loading: false,
            form: {
                name: '',
                content: '',
            },
            errorMessage: ''
        };
    },
    methods: {
        close() {
            this.$emit('closeDialog', false);
        },
        // 获取富文本内容
        changeContent(val) {
            if (val == null) {
                this.errorMessage = '编辑器内容不能为空!';
                this.$emit('editorEvent', 0);
            }
            else {
                this.errorMessage = '';
                this.$emit('editorEvent', 1);
            }
        }
    }
};
</script>
GitHub 加速计划 / vu / vue
83
16
下载
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
最近提交(Master分支:4 个月前 )
9e887079 [skip ci] 3 个月前
73486cb5 * chore: fix link broken Signed-off-by: snoppy <michaleli@foxmail.com> * Update packages/template-compiler/README.md [skip ci] --------- Signed-off-by: snoppy <michaleli@foxmail.com> Co-authored-by: Eduardo San Martin Morote <posva@users.noreply.github.com> 6 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐