vue使用watch監(jiān)聽props的技巧分享
vue 使用watch監(jiān)聽props的一些小建議
當(dāng)在watch里面給data賦值,請使用深拷貝。
<template>
<div class="container">
<div class="left">
<div class="button_group">
<!-- <button @click="random_change_data">修改某一列的數(shù)據(jù)</button>-->
</div>
</div>
<div class="right son">
<son_component :table_data="table_data"></son_component>
</div>
</div>
</template>
<script lang="ts">
import Vue from "vue";
import son_component from "@/components/son_component.vue";
export default Vue.extend({
name: "FatherComponent",
components: {
son_component,
},
data() {
return {
table_data: [],
};
},
mounted() {
this.init_data();
},
methods: {
init_data() {
for (let i = 0; i < 100; i++) {
(
this.table_data as never as [
{ name: string; age: number; check: boolean }
]
).push({
name: `alex${i}`,
age: i,
check: false,
});
}
console.log(this.table_data);
},
generate_random_number(max: number) {
return Math.floor(Math.random() * max) + 1;
},
// random_change_data() {
// /**
// * 隨機修改某一列的數(shù)據(jù)
// */
// const index = this.generate_random_number(this.table_data.length);
// // (this.table_data[index] as { age: number }).age = 100;
// const item = this.table_data[index] as { age: number };
// item.age = 100;
// this.$set(this, index, item);
// },
},
});
</script>
<style scoped>
.container {
display: flex;
flex-direction: row;
width: 100vw;
}
.left,
.right {
width: 50vw;
}
.left {
margin: 0 auto;
line-height: 100%;
text-align: center;
}
</style> <template>
<div>
<div class="table_data">
<table>
<thead>
<tr>
<th>名字</th>
<th>年齡</th>
<th><input type="checkbox" v-model="is_all" /></th>
</tr>
</thead>
<tbody>
<tr v-for="item in data" :key="item.name">
<td>{{ item.name }}</td>
<td>{{ item.age }}</td>
<td><input type="checkbox" v-model="item.check" /></td>
</tr>
</tbody>
</table>
</div>
</div>
</template>
<script lang="ts">
import Vue from "vue";
import { cloneDeep } from "lodash";
export default Vue.extend({
name: "son_component",
data() {
return {
is_all: true,
selection: [], // 選擇的數(shù)據(jù)
data: [], // 表格數(shù)據(jù)
};
},
props: {
table_data: {
type: Array,
default: () => [],
},
choice_list: {
type: Array,
default: () => [],
},
},
watch: {
choice_list: {
handler(new_: [string], old_) {
console.log("choice_list 發(fā)生了改變");
/**
* 根據(jù)名字去判斷是否選擇
*/
if (new_) (this.selection as any) = this.choice_list.concat(new_);
},
immediate: true,
deep: true,
},
table_data: {
handler(new_) {
(this.data as any) = this.table_data;
}
},
},
});
</script>
<style scoped></style>這個時候如果修改data里面的值,是會觸發(fā)watch里面的監(jiān)聽的,所以這里建議使用深拷貝
到此這篇關(guān)于vue使用watch監(jiān)聽props的技巧分享的文章就介紹到這了,更多相關(guān)vue watch監(jiān)聽props內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Element-UI表格嵌入popover遇到的問題及解決方案
在表格中我們通常需要在每一行的一些單元格中顯示popover,這篇文章主要給大家介紹了關(guān)于Element-UI表格嵌入popover遇到的問題及解決方案,需要的朋友可以參考下2023-11-11
Vue?Router?返回后記住滾動條位置的實現(xiàn)方法
使用?Vue?router?創(chuàng)建?SPA(Single?Page?App),往往有這種需求:首頁是列表頁,點擊列表項進入詳情頁,在詳情頁點擊返回首頁后,希望看到的是,首頁不刷新,并且滾動條停留在之前的位置,這篇文章主要介紹了Vue?Router?返回后記住滾動條位置的實現(xiàn)方法,需要的朋友可以參考下2023-09-09
Vue.js報錯Failed to resolve filter問題的解決方法
這篇文章主要介紹了Vue.js報錯Failed to resolve filter問題的解決方法,需要的朋友可以參考下2016-05-05
關(guān)于Element-ui中el-table出現(xiàn)的表格錯位問題解決
使用ElementUI的el-table后,偶然發(fā)現(xiàn)出現(xiàn)行列錯位、對不齊問題,下面這篇文章主要給大家介紹了關(guān)于Element-ui中el-table出現(xiàn)的表格錯位問題解決的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07

