vue中组件间的通讯方式

父传子

父组件中在引用的子标签中自定义属性传值

//子标签

<son :data="toSon"></son>

//数据

data: {

   toSon:'传给子组件',

}

子组件用props接收父组件的传值

//props和data同级

props:{

        //data:String,

        // 或者设置默认值

        data:{

          type:[Number,String],

          default:"默认值"

        },

      },

子传父

在父组件中自定义事件接收数据

//在父组件中

methods: {

   formSon(data){

   console.log(data)  //data即传来的数据

   }

}

//子标签

<son @fromSon1="fromSon"></son>

子组件触发$emit传递数据

//可以在生命周期中触发或者设置点击事件触发

created(){

this.$emit('fromSon1',"传到父组件");

}

缓存

可以将数据存储到本地缓存中,在需要的时候从缓存中取出即可。

1.localStorage和sessionStorage

localStorage存储的数据会一直在浏览器本地存储,除非手动清除

sessionStorage存储的数据在浏览器关闭后就会清除。

localStorage只能存储字符串,任何格式的数据在存储的时候都会被自动转为字符串,所以读取的时候,需要进行类型的转换。

明。

Vuex

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储,管理应用中所有组件的状态。

作用:进行统一的状态管理,解决不同组件共享数据的问题。

不同视图需要变更同一状态的问题。

Ref

利用ref函数获取组件中的标签元素,并且可以使用该标签元素的属性和方法

//例如: 让输入框自动获取焦点

<template>

  <input type="text">---

  <input type="text" ref="inputRef">

</template>

<script lang="ts">

import { onMounted, ref } from 'vue'

/*

ref获取元素: 利用ref函数获取组件中的标签元素

功能需求: 让输入框自动获取焦点

*/

export default {

  setup() {

    //声明一个 ref 来存放该元素的引用

//必须和模板里的 ref 同名

    const inputRef = ref<HTMLElement|null>(null)

    onMounted(() => {

      inputRef.value && inputRef.value.focus()

    })

    return {

      inputRef

    }

  },

}

</script>

事件总线

事件总线像是所有组件共用相同的事件中心,可以向该中心注册发送事件或接收事件,所以组件都可以上下平行地通知其他组件。事件总线多用于兄弟组件的通信。

触发事件

在uni中可以通过uni.$emit(eventName,OBJECT)来触发全局的自定事件。附加参数都会传给监听器回调。

uni.$emit('update',{msg:'页面更新'})

监听事件

uni.$on(eventName,callback)

监听全局的自定义事件。事件可以由 uni.$emit 触发,回调函数会接收所有传入事件触发函数的额外参数

只监听一次

uni.$once(eventName,callback)

监听全局的自定义事件。事件可以由 uni.$emit 触发,但是只触发一次,在第一次触发之后移除监听器。

移除监听

uni.$off([eventName, callback])

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

WeChat624

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值