国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

Vue中組件之間數據的傳遞的示例代碼

來源:懂視網 責編:小采 時間:2020-11-27 22:30:51
文檔

Vue中組件之間數據的傳遞的示例代碼

Vue中組件之間數據的傳遞的示例代碼:Vue中組件的作用域是隔離的,父組件中的數值子組件看不到!也就是說,用angular作比喻,組件的scope天生是scope:()的! 如果父組件需要往子組件中傳數據,此時應該使用標簽屬性: <div id=app> <my-compo c=886>&l
推薦度:
導讀Vue中組件之間數據的傳遞的示例代碼:Vue中組件的作用域是隔離的,父組件中的數值子組件看不到!也就是說,用angular作比喻,組件的scope天生是scope:()的! 如果父組件需要往子組件中傳數據,此時應該使用標簽屬性: <div id=app> <my-compo c=886>&l

Vue中組件的作用域是隔離的,父組件中的數值子組件看不到!也就是說,用angular作比喻,組件的scope天生是scope:()的!
如果父組件需要往子組件中傳數據,此時應該使用標簽屬性:

<div id="app">
 <my-compo c="886"></my-compo>
</div>

子組件中,用props聲明這個值即可。并且在template里面可以直接使用{{c}}來獲得這個屬性,而不需要寫為{{this.props.c}}

import Vue from "vue";

const MyCompo = Vue.extend({
 template : `
 <div>
 <h1>我是MyCompo組件,我的a值是{{a}}</h1>
 <h1>子組件c:{{c}}</h1>
 <input type="button" value="+++" v-on:click="add"/>
 </div>
 `,
 props : ["c"],
 data : function(){
 return {
 a : 1, 
 b : 2
 }
 },
 methods : {
 add : function(){
 this.a ++;
 }
 }
});

export default MyCompo;

如果父組件中要傳一個動態的值(就是父組件的data,不是死數),此時要用v-bind:來傳遞。
v-bind指令表示動態屬性。

<div id="app">
 <my-compo v-bind:c="c"></my-compo>
</div>

此時我們研究,子組件改變了這個值,父組件的值變不變。答:默認情況下不變!

<my-compo v-bind:c="c"></my-compo>

import Vue from "vue";

const MyCompo = Vue.extend({
 template : `
 <div>
 <h1>我是MyCompo組件,我的a值是{{a}},我的c值是:{{c}}</h1>
 <input type="button" value="+++" v-on:click="add"/>

 </div>
 `,
 props : ["c"],
 methods : {
 add : function(){
 this.c ++;
 }
 }
});

export default MyCompo;

子組件的c值變化了,但是外面不變!

也就是說,默認情況下,父組件中的屬性值如果傳給兒子,子組件改變這個值,僅僅改變子組件中的值,父組件中的值不變。

如果非要讓子組件能夠改變父組件中的值,要加sync修飾符:

<my-compo v-bind:c.sync="c"></my-compo>

上面的c屬性是一個基本類型值常數3。此時我們試試引用類型值。

父組件中增加d屬性,值是json。

import Vue from "vue";
import MyCompo from "./components/MyCompo.js";

new Vue({
 el : "#app",
 data : {
 c : 333,
 d : {
 v : 8888
 }
 },
 components : {
 "my-compo" : MyCompo
 }
});

傳給子組件:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Vue學習</title>
</head>
<body>
 <div id="app">
 <h1>我是父親,我的c: {{c}} ,我的d:{{d | json}}</h1>
 <my-compo v-bind:c.sync="c" v-bind:d="d"></my-compo>
 </div>

 <script type="text/javascript" src="public/bundle.js"></script>
</body>
</html>

子組件改變d的時候,父親也變了!!!雖然我們沒加.sync。

總結:

Vue中基本類型值默認單向傳遞,雙向加sync。

引用類型值,默認雙向傳遞。

小tip,v-bind的縮寫語法就是冒號。

屬性可以驗證類型、必填等等。

props : {
 "c" : null,
 "d" : null,
 "e" : {
 type : Number,
 required : true
 }
},

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Vue中組件之間數據的傳遞的示例代碼

Vue中組件之間數據的傳遞的示例代碼:Vue中組件的作用域是隔離的,父組件中的數值子組件看不到!也就是說,用angular作比喻,組件的scope天生是scope:()的! 如果父組件需要往子組件中傳數據,此時應該使用標簽屬性: <div id=app> <my-compo c=886>&l
推薦度:
標簽: 數據 VUE 代碼
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 亚洲一区日韩二区欧美三区 | 欧美在线观看一区二区三区 | 国产一区 在线播放 | 国产免费视屏 | 国产一区二区三区免费视频 | 极品美女国产精品免费一区 | 国产一区二区三区在线视频 | 在线观看视频一区 | 国产精品美女久久久久 | 日韩中文欧美 | 国产午夜高清一区二区不卡 | 成人亚洲欧美日韩在线 | 欧美一区二区在线 | 久久精品无遮挡一级毛片 | 国产高清特黄无遮挡大片 | 亚洲v欧美| 日本三级电影网址 | 一区二区三区国产 | 一区二区三区视频在线观看 | 日本一二三区高清 | 国产伊人久久 | 一级毛片特级毛片免费的 | 亚洲视频免费观看 | 国内高清久久久久久久久 | 麻豆国产高清精品国在线 | 欧美第一页在线观看 | 欧美日韩国产综合在线 | 国产美女一级特黄毛片 | 国产一区二区三区久久 | 色综合欧美综合天天综合 | 99精品国产高清一区二区三区香蕉 | 欧美高清第一页 | 免费黄色网址在线观看 | 国产第一页在线播放 | 91精品国产91久久久久久最新 | 成人国产精品一级毛片视频 | 国产中文久久精品 | 精品视频一区二区三区四区 | 欧美色图日韩色图 | 2021国产精品自拍 | 国产日韩欧美在线播放 |