91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

南康市| 林西县| 耒阳市| 丹寨县| 额敏县| 嘉善县| 启东市| 湖南省| 九寨沟县| 昭通市| 中方县| 虹口区| 合水县| 定安县| 宜州市| 扎兰屯市| 昌宁县| 丰县| 贺兰县| 界首市| 合作市| 晋江市| 湘潭县| 乡城县| 陇西县| 永寿县| 漾濞| 澎湖县| 丰台区| 文山县| 柳林县| 芦溪县| 芷江| 洛川县| 泸定县| 邵武市| 瑞安市| 准格尔旗| 客服| 丽江市| 原平市|