当前位置: 首页 > news >正文

民权网站建设百度云登录入口

民权网站建设,百度云登录入口,hao123从上网官网,java做的网站的好处在Vue.js项目中,表单是与用户交互的重要部分,特别是在需要动态管理表单项的场景下,如何优雅地实现添加、删除、上移、下移及验证功能变得尤为重要。本文将详细介绍如何使用Element UI来实现一个包含动态表单项管理以及验证功能的表单。 效果…

在Vue.js项目中,表单是与用户交互的重要部分,特别是在需要动态管理表单项的场景下,如何优雅地实现添加、删除、上移、下移及验证功能变得尤为重要。本文将详细介绍如何使用Element UI来实现一个包含动态表单项管理以及验证功能的表单。

效果图如下

一、项目背景

假设我们正在开发一个活动管理系统,其中一个功能是为活动添加多条路线信息,每条路线包含路线名称、可参加人数和路线详情。用户需要能够动态地添加、删除、调整路线顺序,并且需要对所有表单项进行验证。

二、实现步骤
  1. 项目初始化

    首先,确保你的Vue项目已经安装了Element UI。如果未安装,可以通过以下命令进行安装:

    npm install element-ui --save
     

    然后在main.js中引入Element UI:

    import Vue from 'vue'; 
    import ElementUI from 'element-ui'; 
    import 'element-ui/lib/theme-chalk/index.css'; Vue.use(ElementUI);

  2. 模板结构

    在组件的template部分,使用Element UI的el-form、el-descriptions、el-row、el-col、el-form-item、el-input等组件来构建表单。特别地,使用v-for指令来动态渲染表单项,并使用slot插槽来添加“新增”按钮。

    <template> <!-- 省略了部分代码,详细代码见文末 --> </template>
  3. 数据定义

    在data函数中定义表单数据form和验证规则rules。form中包含activityTravelLines数组,用于存储路线信息。rules中定义了表单项的验证规则。

    data() {  return {  form: {  activityTravelLines: [  {  name: "",  limitNumber: "",  lineDetail: "",  rulesId: 0,  },  ],  //其他字段  },  arrayFieldRulesId: 0,  rules: {  //其他验证规则  },  };  
    },

  4. 初始化数据

    在created钩子中,调用initData方法初始化数据。如果有初始化数据(如通过接口获取),则遍历activityTravelLines数组,为每一项添加rulesId,并更新验证规则。

    created() {  this.initData();  this.updateRules(); // 更新验证规则  
    },  
    methods: {  initData() {  // 省略了部分代码,详细代码见文末  },  // 其他方法...  
    }
  5. 动态管理表单项

    提供addItem、removeItem、moveUp、moveDown方法来实现表单项的添加、删除、上移、下移功能。每次操作后,都需要调用updateRules方法来更新验证规则。

    methods: {  // 省略了部分代码,详细代码见文末  addItem() {  // 省略了部分代码,详细代码见文末  },  removeItem(index) {  // 省略了部分代码,详细代码见文末  },  moveUp(index) {  // 省略了部分代码,详细代码见文末  },  moveDown(index) {  // 省略了部分代码,详细代码见文末  },  // 其他方法...  
    }
  6. 表单验证

    在submit方法中,使用this.$refs.form.validate方法来验证表单。如果验证通过,则执行提交操作。

    methods: {  // 省略了部分代码,详细代码见文末  submit() {  this.$refs["form"].validate((valid) => {  if (valid) {  //你的提交代码  console.log(this.form, "提交form表单");  }  });  },  
    }
  7. 样式定义

    使用SCSS来定义表单的样式,确保表单项之间的间距和布局合理。

    <style lang="scss" scoped>  
    .btnCont {  display: flex;  justify-content: space-between;  align-items: center;  margin-bottom: 5px;  .titleIndexCont {  font-family: PingFang SC, PingFang SC;  font-weight: 400;  font-size: 20px;  color: #333333;  }  
    }  
    </style>
三、完整代码
<template><div class="container"><el-form ref="form" :model="form" :rules="rules" label-width="120px"><el-descriptions title="路线信息" :column="2"><template slot="extra"><el-button type="primary" @click="addItem" size="mini">新 增</el-button></template></el-descriptions><divv-for="(item, index) in form.activityTravelLines":key="item.rulesId"><div class="btnCont"><div class="titleIndexCont">{{ "路线" + (index + 1) }}</div><div><el-buttontype="danger"icon="el-icon-delete"size="mini"@click="removeItem(index)"></el-button><el-buttontype="success"icon="el-icon-top"size="mini"@click="moveUp(index)"></el-button><el-buttontype="success"icon="el-icon-bottom"size="mini"@click="moveDown(index)"></el-button></div></div><el-row><el-col :span="12"><el-form-itemlabel="路线名称:":prop="`activityTravelLines.${index}.name`"><el-input v-model="item.name"></el-input></el-form-item></el-col><el-col :span="12"><el-form-itemlabel="可参加人数":prop="`activityTravelLines.${index}.limitNumber`"><el-inputv-model="item.limitNumber"type="number":min="0"></el-input></el-form-item></el-col></el-row><el-form-itemlabel="路线详情:":prop="`activityTravelLines.${index}.lineDetail`"><el-inputv-model="item.lineDetail"type="textarea"placeholder="请输入内容"maxlength="300":rows="5"show-word-limit></el-input></el-form-item></div><!-- 其他el-form-item --></el-form><div class="footer"><el-button type="primary" @click="submit">确 定</el-button></div></div>
</template>
<script>
export default {data() {return {form: {activityTravelLines: [{name: "",limitNumber: "",lineDetail: "",rulesId: 0,},],//其他字段},arrayFieldRulesId: 0,rules: {//其他验证规则},};},created() {this.initData();this.updateRules(); // 更新验证规则},mounted() {},methods: {initData() {//如果有初始化数据,要遍历form.activityTravelLines,在每一项里面添加rulesIdif (this.id) {//假设getTravelDetail是你的详情接口getTravelDetail(this.id).then((res) => {this.form = res?.data ?? {};this.form.activityTravelLines = res?.data?.activityTravelLines ?? [];this.form.activityTravelLines.map((item, index) => {item.rulesId = index;});this.arrayFieldRulesId = this.form.activityTravelLines.length - 1;this.updateRules(); // 更新验证规则});}},// 添加表单项addItem() {this.arrayFieldRulesId++;this.form.activityTravelLines.push({name: "",limitNumber: "",lineDetail: "",rulesId: this.arrayFieldRulesId,});this.updateRules(); // 更新验证规则},// 删除表单项removeItem(index) {if (this.form.activityTravelLines.length == 1) {this.$message({ message: "不能小于一条路线", type: "warning" });return;}this.form.activityTravelLines.splice(index, 1);this.updateRules(); // 更新验证规则},// 上移表单项moveUp(index) {if (index > 0) {const movedItem = this.form.activityTravelLines.splice(index, 1)[0];this.form.activityTravelLines.splice(index - 1, 0, movedItem);this.updateRules(); // 更新验证规则}},// 下移表单项moveDown(index) {if (index < this.form.activityTravelLines.length - 1) {const movedItem = this.form.activityTravelLines.splice(index, 1)[0];this.form.activityTravelLines.splice(index + 1, 0, movedItem);this.updateRules(); // 更新验证规则}},// 更新验证规则updateRules() {// 为每个表单项添加验证规则this.form.activityTravelLines.forEach((item, index) => {this.rules[`activityTravelLines.${index}.name`] = [{ required: true, message: "路线名称不能为空", trigger: "blur" },];this.rules[`activityTravelLines.${index}.limitNumber`] = [{ required: true, message: "可参加人数不能为空", trigger: "blur" },];});},submit() {this.$refs["form"].validate((valid) => {if (valid) {//你的提交代码console.log(this.form, "提交form表单");}});},},
};
</script>
<style lang="scss" scoped>
.btnCont {display: flex;justify-content: space-between;align-items: center;margin-bottom: 5px;.titleIndexCont {font-family: PingFang SC, PingFang SC;font-weight: 400;font-size: 20px;color: #333333;}
}
</style>
四、总结

本文详细介绍了如何在Vue.js项目中使用Element UI实现一个包含动态表单项管理以及验证功能的表单。通过动态渲染表单项、管理表单项的顺序、以及进行表单验证,我构建了一个灵活且功能强大的表单组件。希望这篇文章能帮助你在项目中更好地处理类似的需求。

http://www.dinnco.com/news/24778.html

相关文章:

  • 在哪个网站做兼职淘宝客服seo怎么优化步骤
  • 怎么做网站 ppt互联网seo是什么意思
  • wordpress 影楼主题seo搜索优化公司报价
  • 小程序免费制作平台登录网站关键词如何优化
  • dreamweaver网站建设教程蜂蜜网络营销推广方案
  • 咸阳企业网站设计开发制作24小时最新国际新闻
  • 做瞹瞹视频电影邪恶网站品牌推广方案案例
  • 国际物流公司网站武汉网络推广自然排名
  • 查看网站的注册时间市场调研公司
  • 手机价格网站建设杭州seo网站优化
  • 湖北武汉企业网站建设百度网址安全检测
  • 网站ping怎么做作品推广
  • 小型深圳网站定制开发seo 关键词优化
  • 杭州 洛阳网站建设公司 网络服务常用的营销策略
  • 装饰工程施工进度计划表武汉网站seo
  • 建设部网站王尚春搜索关键词优化服务
  • 在凡科建设网站的流程苏州排名搜索优化
  • 广州一起做网店网站官方近三天发生的重要新闻
  • 合肥企业网站建设工作室电商平台推广公司
  • 做企业网站大约多少钱如何进行百度推广
  • wordpress 建站公司seo关键词排名优
  • 做电子商务网站需要什么手续百度识图软件
  • apmserv安装wordpress深圳优化怎么做搜索
  • 新浪云服务器做网站seo优化是啥
  • 天津网站建设是什么广州网络运营课程培训班
  • 小程序网站建设的公司seo权威入门教程
  • wordpress 4.8.3学校seo推广培训班
  • 网络营销推广策略包括哪些深圳百度网站排名优化
  • asp.net网站开发框架浙江网站建设营销
  • 个人软件外包接单平台seo站长工具查询