Vue有关子组件向父组件传值问题(已解决)

简介: Vue有关子组件向父组件传值问题(已解决)
今天在写后台的时候,遇到一个问题,页面是tab进行切换的,然后很多类似的代码,于是我这边就抽出一个单独的页面进行编写,但是后面写完之后,需要根据子组件的筛选条件进行表单数据的渲染,查了有关资料,完美解决 :以下是解决方案:

父组件

<el-tabs v-model="activeName" @tab-click="handleClick" type="border-card">
      <el-tab-pane label="全部" name="all">
        <all :receive="receive"></all>
      </el-tab-pane>
      <el-tab-pane label="签署中" name="sign">
        <sign :receive="receive"></sign>
      </el-tab-pane>
      <el-tab-pane label="已完成" name="comple">
        <comple :receive="receive"></comple>
      </el-tab-pane>
      <el-tab-pane label="即将截至签署" name="cutOff">
        <cutOff :receive="receive"></cutOff>
      </el-tab-pane>
    </el-tabs>
  methods: {
    //接受子组件传来的搜索条件
    receive(searchInfo) {
      console.log("this.$refs.allInfo:", searchInfo);
      //todo逻辑操作
    },
   }

子组件

<template>
  <el-card class="box-card">
        <el-form-item label="生效日期" v-show="showSearch">
          <el-date-picker
            v-model="form.effectivetime"
            value-format="yyyy-MM-dd HH:mm:ss"
            type="datetimerange"
            start-placeholder="开始日期"
            end-placeholder="结束日期"
            :default-time="['00:00:00']"
          >
          </el-date-picker>
        </el-form-item>
        <el-form-item label="到期日期" v-show="showSearch">
          <el-date-picker
            v-model="form.expiretime"
            value-format="yyyy-MM-dd HH:mm:ss"
            type="datetimerange"
            start-placeholder="开始日期"
            end-placeholder="结束日期"
            :default-time="['00:00:00']"
          >
          </el-date-picker>
        </el-form-item>
  </el-card>
</template>
<script>
export default {
  name: "all",
  props: ["receive"],//接受父组件定义的变量
  data() {
    return {
      form: {
        status:"",
        effectiveStartTime: "",
        effectiveEndTime: "",
        expiryStartTime: "",
        expiryEndTime: "",
      },
      showSearch: false,
    };
  },
  created() {},
  methods: {
    handleQuery() {
      // 调用传入的函数,将name传递给父组件
      this.receive(this.form);
      //这样 父组件 在receive(){}方法中就可以获取到子组件传来的数值信息了~
    },
};
</script>


相关文章
|
2月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
303 2
|
1月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
280 137
|
4月前
|
人工智能 JSON JavaScript
VTJ.PRO 首发 MasterGo 设计智能识别引擎,秒级生成 Vue 代码
VTJ.PRO发布「AI MasterGo设计稿识别引擎」,成为全球首个支持解析MasterGo原生JSON文件并自动生成Vue组件的AI工具。通过双引擎架构,实现设计到代码全流程自动化,效率提升300%,助力企业降本增效,引领“设计即生产”新时代。
404 1
|
4月前
|
JavaScript 安全
在 Vue 中,如何在回调函数中正确使用 this?
在 Vue 中,如何在回调函数中正确使用 this?
259 0
|
JavaScript
纯vue以及vue+laravel父组件往子组件传递图片路径
纯vue以及vue+laravel父组件往子组件传递图片路径
|
5月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
778 0
|
7月前
|
JavaScript
vue实现任务周期cron表达式选择组件
vue实现任务周期cron表达式选择组件
1010 4
|
5月前
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
6月前
|
JavaScript 数据可视化 前端开发
基于 Vue 与 D3 的可拖拽拓扑图技术方案及应用案例解析
本文介绍了基于Vue和D3实现可拖拽拓扑图的技术方案与应用实例。通过Vue构建用户界面和交互逻辑,结合D3强大的数据可视化能力,实现了力导向布局、节点拖拽、交互事件等功能。文章详细讲解了数据模型设计、拖拽功能实现、组件封装及高级扩展(如节点类型定制、连接样式优化等),并提供了性能优化方案以应对大数据量场景。最终,展示了基础网络拓扑、实时更新拓扑等应用实例,为开发者提供了一套完整的实现思路和实践经验。
835 77
|
7月前
|
缓存 JavaScript 前端开发
Vue 基础语法介绍
Vue 基础语法介绍