获取父子组件的实例化对象

一.$ref获取子组件的实例化对象

代码:

App.Vue

<template>
  <div class="">
    <One ref="xxx"></One>
  </div>
</template>

<script>
import One from "@/components/One.vue";
export default {
  name: "",
  components: {
    One,
  },
  mounted() {
    console.log(this.$refs.xxx);
  },
  methods: {},
};
</script>

<style scoped></style>

One.vue

<template>
  <div class="">
    <h1>张123</h1>
  </div>
</template>

<script>
export default {
  data() {
    return {
      name: "不分手的恋爱",
    };
  },
  name: "",
  methods: {
    fn() {
      
    },
  },
};
</script>

<style scoped></style>

打印之后的结果:

 调用变量:

 mounted() {
    console.log(this.$refs.xxx.name);
 },

 调用函数:

 mounted() {
    console.log(this.$refs.xxx.fn());
  },

如果是在一个标签上呢?

代码:

<template>
  <div class="">
    <h1 ref="xxx">没有你以后我灵魂失控</h1>
  </div>
</template>

<script>
export default {
  mounted() {
    console.log(this.$refs.xxx);
  },
  name: "",
  methods: {},
};
</script>

<style scoped></style>

获取到的是一个真实Dom:

总结:

1.如果在组件上加ref获取到是这个组件的实例化对象,可以使用组件的变量和方法

2.如果加在一个标签上获取的是这个标签的真实Dom

二.$parent获取父组件的实例化对象

父组件:

<template>
  <div class="">
    <One></One>
    <h1>{{ name }}</h1>
  </div>
</template>

<script>
import One from "@/components/One.vue";
export default {
  data() {
    return {
      name: "你要的全拿走",
    };
  },
  components: {
    One,
  },
  name: "",
  methods: {},
};
</script>

<style scoped></style>

子组件:

<template>
  <div class="">
    <button @click="fn">获取父组件的实力对象</button>
  </div>
</template>

<script>
export default {
  name: "",
  methods: {
    fn() {
      console.log(this.$parent.name);
    },
  },
};
</script>

<style scoped></style>

打印的结果:

说明已经获取到了。

三.在开发中的应用

如:

<template>
  <div class="setting">
    <el-card>
      <el-tabs>
        <el-tab-pane label="角色管理" lazy>
          <el-button
            type="primary"
            size="small"
            @click="addClick"
          >+新增角色</el-button>
          <el-table :data="list">
            <!-- 数据绑定data -->
            <!-- label表示标题 -->
            <!-- prop='对应的字段名' -->
            <!-- 自定义列 -->
            <!-- <template>
                <div v-slot="{$index:索引}:row:当前行数据">

                </div>
              </template> -->
            <el-table-column label="序号" type="index">
              <template v-slot="{ $index }">
                <div>
                  {{ (page.page - 1) * page.pagesize + $index + 1 }}
                </div>
              </template>
            </el-table-column>
            <el-table-column label="角色名" prop="name" />
            <el-table-column label="描述" prop="description" />
            <el-table-column label="操作">
              <!-- row当前行的数据 -->
              <template v-slot="{ row }">
                <div>
                  <el-button type="text">分配权限</el-button>
                  <!-- 1.打开弹窗 -->
                  <!-- 2.回显数据 -->
                  <!-- 当前行数据 包含所有数据  只需要传过去-->
                  <!-- 3.定义变量区分场景 -->
                  <!-- 1.标题 -->
                  <!-- 2.表单验证 -->
                  <!-- 3.分场景调用接口 -->
                  <!-- 定义编辑api -->
                  <!-- 导入 -->
                  <el-button type="text" @click="edit(row)">修改</el-button>
                  <el-button type="text" @click="del(row)">删除</el-button>
                </div>
              </template>
            </el-table-column>
          </el-table>
          <div class="page">
            <!-- current-page当前页 -->
            <!-- page-sizes 页容量 默认页容量一定要在页容量中存在-->
            <!-- layout布局 -->
            <el-pagination
              style="text-align: right"
              :current-page="page.page"
              :page-sizes="[1, 10, 100, 200, 300, 400]"
              :page-size="page.pagesize"
              layout="total, sizes, prev, pager, next, jumper"
              :total="page.total"
              @size-change="handleSizeChange"
              @current-change="handleCurrentChange"
            />
          </div>
        </el-tab-pane>
        <el-tab-pane label="公司信息" lazy>
          <Info />
        </el-tab-pane>
      </el-tabs>
    </el-card>
    <Add ref="add" />
  </div>
</template>

<script>
import { sysRole, sysRoleDelete } from '@/api/setting.js'
import Add from './components/add.vue'

export default {
  name: '',
  components: {
    Info: () => import('./components/info.vue'),
    Add
  },
  data() {
    return {
      list: [],
      page: {
        page: 1, // 默认页码
        pagesize: 10, // 每页条数
        total: 100
      }
    }
  },
  created() {
    this.getData()
  },
  methods: {
    // 页码改变
    handleSizeChange(size) {
      this.page.pagesize = size
      // 页容量回到第一页
      this.page.page = 1
      this.getData()
      console.log(size)
    },
    // 页容量改变
    handleCurrentChange(page) {
      this.page.page = page
      this.getData()
      console.log(page)
    },
    // 获取列表
    async getData() {
      const res = await sysRole(this.page)
      // 存储分页总数
      this.page.total = res.data.total
      // 存储列表数据
      this.list = res.data.rows
      console.log(res.data.rows, '返回的数据')
    },
    // 新增按钮的点击
    addClick() {
      // 打开弹窗
      this.$refs.add.isShow = true
      this.$refs.add.mode = 'add'
    },
    // 删除事件
    del(row) {
      console.log(row)
      this.$confirm('你确定要删除该角吗?', '提示')
        .then(async() => {
          await sysRoleDelete(row.id)
          // 提示信息
          this.$message.success('删除成功')
          // 刷新列表数据回到第一页
          this.handleCurrentChange(1)
        })
        .catch(() => {})
    },
    // 修改
    edit(row) {
      this.$refs.add.isShow = true
      // 回显数据
      this.$refs.add.form = JSON.parse(JSON.stringify(row))
      this.$refs.add.mode = 'edit'
    }
  }
}
</script>

<style scoped></style>

在这里通过获取到子组件的实例化对象,来控制弹窗的显示和隐藏。

Add.vue

<template>
  <div class="">
    <el-dialog
      :visible="isShow"
      :title="{ add: '新增角色', edit: '编辑角色' }[mode]"
      @close="closeEvent"
    >
      <el-form ref="form" label-width="100px" :rules="rules" :model="form">
        <el-form-item label="角色名称" prop="name">
          <el-input v-model="form.name" />
        </el-form-item>
        <el-form-item label="角色描述" prop="description">
          <el-input v-model="form.description" />
        </el-form-item>
      </el-form>
      <template>
        <div style="text-align: center">
          <el-button @click="closeEvent">取消</el-button>
          <el-button type="primary" @click="submit">确定</el-button>
        </div>
      </template>
    </el-dialog>
  </div>
</template>

<script>
import { sysRolePost, sysRolePut } from '@/api/setting'
export default {
  name: '',
  model: {
    prop: 'isShow'
  },
  // props: {
  //   isShow: {
  //     type: Boolean,
  //     default: false
  //   }
  // },

  data() {
    return {
      mode: 'add', // 默认 新增 edit 编辑
      isShow: false,
      form: {
        name: '', // 角色名称
        description: '' // 角色描述
      },
      rules: {
        name: [{ required: true, message: '必填', trigger: 'blur' }],
        description: [{ required: true, message: '必填', trigger: 'blur' }]
      }
    }
  },
  methods: {
    closeEvent() {
      // 子传递父值,将其变为false

      this.isShow = false
      // 重置表单
      this.$refs.form.resetFields
      this.form = {
        name: '',
        description: ' '
      }
    },
    // 确定按钮
    submit() {
      this.$refs.form.validate(async(result) => {
        if (result) {
          if (this.mode === 'add') {
            await sysRolePost(this.form)
            // 关闭页面

            this.$message.success('新增成功')
          } else {
            await sysRolePut(this.form)
            this.$message.success('编辑成功')
          }
          this.closeEvent()
          // 刷新父级列表的数据

          // 组件的ref拿到的是add组件的实例对象
        }
      })
    }
  }
}
</script>

<style scoped></style>

四.总结

$ref:

1.如果是标签,则获取到的是DOM

2.如果是在组件上,则获取的是组件的实例化对象。

$parent

能够获取父组件的实例化对象(最近的父组件)。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
vue的常用方法总结 第一章 Vue核心知识讲解 5 第二节 引包、留坑、实例化 、插值表达式{{}} 5 1. 引包 5 2. 留坑 5 3. 实例化 5 4. 插值表达式{{ }} 5 第三节 熟悉及使用常用指令 5 1. 什么是指令 5 2. 常用的指令有哪些,及怎么使用这些指令 6 第四节 阐述vue单双向数据流及事件绑定 6 1. vue单向数据流绑定属性值 v-bind: (属性) 简写 :(属性) 6 2. vue双向数据流 v-model 只作用于有value属性的元素 7 3. 事件绑定v-on:事件名="表达式||函数名" 简写 @事件名="表达式||函数名" 8 4. 总结 8 第五节 过滤器 8 1、过滤器有全局过滤器和组件内的过滤器 应用 {{ msg | 过滤器名}} 8 2、 vue中的this是vue封装好给我们使用的,跟平常方法里面的this是不同的 9 第六节 数据监听watch(深度监听)计算属性computed 9 watch监听单个,computed监听多个 9 总结: 10 第二章 组件化开发知识介绍 11 第一节 组件化开发 11 1、 创建组件的两种方式 11 局部声明 11 2、组件类型(组件开发三步曲:声明、注册、使用 ) 11 第二节 slot插槽和ref、$parent (重点) 11 1、slot插槽 11 2、ref获取组件实例 12 第三节 父子组件的通信 (核心) 13 1、传子 14 2、子传 14 第四节 非父子组件之间的通信 14 简介:建立Bus总线机制实施非父子组件通讯 14 3、回调函数写法 16 第五节 vue的生命周期 17 1、需要频繁的创建和销毁组件 17 2、组件缓存 17 3、成对比较 17 第三章 Vue核心插件之路由模块 18 第一节 路由的跳转原理(哈希模式) 18 1、单页应用的路由模式有两种(哈希模式、history模式) 19 2、 哈希模式原理 19 3、建议的选择:(小D课堂课程) 19 第二节 安装和使用路由 19 第三节 路由的跳转 20 1、路由的跳转方式2种: 20 2、区别: 20 3、vue-router中的对象:$route $router 21 第四节 路由的传参和取参 21 1. 查询参 21 2. 路由参数 21 3、js跳转路由传参和标签传参,路由相同而参数不同时页面不做刷新的问题 22 总结: 22 第五节 嵌套路由(Children) 23 第六节 路由守卫 23 第五章 Vue全家桶各部分核⼼知识详解 24 第1节 构建vue项⽬的利器—脚⼿架vue-cli3 24 1、安装vue-cli3 24 2、创建项⽬ 24 3、 vue.config.js ⼿动在根⽬录新建⼀个vue.config.js⽂件 24 第2节 ⽗⼦组件传值(参考第二章第2、3节) 25 第3节 非⽗⼦组件传值(参考第二章第4节) 25 1. 事件总线(参考第二章第4节) 25 2. $attrs / $listeners 25 3. Vuex (详见第5节) 25 第4节 玩转单⻚⾯应⽤的控制中⼼—vue-router(与第三章基本差不多) 26 梦学谷第137课ElementUI实现页面横向指示导航,比小D课堂的那种写法要好点 26 1、路由的基本配置 26 2、路由的跳转 26 3、动态路由 27 4、嵌套路由 27 5、导航守卫 27 6、路由懒加载 28 第5节 状态管理中⼼—vuex的基础⽤法(官方文档,非常好用) 28  State 28  Mutations 28  Actions 28  vuex⾥包含的基本参数 28  还有别的mapState这些很好用 29 import { mapState, mapMutations } from "vuex";(导入非默认成员) 29 其实是ES6语法,详见梦学谷89课 29 第6节 状态管理中⼼—vuex的⾼级⽤法 29  vuex中的计算属性—Getters 30  模块化概念—Modules 30

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值