中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue 組件的掛載與父子組件的傳值實例

發布時間:2020-10-07 23:21:35 來源:腳本之家 閱讀:199 作者:愛學習的小發發 欄目:開發技術

1:將需要掛載的組件放置在component之中

Vue 組件的掛載與父子組件的傳值實例

2:全局掛載在main.js之中

import Vue from 'vue'
import App from './App.vue'
import getTime from './component/child/getTime'

//全局注冊 整個項目的組件都可以使用
//注冊給整個vue 對象
//引入需要注冊的全局組件

//在vue類的方法 component里面進行注冊
Vue.component('v-times',getTime);
Vue.component('v-times',{
 template:"<div>{{msg}}</div>",//字符串的標簽模板
 data(){ //當前模板的數據
  return {
   msg:"時間"
  }
 }
});
new Vue({
 el: '#app',
 render: h => h(App)
})

3:局部掛載至當前父組件之內

<script>
//組件在誰里面使用 在誰里面注冊 這種注冊方式叫做局部注冊
//局部注冊只能在父組件里使用
import topTitle from "./component/systemtoptitle";
import leftMenu from "./component/systemleftmenu";
import rightContent from "./component/systemrightcontent";
//注冊組件
//注冊完成之后使用組件
export default {
 name: "app",
 components: {
  //注冊
  //常規寫法鍵值寫法
  "v-toptitle": topTitle,
  "v-leftmenu": leftMenu,
  "v-rightcontent": rightContent
  //簡單寫 topTitle leftMenu rightContent
 },
 data() {
  return {};
 }
};
</script>

4:父組件傳值給子組件

父組件:

<template>
 <div id="toptitle">
  <!--logo子組件是toptitle的子組件-->
  <!--子組件接收值-->
  <v-logo :sysname="name"></v-logo>
 </div>
</template>
<script>
import logo from './child/logo'
export default{
 name:"toptitle ",
 components:{
  'v-logo':logo
 },
 data(){
  return {
   //比如下面的兩個信息是后臺返回的
   name:"學生信息管理",
   logo:"src/assets/logo.png"
  }
 }
}
</script>

子組件:

<template>
 <div id="logoinfo">
  <!--注意此處為:src-->
  <img class="logoimg" :src="logoimg" alt=""/>
  <span class="systemname">{{sysname}}</span>
 </div>
</template>
<script>
export default {
 //子組件調用父組件的值
 //1 簡單寫法
 //2 約束數據類型的寫法 如果數據類型不一致 會報警告
 //3 如果父組件沒有傳值 走默認值
 name: "logoinfo",
 //props: ["logo", "sysname"],
 /* props:{
   'logoimg':String,
   'sysname':String
 }, */
 props:{
   'logoimg':{
     type:String,
     default:"src/assets/wanmou.jpg"
   },
   'sysname':String
 },
 data() {
  return {
   //子組件定義props屬性接收父組件傳遞的數據
  };
 }
};
</script>

5:子組件調用父組件的值

子組件:

<template>
 <div id="logoinfo">
  <!--注意此處為:src-->
  <img class="logoimg" :src="logoimg" alt=""/>
  <span class="systemname">{{sysname}}</span>
 </div>
</template>
<script>
export default {
 //子組件調用父組件的值
 //1 簡單寫法
 //2 約束數據類型的寫法 如果數據類型不一致 會報警告
 //3 如果父組件沒有傳值 走默認值
 name: "logoinfo",
 //props: ["logo", "sysname"],
 /* props:{
   'logoimg':String,
   'sysname':String
 }, */
 props:{
   logoimg:{
     type:String,
     default:"src/assets/wanmou.jpg"
   },
   sysname:String,
   parentinfo:Object
 },
 mounted() {
  //1 在子組件里獲取整個父組件
  //子組件執行父組件的函數
  //let parent=this.parentinfo;
  //parent.childsend();

  //2 子組件獲取父組件 內置方法
  let parentdata=this.$parent;
  console.log(parentdata);
 },
 data() {
  return {
   //子組件定義props屬性接收父組件傳遞的數據
  };
 },
 methods: {
  sendmsg(){
   console.log("子組件函數");
  }
 }
}
</script>

父組件:

<template>
 <div id="toptitle">
  <!--logo子組件是toptitle的子組件  
  //父組件獲取子組件的所有內容
  //使用ref獲取虛擬的dom來獲取子組件
  -->
  <!--子組件接收值-->
  <v-logo :parentinfo="this" ref="logolist" :sysname="name"></v-logo>
 </div>
</template>
<script>
import logo from './child/logo'
export default{
 name:"toptitle",
 components:{
  'v-logo':logo
 },
 mounted() {
  //組件掛載完的執行函數
  let logoinfo=this.$refs.logolist;
  //獲取到的是整個子組件 父組件里面執行子組件的方法
  logoinfo.sendmsg();
 },
 data(){
  return {
   //比如下面的兩個信息是后臺返回的
   name:"學生信息管理",
   logo:"src/assets/logo.png"
  }
 },
 methods: {
  childsend(){
   console.log("父組件里面的函數");
  }
 }
}
</script>

補充知識:vue-router中的組件怎么傳遞參數

第一種方法params

 {
   path: '/user/:userid',
   component: User
  },
<template>
<div>
<h3>{{userid}}</h3> // 
<h4>{{this.$route.params}}</h4>
</div>
</template>
<router-link :to='/user/+userid' tag="button">用戶</router-link>
<router-view></router-view>

export default {
 name: 'App',
 data() {
  return {
   userid: 'lisi'
  }
 }
}

Vue 組件的掛載與父子組件的傳值實例

第二種 query

 {
   path: '/profile',
   component: Profile
  }
<template>
<div>
<h3>我是Profile</h3>
<h4>{{this.$route.query}}</h4>
</div>
</template>
<router-link :to="{path: '/profile', query: {
   name: 'hylls',
   age: 20,
   height: 1.77
  }}" tag="button">profile</router-link>
  <router-view></router-view>

Vue 組件的掛載與父子組件的傳值實例

以上這篇Vue 組件的掛載與父子組件的傳值實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武隆县| 玛沁县| 农安县| 辉南县| 新竹县| 忻城县| 昌都县| 广灵县| 双城市| 永兴县| 隆昌县| 舟山市| 台北县| 黔东| 德令哈市| 和平县| 黄梅县| 嘉善县| 盐山县| 建始县| 永和县| 托里县| 咸丰县| 正定县| 甘谷县| 华安县| 延边| 武宁县| 宁陕县| 安吉县| 德格县| 花莲县| 西青区| 高邮市| 德州市| 康平县| 横山县| 商河县| 芜湖县| 嘉鱼县| 吴忠市|