vue-property-decorator和typescript结合构建的class类组件,父组件触发子组件方法的方式

class类组件示例

  • Father类组件

    <template>
    <div>
    <h1>父组件</h1>
    <button @click="handleSonMethod">点击触发子组件方法(修改子组件的描述)</button>
    <Son ref="son" />
    </div>
    </template> <script lang='ts'> // lang要定义为ts
    import { Vue, Prop, Component } from "vue-property-decorator";
    import Son from "./Son.vue"; @Component({
    name: "Father",
    components: { Son }
    })
    export default class Father extends Vue {
    // prop
    @Prop(Array) sub_projects!: string[]; // 必传
    @Prop(String) selected_project?: string; // 非必传 // data
    son: any = null // 存储子组件
    selected_org: string = "1";
    options: Array<{ value: string; label: string }> = [
    {
    value: "1",
    label: "1"
    },
    {
    value: "2",
    label: "2"
    },
    {
    value: "3",
    label: "3"
    }
    ]; // computed 计算属性
    get username(): string {
    return `计算属性username`;
    } // 钩子函数
    created() {
    console.log("created钩子触发了");
    } // method 方法
    handleSonMethod() {
    // 调用子组件的handleChangeDesc方法
    (this.$refs.son as any).handleChangeDesc('你好,中国')
    }
    }
    </script>
  • Son类组件

    <template>
    <div>
    <h2>子组件的描述信息:<span style='color: red'>{{ desc }}</span></h2>
    </div>
    </template> <script lang='ts'>
    import { Vue, Component } from "vue-property-decorator"; @Component({ name: "Son" })
    export default class Son extends Vue { // data
    desc: string = "我是子组件Son"; /**
    * @description: 修改子组件展示的描述信息
    * @param { string } msg 子组件描述信息
    */
    handleChangeDesc(msg: string) {
    this.desc = msg;
    }
    }
    </script>

父组件触发子组件方法的方式

  • 以前的方式 this.$refs.son.handleChangeDesc('你好,中国')

    • 会报错,因为引入了typescript

  • 第一种方式:类型断言

    • as 关键字(推荐用这种)

      handleSonMethod() {
      // 调用子组件的handleChangeDesc方法
      (this.$refs.son as any).handleChangeDesc('你好,中国')
      }
    • <数据类型> ===>> 比如

      handleSonMethod() {
      // 调用子组件的handleChangeDesc方法
      (<any>this.$refs.son).handleChangeDesc('你好,中国')
      }
  • 第二种方式:将this.$refs.son赋值给一个组件的一个属性

    // 1. 组件上定义一个可以存储任意数据类型值的属性‘son’
    son: any = null // 存储子组件 // 2. 将子组件的实例赋值给‘son’,通过这个变量去调用子组件的方法
    handleSonMethod() {
    // 调用子组件的handleChangeDesc方法
    this.son = this.$refs.son
    this.son.handleChangeDesc('你好,中国')
    }
  • 效果图

    • 触发前

    • 触发后

vue-property-decorator和typescript结合构建的class类组件,父组件触发子组件方法的方式的更多相关文章

  1. vue单文件组件形成父子(子父)组件之间通信(vue父组件传递数据给子组件,子组件传递数据给父组件)

    看了很多文章,官网文档也有看,对父子组件通信说的不是很明白:决定自己总结一下: vue一般都使用构建工具构建项目:这样每个组件都是单文件组件:而网上很多文章都是script标签方式映入vue,组件通信 ...

  2. vue组件中的样式属性:scoped,解决在父组件中无法修改子组件样式问题

    Scoped CSS规范是Web组件产生不污染其他组件,也不被其他组件污染的CSS规范. vue组件中的style标签标有scoped属性时表明style里的css样式只适用于当前组件元素,它是通过使 ...

  3. Vue : props 使用细节(父组件传递数据给子组件)

    props使用细节 在Vue.js中我们可以使用 props 实现父组件传递数据给子组件,下面我们总结一下props的使用细节 1.基础类型检查 2.必填数据 3.默认值 4.自定义验证函数 其中每一 ...

  4. vue中父组件传数据给子组件

    父组件: <template> <parent> <child :list="list"></child> //在这里绑定list对 ...

  5. vue.js中父组件触发子组件中的方法

    知识点:vue.js中,父组件的method中,触发子组件中的方法,获得子组件中的定义的属性 (1)子组件 : child_crud.js var html_child_crud= "< ...

  6. vue 父组件数据修改,子组件数据未修改

    页面: 父组件  <myfeedback></myfeedback>  子组件  <news></news> myfeedback.vue <te ...

  7. vue 父向子组件传递数据,子组件向父组件传递数据方式

    父组件向子组件传递数据通过props,子组件引入到父组件中,设置一个值等于父组件的数据,通过:bind将数据传到子组件中,子组件中通过props接收父组件的数据,这样就可以使用父组件的数据了,循环组件 ...

  8. vue父组件传参给子组件

    其实组件之间传参有很多种方法: 1.通过本地存储 2.使用vuex状态管理 今天记录一下第三种方法 1.首页我们先创建一个项目(创建项目自行百度) 2.打开项目,在components文件夹下新建一个 ...

  9. 【vue】父向子组件传参、子组件向父传参

    1.父向子组件传参 App.vue为父,引入componetA组件之后,则可以在App.vue中使用标签(注意驼峰写法要改成componet-a写法,因为html对大小写不敏感,componenta与 ...

随机推荐

  1. jquery (对内容,元素,属性,class的操作)

    对内容的操作: 捕获:获得内容 text() - 设置或返回所选元素的文本内容html() - 设置或返回所选元素的内容(包括 HTML 标记)val() - 设置或返回表单字段的值. 设置:设置内容 ...

  2. 【CuteJavaScript】Angular6入门项目(2.构建项目页面和组件)

    本文目录 一.项目起步 二.编写路由组件 三.编写页面组件 1.编写单一组件 2.模拟数据 3.编写主从组件 四.编写服务 1.为什么需要服务 2.编写服务 五.引入RxJS 1.关于RxJS 2.引 ...

  3. KafkaManager2.0.0.2安装与使用

    KafkaManager 是雅虎开源的一款 针对kafka集群的web管理工具, 具体功能和介绍就不再这细讲 kafka-manager github官网  https://github.com/ya ...

  4. JS实现链式调用 a().b().c()

    function a() { this.b = function () { console.log('111') return this } this.c = function () { consol ...

  5. JSP请求是如何被处理的?jsp的执行原理

    客户端通过浏览器发送jsp请求,服务器端接受到请求后,判断是否是第一次请求该页面,或者该页面是否改变,若是,服务器将jsp页面翻译为servlet,jvm将servlet编译为.class文件,字节码 ...

  6. 清晰架构(Clean Architecture)的Go微服务: 程序结构

    我使用Go和gRPC创建了一个微服务,并试图找出最佳的程序结构,它可以用作我未来程序的模板. 我有Java背景,并发现自己在Java和Go之间挣扎,它们之间的编程理念完全不同.我写了一系列关于在项目工 ...

  7. 一个简单的示例在spring boot中实现国际化

    最近在网上找了一个有关账单管理的spring boot项目,其中有一部分是涉及显示国际化信息的,即将页面上的中英文进行转换.因为在这之前这部分内容没有接触过,所以在这记录下过程. 中文效果图如下所示: ...

  8. linus 命令

    系统信息 arch 显示机器的处理器架构uname -m 显示机器的处理器架构uname -r 显示正在使用的内核版本 dmidecode -q 显示硬件系统部件 - (SMBIOS / DMI) h ...

  9. 运算符副作用总结与例子(js)

    js中运算符副作用总结与例子 js中赋值运算符,递增递减运算符,delete运算符具有副作用,简单地说就是前后表达式的值会相互影响,除此之外其它的js运算符都没有副作用. 但函数表达式和对象创建表达式 ...

  10. flink time and watermark

    流处理中时间本质上就是一个普通的递增字段(long型,自1970年算起的微秒数),不一定真的表示时间. watermark只是应对乱序的办法之一,大多是启发式的,在延迟和完整性之间抉择.(如果没有延迟 ...