Vue3(四)组件传值

坚持、坚持、再坚持!
努力、努力、再努力!
今天把Vue3更完

关键字:父子组件传值、

1. 父子组件传值

<Son1 :name="name" :age="age" :sex="sex" 
      @updateName="name=$event" @updateAge="age=$event" @updateSex="sex=$event">
    <!-- 通过template组件指定具体的插槽 -->
    <template v-slot:one>
        <div>
            <button>按钮1</button>
        </div>
        <p>HelloWorld</p>
    </template>
    <!-- #是v-slot:的简写 -->
    <template #two>
        <div>
            <button>按钮2</button>
        </div>
        <p>你好世界</p>
    </template>
</Son1>

<h2>Son1</h2>
<div>
    姓名:{{myName}}
    年龄:{{myAge}}
    性别:{{mySex}}
    <button @click="updateData">修改信息</button>
</div>
<!-- 插槽,定义多个插槽时,需要给插槽定义名称:具名插槽 -->
<slot name="one"></slot>
<slot name="two"></slot>
<GrandSon1 />
import { ref } from 'vue';
import GrandSon1 from './GrandSon1.vue'
export default {
  name: "Son1",
  components:{
      GrandSon1
  },
  // 接收父组件传过来的数据
  props:['name','age'],
  // Vue2中的方式   
  /* data() {
      return {
          myName:this.name,
          myAge:this.age,
          mySex:this.sex
      }
  },
  methods: {
      updateData(){
          this.myName = '李四'
          this.myAge = 30
          this.mySex = '女'
          this.$emit('updateName',this.myName)
          this.$emit('updateAge',this.myAge)
          this.$emit('updateSex',this.mySex)
      }
  }, */

  //setup函数中通过参数props接收父组件传递进来的参数
  //注意:props参数中,只会接收props选项中接收的参数 
  //context参数里面有三个对象:attrs,emit,slots
  //attrs用于获取没有采用props选项接收的参数
  //emit用于触发自定义事件
  //slots用于获取插槽信息
  setup(props,{attrs,emit,slots}) {
      //slots对象返回的是插槽里面所有内容的虚拟DOM
      console.log(slots.one()[0].children);
      //获取姓名和年龄
      let myName = ref(props.name)
      let myAge = ref(props.age)
      //获取性别
      let mySex = ref(attrs.sex)
      //修改数据的方法
      let updateData = ()=>{
          //修改自身数据
          myName.value = '李四'
          myAge.value = 30,
          mySex.value = '女'
          //触发自定义事件,将最新数据回传给父组件
          emit('updateName',myName.value)
          emit('updateAge',myAge.value)
          emit('updateSex',mySex.value)
      }
      return{
          myName,
          myAge,
          mySex,
          updateData
      }
  }
};

2. 祖孙组件传值

import {reactive, provide} from 'vue'
let phone = reactive({
    name:'华为',
    price:5000
})

//provide将指定的数据添加为依赖数据,让后代组件可以直接使用
provide('phone',phone)

<h3>GrandSon1</h3>
<div>
    手机信息:{{phone}}
    <button @click="updatePhone">修改手机</button>
</div>
import {inject} from 'vue'
// inject注入祖级组件中设置为依赖的数据
let phone = inject('phone')
let updatePhone = ()=>{
    phone.name = '苹果'
    phone.price = 8000
}
return {
    phone,
    updatePhone,
}

3. v-model

<!-- Vue3可以通过v-model指令实现对多个数据的双向绑定 -->
<Son2 v-model:name="name" v-model:age="age" v-model:sex="sex" 
@click="testClick" />

<h2>Son2</h2>
<div>
    姓名:{{myName}}
    年龄:{{myAge}}
    性别:{{mySex}}
    <button @click="updateData">修改信息</button>
    <button @click="emitClick">触发一个click事件</button>
</div>
let testClick = (e)=>{
    alert(e)
}
import { ref } from 'vue';
export default {
  name: "Son2",
  //props选项接收父组件参数
  props:['name','age','sex'],
  //emits选项确定父组件可以触发哪些事件 
  //注意:因为click跟原生事件同名,如果不在emits里面配置的话,父组件会触发两次click事件 
  emits:['click'],
  setup(props,{emit}) {
      let myName = ref(props.name)
      let myAge = ref(props.age)
      let mySex = ref(props.sex)
      let updateData = ()=>{
          myName.value = '谢娜'
          myAge.value = 35,
          mySex.value = '女'
          //注意:自定义事件名称必须命名为update:属性名
          //就可以实现对父组件中指定属性的双向绑定   
          emit('update:name',myName.value)
          emit('update:age',myAge.value)
          emit('update:sex',mySex.value)
      }
      let emitClick = ()=>{
          //触发一个click事件
          emit('click','哈哈')
      }
      return{
          myName,
          myAge,
          mySex,
          updateData,
          emitClick
      }
  }
};

4.异步组件

定义

<h2>Son3</h2>
<div>姓名:{{name}},年龄:{{age}}</div>
import {ref} from 'vue'
export default {
  name: "Son3",
  setup() {
      let name = ref('周杰伦')
      let age = ref(20)

      //注意:通常情况下,setup方法直接返回对象,不要返回Promise对象。
      return new Promise((resolve,reject)=>{
          setTimeout(() => {
            resolve({
                name,
                age
            })
          }, 2000);
      })
  }

使用

<!-- suspense用于在渲染异步组件时,显示Loading... -->
<!-- 注意:异步加载的组件可以用suspense,也可以不用;
但是,如果组件中setup的返回值是一个Promise对象,该组件必须要用suspense -->
<suspense>
    <template #default>
        <Son3/>
    </template>
    <template #fallback>
        Loading...
    </template>
</suspense>
// defineAsyncComponent组合式API,用于定义异步组件
import {defineAsyncComponent} from 'vue'
// 异步导入组件
let Son3 = defineAsyncComponent(()=>import('./components/Son3.vue'))

5. teleport组件

官方起的名称:瞬移。通过to属性确定里面的元素移动到哪

<h2>Son4</h2>
<button @click="show=true">弹出</button>
<!-- teleport组件:官方起的名称:瞬移。通过to属性确定里面的元素移动到哪 -->
<teleport to="body">
    <div v-show="show" class="box">
        <button @click="show=false">关闭</button>
    </div>
</teleport>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335

推荐阅读更多精彩内容