@qingbing/ts-v3-form-button
TypeScript icon, indicating that this package has built-in type declarations

2.0.3 • Public • Published

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 属性说明

属性名 类型 是否必需 默认值 意义
refForm String 'form' 控制的表单, 不涉及 reset 或 submit 字段无效
buttons Array ["submit", "reset"] 显示的按钮组
submitType String 'primary' submit 按钮类型
submitLabel String '确认' submit 按钮显示
submitCallback Function - submit 回调函数
resetType String 'default' reset 按钮类型
resetLabel String '重置' reset 按钮显示
resetCallback Function - reset 回调函数, 普通情况, 使用默认操作方法即可
cancelType String 'default' cancel 按钮类型
cancelLabel String '取消' cancel 按钮显示
cancelCallback Function - 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>

Package Sidebar

Install

npm i @qingbing/ts-v3-form-button

Weekly Downloads

3

Version

2.0.3

License

MIT

Unpacked Size

18 kB

Total Files

5

Last publish

Collaborators

  • qingbing