亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

石河子市| 将乐县| 天祝| 满城县| 伊金霍洛旗| 隆德县| 饶阳县| 甘孜| 新晃| 什邡市| 凯里市| 高密市| 高雄县| 隆回县| 天津市| 鲁山县| 阿拉善右旗| 吴江市| 宝鸡市| 湘乡市| 社会| 六枝特区| 静海县| 桃源县| 万荣县| 霍州市| 柳林县| 兴宁市| 安阳市| 页游| 赞皇县| 黄梅县| 永吉县| 北海市| 乌拉特前旗| 阿瓦提县| 博客| 凯里市| 即墨市| 泽州县| 增城市|