项目实现|利用el-form+el-popover实现一个简单的弹框🎉

3.1 需求

效果:

3.2 实现

父组件:

父组件设计包含一个按钮,一个el-popover、一个子组件

xml 复制代码
  <div>
    <el-popover placement="bottom" trigger="click" ref="popover">
      <dialog-comp @save="save" ref="dialog"></dialog-comp>
      <el-button slot="reference" type="primary" size="mini">点击出现弹框</el-button>
    </el-popover>
  </div>

父组件的工作:

拿到子组件提交的值;关闭popover、清空子组件弹框的数据

kotlin 复制代码
   save (v) {
      this.inputValue = v.value
      this.$refs.popover.doClose() // 关闭弹框
      this.$refs.dialog.reset() // 清空数据
    }

子组件:

子组件由一个单纯的表单组成

xml 复制代码
  <el-form :model="form" ref="form" size="small" :rules="rules">
    <el-form-item label="作业名称" prop="value" required>
      <el-input v-model="form.value"></el-input>
    </el-form-item>
    <el-form-item>
      <el-button type="primary" @click="save" style="float: right" >保存</el-button>
    </el-form-item>
  </el-form>

子组件的工作:

完成表单的校验和提交表单的数据

kotlin 复制代码
    save () {
      this.$refs.form.validate((valid) => {
        if (valid) {
          this.$emit('save', this.form)
        } else {
          return false
        }
      })
    },

抛出一个清空表单的方法,便于调用

kotlin 复制代码
    reset () {
      this.$refs.form.resetFields()
    }

完整的代码如下:

父组件:

xml 复制代码
<template>
  <div class="about" ref="box">
    <el-input v-model="inputValue" style="margin-bottom: 50px"></el-input>
    <el-popover placement="bottom" trigger="click" ref="popover">
      <dialog-comp @save="save" ref="dialog"></dialog-comp>
      <el-button slot="reference" type="primary" size="mini"
        >点击出现弹框</el-button
      >
    </el-popover>
  </div>
</template>
<script>
import DialogComp from '@/components/DialogComp.vue'
export default {
  components: {
    DialogComp
  },
  data () {
    return {
      inputValue: ''
    }
  },
  methods: {
    save (v) {
      console.log(v)
      this.inputValue = v.value
      this.$refs.popover.doClose() // 关闭弹框
      this.$refs.dialog.reset() // 清空数据
    }
  }
}
</script>
<style scoped>
.about {
  width: 500px;
  margin: auto;
}
</style>
​

子组件:

xml 复制代码
<!--  -->
<template>
  <el-form :model="form" ref="form" size="small" :rules="rules">
    <el-form-item label="作业名称" prop="value" required>
      <el-input v-model="form.value"></el-input>
    </el-form-item>
    <el-form-item>
      <el-button type="primary" @click="save" style="float: right"
        >保存</el-button
      >
    </el-form-item>
  </el-form>
</template>
​
<script>
export default {
  data () {
    return {
      form: {
        value: ''
      },
      rules: {
        vaule: {
          required: true,
          message: '必填',
          trigger: blur
        }
      }
    }
  },
  methods: {
    save () {
      this.$refs.form.validate((valid) => {
        if (valid) {
          this.$emit('save', this.form)
        } else {
          return false
        }
      })
    },
    reset () {
      this.$refs.form.resetFields()
    }
  }
}
</script>
​
相关推荐
majingming1237 小时前
FUNCTION
java·前端·javascript
A_nanda8 小时前
Vue项目升级
前端·vue3·vue2
SuperEugene8 小时前
Axios 接口请求规范实战:请求参数 / 响应处理 / 异常兜底,避坑中后台 API 调用混乱|API 与异步请求规范篇
开发语言·前端·javascript·vue.js·前端框架·axios
abigale039 小时前
【浏览器 API / 网络请求 / 文件处理】前端文件上传全流程:从基础上传到断点续传
前端·typescript·文件上传·vue cli
子兮曰9 小时前
Bun v1.3.11 官方更新全整理:新增功能、关键修复与升级验证
javascript·node.js·bun
Setsuna_F_Seiei9 小时前
AI 对话应用之页面滚动交互的实现
前端·javascript·ai编程
新缸中之脑9 小时前
追踪来自Agent的Web 流量
前端
wefly201710 小时前
从使用到原理,深度解析m3u8live.cn—— 基于 HLS.js 的 M3U8 在线播放器实现
java·开发语言·前端·javascript·ecmascript·php·m3u8
英俊潇洒美少年10 小时前
vue如何实现react useDeferredvalue和useTransition的效果
前端·vue.js·react.js
英俊潇洒美少年11 小时前
ref 底层到底是怎么变成响应式的?
vue.js