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

溫馨提示×

溫馨提示×

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

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

vue項目重構技術要點的示例分析

發布時間:2021-09-09 14:09:34 來源:億速云 閱讀:139 作者:小新 欄目:web開發

這篇文章給大家分享的是有關vue項目重構技術要點的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

vue數據更新, 視圖未更新

這個問題我們經常會遇到,一般是vue數據賦值的時候,vue數據變化了,但是視圖沒有更新。這個不算是項目重構的技術要點,也和大家分享一下vue2.0通常的解決方案吧!

解決方案如下:

1、通過vue.set方式賦值

Vue.set(數據源, key, newValue)

2、 通過Array.prototype.splice方法

數據源.splice(indexOfItem, 1, newValue)

3、修改數據的長度

數據源.splice(newLength)

4、變異方法

Vue.js 包裝了被觀察數組的變異方法,故它們能觸發視圖更新。被包裝的方法有:

push()
pop()
shift()
unshift()
splice()
sort()
reverse()

prop 對象數組應用

在 JavaScript 中對象和數組是引用類型,指向同一個內存空間,如果 prop 是一個對象或數組, 在子組件內部改變它會影響父組件的狀態 。利用這一點,我們在子組件中改變prop數組或者對象,父組件以及所有應用到prop中數據的地方都會變化。我之前寫過一篇js深拷貝和淺拷貝的文章,感興趣的去看下,其實,原理是一致的。

案例如下:

<input class="pinput max" type="text" v-model="itemData.data.did">

<script>
export default {
 components: {
 },
 data() {
 },
 props: {
 itemData: Object
 },
 methods: {
 }
};
</script>

所有應用到itemData的地方都會變化!

上面這種改變prop,Vue 不會在控制臺給出警告,假如我們完全改變或者賦值prop,控制臺會發出警告!引用官方給出的解決方案如下:

1、定義一個局部變量,并用 prop 的值初始化它:

props: ['initialCounter'],
data: function () {
 return { counter: this.initialCounter }
}

2、定義一個計算屬性,處理 prop 的值并返回:

props: ['size'],
computed: {
 normalizedSize: function () {
 return this.size.trim().toLowerCase()
 }
}

v-model 的一些坑

其實v-model和sync都是一些語法糖,我之前有文章介紹過,官網也能找到類似的案例!

v-model 數據有時候是undefined的時候,不會報錯,所以,一定要注意,v-model不能是undefined,否則有些莫名的問題!

重構-動態組件的創建

有時候我們有很多類似的組件,只有一點點地方不一樣,我們可以把這樣的類似組件寫到配置文件中,動態創建和引用組件

方法一:component 和is配合使用

通過使用保留的 元素,并對其 is 特性進行動態綁定,你可以在同一個掛載點動態切換多個組件:

var vm = new Vue({
 el: '#example',
 data: {
 currentView: 'home'
 },
 components: {
 home: { /* ... */ },
 posts: { /* ... */ },
 archive: { /* ... */ }
 }
})
<component v-bind:is="currentView">
 <!-- 組件在 vm.currentview 變化時改變! -->
</component>

方法二:通過render方法創建

<script>
export default {
 data() {
 return {
 };
 },
 render: function(createElement) {
 let _type = bi.chart.data.type;
 let _attr = bi.chart.components[_type]["attr"];
 return createElement(_attr, {
  props: {
  }
 });
 }
};
</script>

bi.chart.components[_type]["attr"]這個是在配置文件中動態配置的,type點擊的時候會改變,會取不同type下面的attr屬性!

公共屬性抽離

我們在項目中,經常會用很多狀態或者數據,我們可以把很多公共數據抽離出來,放到一個對象中,后面我們可以監聽這個數據對象變化。進行數據保存或者獲取。

c: {
 handler: function (val, oldVal) { /* ... */ },
 deep: true
},
// 該回調將會在偵聽開始之后被立即調用
d: {
 handler: function (val, oldVal) { /* ... */ },
 immediate: true
},

可以利用上面深度監聽。假如初始化的時候要立即執行,我們可以用立即執行監聽!

require動態加載依賴

我們可以利用require同步特性,在代碼中動態加載依賴,例如下面echart主題,我們可以點擊切換的時候,動態加載!

require("echarts/theme/"+ data.theme);

import加載要放到頭部,初始化的時候,可以把默認主題用import加載進來!

感謝各位的閱讀!關于“vue項目重構技術要點的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

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

vue
AI

泾阳县| 南雄市| 固原市| 建宁县| 台北市| 黄陵县| 镇安县| 衡阳县| 临武县| 岑巩县| 蓬莱市| 山西省| 江华| 通山县| 固镇县| 宣武区| 皮山县| 平顶山市| 仪征市| 若尔盖县| 高青县| 德钦县| 玛纳斯县| 察哈| 襄垣县| 德令哈市| 镇沅| 陆良县| 岳阳县| 广宗县| 景洪市| 安阳市| 阿拉善右旗| 武山县| 定陶县| 双鸭山市| 岫岩| 灌云县| 鹤山市| 深水埗区| 五大连池市|