Vxe UI vxe-form 实现折叠表单,当表单很多时实现自动收起与展开

Vxe UI vue vxe-form 实现折叠表单,当表单很多时实现自动收起与展开

代码

folding 用于将当前表单项设置为默认隐藏
collapse-node 设置折叠按钮,加上之后会自动在该表单项的右侧显示一个折叠按钮

<template>
  <div>
    <vxe-form
      title-colon
      ref="formRef"
      title-width="100"
      title-align="right"
      :data="formData"
      @submit="submitEvent">
      <vxe-form-item title="名称" field="name" span="12">
        <template #default="params">
          <vxe-input v-model="formData.name"></vxe-input>
        </template>
      </vxe-form-item>
      <vxe-form-item title="昵称" field="nickname" span="12">
        <template #default="params">
          <vxe-input v-model="formData.nickname"></vxe-input>
        </template>
      </vxe-form-item>
      <vxe-form-item title="角色" field="role" span="12" folding>
        <template #default="params">
          <vxe-input v-model="formData.role"></vxe-input>
        </template>
      </vxe-form-item>
      <vxe-form-item title="性别" field="sex" span="12" folding>
        <template #default="params">
          <vxe-input v-model="formData.sex"></vxe-input>
        </template>
      </vxe-form-item>
      <vxe-form-item title="年龄" field="age" span="12" folding>
        <template #default="params">
          <vxe-input v-model="formData.age"></vxe-input>
        </template>
      </vxe-form-item>
      <vxe-form-item title="大小" field="num" span="12" folding>
        <template #default="params">
          <vxe-input v-model="formData.num"></vxe-input>
        </template>
      </vxe-form-item>
      <vxe-form-item title="创建时间" field="createDate" span="12" folding>
        <template #default="params">
          <vxe-input v-model="formData.createDate"></vxe-input>
        </template>
      </vxe-form-item>
      <vxe-form-item title="更新时间" field="updateDate" span="12" folding>
        <template #default="params">
          <vxe-input v-model="formData.updateDate"></vxe-input>
        </template>
      </vxe-form-item>
      <vxe-form-item align="center" span="24" collapse-node>
        <template #default>
          <vxe-button type="submit" status="primary" content="搜索"></vxe-button>
        </template>
      </vxe-form-item>
    </vxe-form>
  </div>
</template>

<script setup>
import { ref } from 'vue'
import { VxeUI } from 'vxe-pc-ui'

const formRef = ref()
const formData = ref({
  name: 'test1',
  role: '',
  nickname: 'Testing',
  sex: '',
  age: '',
  num: '',
  createDate: '',
  updateDate: ''
})

const changeEvent = (params) => {
  const $form = formRef.value
  if ($form) {
    $form.updateStatus(params)
  }
}

const submitEvent = () => {
  VxeUI.modal.message({ content: '保存成功', status: 'success' })
}
</script>

效果如下:

请添加图片描述

配置式表单也是一样的

<template>
  <div>
    <vxe-form v-bind="formOptions" v-on="formEvents" ></vxe-form>
  </div>
</template>

<script setup>
import { reactive } from 'vue'
import { VxeUI } from 'vxe-pc-ui'

const formOptions = reactive({
  titleWidth: 100,
  titleColon: true,
  titleAlign: 'right',
  data: {
    name: 'test1',
    role: '',
    nickname: 'Testing',
    sex: '',
    age: '',
    num: '',
    createDate: '',
    updateDate: ''
  },
  items: [
    { field: 'name', title: '名称', span: 12, itemRender: { name: 'VxeInput' } },
    { field: 'nickname', title: '昵称', span: 12, itemRender: { name: 'VxeInput' } },
    { field: 'role', title: '角色', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    { field: 'sex', title: '性别', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    { field: 'age', title: '年龄', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    { field: 'num', title: '大小', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    { field: 'createDate', title: '创建时间', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    { field: 'updateDate', title: '更新时间', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    {
      align: 'center',
      span: 24,
      collapseNode: true,
      itemRender: {
        name: 'VxeButtonGroup',
        options: [
          { type: 'submit', content: '搜索', status: 'primary' }
        ]
      }
    }
  ]
})

const formEvents = {
  submit () {
    VxeUI.modal.message({ content: '点击搜索', status: 'success' })
  }
}
</script>

也可以使用插槽

<template>
  <div>
    <vxe-form v-bind="formOptions" >
		<template #active>
			<vxe-button status="primary" @click="searchEvent">搜索</vxe-button>
		</template>
    </vxe-form>
  </div>
</template>

<script setup>
import { reactive } from 'vue'
import { VxeUI } from 'vxe-pc-ui'

const formOptions = reactive({
  titleWidth: 100,
  titleColon: true,
  titleAlign: 'right',
  data: {
    name: 'test1',
    role: '',
    nickname: 'Testing',
    sex: '',
    age: '',
    num: '',
    createDate: '',
    updateDate: ''
  },
  items: [
    { field: 'name', title: '名称', span: 12, itemRender: { name: 'VxeInput' } },
    { field: 'nickname', title: '昵称', span: 12, itemRender: { name: 'VxeInput' } },
    { field: 'role', title: '角色', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    { field: 'sex', title: '性别', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    { field: 'age', title: '年龄', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    { field: 'num', title: '大小', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    { field: 'createDate', title: '创建时间', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    { field: 'updateDate', title: '更新时间', span: 12, folding: true, itemRender: { name: 'VxeInput' } },
    { align: 'center', span: 24, collapseNode: true, slots: { default: 'active' } }
  ]
})

const searchEvent = () => {
  VxeUI.modal.message({ content: '搜索', status: 'success' })
}
</script>

查看 https://github.com/x-extends/vxe-pc-ui
查看码云 https://gitee.com/x-extends/vxe-pc-ui

vxe-form是一个基于Vue.js表单组件库,其中包含了多种表单元素,包括下拉框(select)。 使用vxe-form中的下拉框非常简单。首先,需要引入相关的组件。 在Vue的模板中,通过使用vxe-form-item组件包裹下拉框来创建表单项,例如: <vxe-form-item label="性别"> <vxe-select v-model="gender" placeholder="请选择性别"> <vxe-option label="男" value="male"></vxe-option> <vxe-option label="女" value="female"></vxe-option> <vxe-option label="其他" value="other"></vxe-option> </vxe-select> </vxe-form-item> 在上述代码中,我们通过vxe-form-item设置了表单项的Label为“性别”,并且使用了v-model指令将下拉框的选择值绑定到data中的gender变量上,使得选择的值能够在Vue实例中进行使用。 在vxe-select中,我们将每个选项都使用vxe-option组件包裹,其中label属性设置了选项的展示文本,value属性设置了选项的值。 通过上述代码,我们就成功地创建了一个具有下拉框的表单项。当用户在下拉框中进行选择时,Vue实例中对应的gender变量会被更新为所选的值。 除了上述基本的使用方式外,vxe-form的下拉框还支持更多的配置。可以通过设置disabled属性来禁用下拉框,设置clearable属性来显示清除按钮,设置filterable属性来启用可搜索的下拉框等等。 总之,vxe-form中的下拉框使用简单方便,通过设置v-model绑定数据实现数据的双向绑定,可以满足常见的下拉选择需求。同时,通过配置属性,可以进一步定制下拉框的功能和外观。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值