2.0.3 • Published 2 months ago

@qingbing/ts-v3-form-button v2.0.3

Weekly downloads
-
License
MIT
Repository
-
Last release
2 months ago

FormButton 插件介绍

1. 概要说明

1.1 地址

https://gitee.com/duqingbing/ts-v3-package/tree/ts-v3-form-button

1.2 插件描述

vite + ts + vue3 + element-plus 封装的 FormButton 插件

1.3 重要依赖

  • @qingbing/ts-v3-utils: ^1.0.1
  • @qingbing/ts-v3-element-plus: ^2.1.4
  • element-plus: ^2.6.2
  • vue: ^3.4.21

1.4 插件安装

# yarn 安装
yarn add @qingbing/ts-v3-form-button

# npm 安装
npm i @qingbing/ts-v3-form-button

2. 包说明

2.1 属性说明

属性名类型是否必需默认值意义
refFormString'form'控制的表单, 不涉及 reset 或 submit 字段无效
buttonsArray"submit", "reset"显示的按钮组
submitTypeString'primary'submit 按钮类型
submitLabelString'确认'submit 按钮显示
submitCallbackFunction-submit 回调函数
resetTypeString'default'reset 按钮类型
resetLabelString'重置'reset 按钮显示
resetCallbackFunction-reset 回调函数, 普通情况, 使用默认操作方法即可
cancelTypeString'default'cancel 按钮类型
cancelLabelString'取消'cancel 按钮显示
cancelCallbackFunction-cancel 回调函数

2.2 事件说明

事件名类型意义
---

2.3 实例暴露说明

属性名类型意义
--

3. 示例

3.1 全局注册使用

  • 一旦注册, FormButton 作为组件全局通用
  • 使用方法参考 3.2 模板组件使用, 去掉组件导入的语句即可
// main.ts
import { FormButtonPlugin } from '@qingbing/ts-v3-form-button'
app.use(FormButtonPlugin, {
  name: 'FormButton',
  options: {}
})

3.2 模板组件使用

<template>
    <h1>FormButton 组件</h1>
    <el-form :ref="refForm" :model="formData" label-width="120px" label-suffix=":" label-position="left">
        <el-form-item prop="email" label="Email" :rules="[
            {
                required: true,
                message: 'Please input email',
                trigger: 'blur',
            },
            {
                type: 'email',
                message: 'Please input correct email address',
                trigger: ['blur', 'change'],
            },
        ]">
            <el-input v-model="formData.email" />
        </el-form-item>
        <el-form-item prop="username" label="Username" :rules="[
            {
                required: true,
                message: 'Please input username',
                trigger: 'blur',
            },
        ]">
            <el-input v-model="formData.username" />
        </el-form-item>

        <el-form-item>
            <FormButton :buttons="buttons" :submitCallback="submitCallback" ref-form="ref-form" />
        </el-form-item>
    </el-form>
    <hr>
    <el-form :ref="refForm1" :model="formData1" label-width="120px" label-suffix=":" label-position="left">
        <el-form-item prop="username" label="Username" :rules="[
            {
                required: true,
                message: 'Please input username',
                trigger: 'blur',
            },
        ]">
            <el-input v-model="formData1.username" />
        </el-form-item>

        <el-form-item>
            <FormButton :buttons="buttons1" :submitCallback="submitCallback1" ref-form="ref-form1" />
        </el-form-item>
    </el-form>
</template>
  
<script lang="ts" setup>
import type { TFormButtonButtons, TFormButtonSubmitParams } from "@qingbing/ts-v3-form-button";
import { reactive, ref } from 'vue'
import { FormButton } from "@qingbing/ts-v3-form-button";

const refForm = ref('ref-form')

const formData = reactive<{
    email: string
    username: string
}>({
    email: '',
    username: 'qingbing',
})
const buttons: TFormButtonButtons = [
    "submit",
    "cancel",
    "reset",
    {
        "label": "TEST",
        callback: () => {
            console.log(222);
        }
    }
];
const submitCallback = (params: TFormButtonSubmitParams) => {
    console.log(params);
    params.callFailure("哦河, 操作失败了")
}


const refForm1 = ref('ref-form1')
const formData1 = reactive<{
    username: string
}>({
    username: '',
})
const buttons1: TFormButtonButtons = [
    "submit",
    "cancel",
    {
        "label": "TEST",
        callback: () => {
            console.log(111);
        }
    }
];
const submitCallback1 = (params: TFormButtonSubmitParams) => {
    console.log(params);
    params.callSuccess("哦业, 操作成功了")
}

</script>