首頁 > web前端 > Vue.js > vue3中組件間怎麼傳值

vue3中組件間怎麼傳值

WBOY
發布: 2023-05-22 08:58:21
轉載
10533 人瀏覽過

vue3元件間的傳值(props)

父元件向子元件傳值

在父元件中:

##1.引入ref

vue3中組件間怎麼傳值

2.定義要傳遞的屬性和屬性值

vue3中組件間怎麼傳值

#3.向vue頁面中的子元件傳遞該屬性屬性

vue3中組件間怎麼傳值

傳遞屬性

:傳給子元件的名字(自訂) = 「對應定義在父元件的屬性名稱」

在子元件中:

4.接收父元件傳來的屬性

props: {
 showDialogVisible: Boolean
},
setup() {
 return {
 }
}
登入後複製

5.註冊該元件

setup(props) {
    // 可以打印查看一下props传过来的属性以及属性的值
	console.log(props);
	
	return {
		props
	}
}
登入後複製

6.在子元件的頁面使用該屬性

vue3中組件間怎麼傳值

父元件傳送值給子元件完成!

子元件傳送值(常規)

vue3中組件間怎麼傳值

vue3中組件間怎麼傳值

由於vue資料傳遞是

單向資料流,子元件沒有權利修改父元件傳過來的數據,只能請求父元件對原始資料進行修改,用emit 通知父元件去修改。 1.在子元件中定義要修改父元件那個屬性(或方法)的值

setup(props,context) {
    context.emit('setShow', false);
	
	return {
	}
}
//也可以:es6解构赋值取到emit
//setup(props,{emit}) {
//    emit('setShow', false);
//	
//	return {
//	}
//}
登入後複製

context.emit(‘傳入父元件自訂的屬性名’, 屬性值);

  • 在父元件中:

2.再頁面接收子元件中傳入的自訂屬性名,綁定在自身對應的屬性(方法)上

vue3中組件間怎麼傳值

#父元件向子元件傳值完成!
  • 附上我的父元件方法:

  • 子元件向父元件傳值(v-model)

如果

子元件傳送給父元件

的值剛好是vue3中組件間怎麼傳值父元件向子元件

傳的值,可以直接在該屬性上進行雙向綁定。

註:閱讀此小節建議先看完第一節:父元件傳送值給子元件

在子元件上:vue3中組件間怎麼傳值

1.直接修改從props拿到的屬性

##在父元件上:

2.在父頁面中的子元件上進行綁定

vue3中組件間怎麼傳值傳值完成!

###vue3元件之間傳值與事件處理######這篇文章前自己也上網找了資料,發現這塊資料極少,所以還是自己記錄一下######專案需求是每個頁面需要加上頂部導覽列,加上返回事件############### 先寫子元件程式碼,在components目錄下建立一個nav.vue檔:## ####子元件nav.vue檔案內容###
<template>
   <div>
    <el-affix position="top" :offset="0">
        <div class="nav">
          <span @click="backGo"><img  src="../assets/back.png"/ alt="vue3中組件間怎麼傳值" >返回</span>
          <p>{{title}}</p>
        </div>
    </el-affix>
  </div>
</template>
<script setup>
import{ defineProps } from "vue"
const props =defineProps({ //子组件定义接收父组件传过来的值
       title:String 
})
//点击返回事件
const backGo = () => {
    history.back()
}
</script>
<style scoped>
.nav{width: 100%;height:.6rem;display: flex;align-items: center;justify-content: center;text-align: center;position: relative;background-color: #ffffff;border-bottom: 1px solid #f0f0f0;}
.nav span{position: absolute;height:100%;left: .2rem;top: 0;display: flex;align-items: center;color: #8a8a8a;}
.nav span img{width: .32rem;}
</style>
登入後複製
###父元件aboutus.vue檔案:###
<template>
  <div class="wrap">
      <Nav title="关于我们"></Nav> <!--记住这里第一个字母大写哦-->
        <div class="lists">
          <ul class="abus">
              <li><p><router-link to="/company">公司介绍</router-link></p></li>
              <li><p><router-link to="/privacy">隐私政策</router-link></p></li>
              <li><p><router-link to="/useragree">用户协议</router-link></p></li>
          </ul>
      </div>
  </div>
</template>
<script setup>
import Nav from &#39;@/components/nav.vue&#39; 
 
</script>
登入後複製
###記住引入子元件時,第一個字母大寫哦 ! ######是不是很簡單! ######下面介紹子元件傳值######同樣是拿子元件nav.vue來測試,直接上程式碼:###
<template>
    <div>
    <el-affix position="top" :offset="0">
    <div class="nav">
      <span @click="backGo"><img  src="../assets/back.png"/ alt="vue3中組件間怎麼傳值" >返回</span>
      <p>{{title}}</p>
    </div>
  </el-affix>
    </div>
</template>
<script setup>
import{ defineProps ,defineEmits} from "vue"
const emits =defineEmits([&#39;getBackGo&#39;]) //注册父组件回调方法
const props =defineProps({
       title:String
})
const backGo = () => {
    // history.back()
    emits("getBackGo","传个值给父组件!")
}
</script>
<style scoped>
.nav{width: 100%;height:.6rem;display: flex;align-items: center;justify-content: center;text-align: center;position: relative;background-color: #ffffff;border-bottom: 1px solid #f0f0f0;}
.nav span{position: absolute;height:100%;left: .2rem;top: 0;display: flex;align-items: center;color: #8a8a8a;}
.nav span img{width: .32rem;}
</style>
登入後複製
###來看看父元件aboutus.vue寫法: ###
<template>
  <div class="wrap">
      <Nav title="关于我们" @getBackGo="getBackGoInfo"></Nav>
      <img  src="../../assets/logo.jpg" class="logo"/ alt="vue3中組件間怎麼傳值" >
      <div class="lists">
          <ul class="abus">
              <li><p><router-link to="/company">公司介绍</router-link></p></li>
              <li><p><router-link to="/privacy">隐私政策</router-link></p></li>
              <li><p><router-link to="/useragree">用户协议</router-link></p></li>
          </ul>
      </div>
  </div>
</template>
<script setup>
import Nav from &#39;@/components/nav.vue&#39;
const getBackGoInfo = (value) => {
    console.log(value)
}
 
</script>
登入後複製
###效果如下:#############

以上是vue3中組件間怎麼傳值的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:yisu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板