欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue更新數(shù)據(jù)卻不渲染頁面的解決

 更新時間:2022年08月12日 10:07:30   作者:自信酷  
這篇文章主要介紹了vue更新數(shù)據(jù)卻不渲染頁面的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue更新數(shù)據(jù)卻不渲染頁面

1.Vue不能檢測通過數(shù)組索引直接修改一個數(shù)組項

原因:由于JavaScript的限制,Vue不能檢測數(shù)組和對象的變化

解決辦法:

this.$set(arr,index,newVal)

2.選擇功能選中時賦值了,但沒渲染頁面

場景:

 

點擊這個沒有顯示“√”

解決辦法:

checkClick (item) {
    item.check =! item.check;
    this.$forceUpdate() 
},

聽說循環(huán)數(shù)據(jù)更新的層級太深,導(dǎo)致數(shù)據(jù)不更新,從而導(dǎo)致視圖不更新,用上面可以解決,但我沒遇到過這種情況,請查看Vue.js官方

3.路由參數(shù)變化時

頁面不更新,本質(zhì)上就是數(shù)據(jù)沒有更新

原因:路由視圖組件引用了相同組件時,當(dāng)路由參數(shù)變化時,會導(dǎo)致該組件無法更新。

解決辦法:

通過watch監(jiān)聽$route的變化

watch: {
    '$route': function() {
 
     }
}

4.在異步更新執(zhí)行之前操作DOM數(shù)據(jù)不會變化

原因:Vue在更新DOM時是異步執(zhí)行。

只要偵聽到數(shù)據(jù)變化,Vue將開啟一個隊列,并緩沖在同一個事件循環(huán)中發(fā)生的所有數(shù)據(jù)變更。

如果同一個 watcher 被多次觸發(fā),只會被推入到隊列中一次。

這種在緩沖時去除重復(fù)數(shù)據(jù)對于避免不必要的計算和 DOM 操作是非常重要的。

然后,在下一個的事件循環(huán)“nextTick”中,Vue 刷新隊列并執(zhí)行實際 (已去重的) 工作。

解決辦法:

this.$nextTick(function(){ })

5.獲取后臺返回的數(shù)組進行排序處理了,頁面內(nèi)容卻不排序

 原因:顯示的元素不會動

解決辦法:

使用v-if先隱藏元素,更新的數(shù)組排序處理好了,才顯示元素

vue頁面的渲染過程

首先vue會找到webpack的打包配置文件。在build/webpack.base.conf.js下:在這里,定義了vue的程序入口文件

vue加載時文件的執(zhí)行順序

  • 執(zhí)行index.html文件
  • 執(zhí)行main.js文件
  • main.js掛載了app.vue文件,用app.vue的templete替換index.html中的
  • main.js中注入了路由文件,將對應(yīng)的組件渲染到router-view中
  • router-view中加載Layout文件
  • Layout 加載Navbar, Sidebar, AppMain

vue內(nèi)部頁面的執(zhí)行順序

Vue 推薦在絕大多數(shù)情況下使用 template 來創(chuàng)建你的 HTML。但是模板畢竟是模板,不是真實的dom節(jié)點。從模板到真實dom節(jié)點還需要經(jīng)過一些步驟

  • 把模板編譯為render函數(shù)
  • 實例進行掛載, 根據(jù)根節(jié)點render函數(shù)的調(diào)用,遞歸的生成虛擬dom
  • 對比虛擬dom,渲染到真實dom

組件內(nèi)部data發(fā)生變化,組件和子組件引用data作為props重新調(diào)用render函數(shù),生成虛擬dom, 返回到步驟3

一. 模板到render

// App.vue 
<template>
    <div>
        hello word
    </div>
</template>
<script>
export default {
}
</script>
<style>
</style>

vue中各選項及鉤子函數(shù)執(zhí)行順序

在頁面首次加載執(zhí)行順序有如下:

  • beforeCreate //在實例初始化之后、創(chuàng)建之前執(zhí)行
  • created //實例創(chuàng)建后執(zhí)行
  • beforeMounted //在掛載開始之前調(diào)用
  • filters //掛載前加載過濾器
  • computed //計算屬性
  • directives-bind //只調(diào)用一次,在指令第一次綁定到元素時調(diào)用
  • directives-inserted //被綁定元素插入父節(jié)點時調(diào)用
  • activated //keek-alive組件被激活時調(diào)用,則在keep-alive包裹的嵌套的子組件中觸發(fā)
  • mounted //掛載完成后調(diào)用
  • {{}} //mustache表達式渲染頁面

修改頁面input時,被自動調(diào)用的選項順序如下:

  • watch //首先先監(jiān)聽到了改變事件
  • filters //過濾器沒有添加在該input元素上,但是也被調(diào)用了
  • beforeUpdate //數(shù)據(jù)更新時調(diào)用,發(fā)生在虛擬dom打補丁前
  • directived-update //指令所在的組件的vNode更新時調(diào)用,但可能發(fā)生在其子vNode更新前
  • directives-componentUpdated //指令所在的組件的vNode及其子組件的vNode全部更新后調(diào)用updated //組件dom已經(jīng)更新

組件銷毀時,執(zhí)行順序如下:

  • beforeDestroy //實例銷毀之前調(diào)用
  • directives-unbind //指令與元素解綁時調(diào)用,只調(diào)用一次
  • deactivated //keep-alive組件停用時調(diào)用
  • destroyed //實例銷毀之后調(diào)用

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 一文詳解vue2的diff算法流程

    一文詳解vue2的diff算法流程

    本篇文章將會嘗試從算法的角度主要聊一聊vue2的diff策略,幫助讀者朋友在遇到相關(guān)的面試題時可以和面試官談笑風(fēng)生,文中有相關(guān)的圖解和代碼示例,感興趣的同學(xué)跟著小編一起來看看吧
    2023-08-08
  • 關(guān)于vant折疊面板默認(rèn)展開問題

    關(guān)于vant折疊面板默認(rèn)展開問題

    這篇文章主要介紹了關(guān)于vant折疊面板默認(rèn)展開問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue3系列教程之插槽slot詳解

    Vue3系列教程之插槽slot詳解

    插槽(slot)可以說在一個?Vue?項目里面處處都有它的身影,比如我們使用一些UI?組件庫的時候,我們通常可以使用插槽來自定義我們的內(nèi)容,今天通過本文給大家介紹vue3插槽slot的相關(guān)知識,感興趣的朋友一起看看吧
    2022-08-08
  • Vue input輸入框中的值如何變成黑點問題

    Vue input輸入框中的值如何變成黑點問題

    這篇文章主要介紹了Vue input輸入框中的值如何變成黑點問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Vue配合iView實現(xiàn)省市二級聯(lián)動的示例代碼

    Vue配合iView實現(xiàn)省市二級聯(lián)動的示例代碼

    本篇文章主要介紹了Vue配合iView實現(xiàn)省市二級聯(lián)動的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • nuxt 頁面路由配置,主頁輪播組件開發(fā)操作

    nuxt 頁面路由配置,主頁輪播組件開發(fā)操作

    這篇文章主要介紹了nuxt 頁面路由配置,主頁輪播組件開發(fā)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 如何使用VuePress搭建一個類型element ui文檔

    如何使用VuePress搭建一個類型element ui文檔

    這篇文章主要介紹了如何使用VuePress搭建一個類型element ui文檔,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02
  • vue3 vite配置跨域及不生效問題解決

    vue3 vite配置跨域及不生效問題解決

    這篇文章主要介紹了vue3 vite配置跨域以及不生效問題,本文給大家分享完美解決方案,需要的朋友可以參考下
    2023-07-07
  • Vue+Vite項目初建(axios+Unocss+iconify)的實現(xiàn)

    Vue+Vite項目初建(axios+Unocss+iconify)的實現(xiàn)

    一個好的項目開始搭建總是需要配置許多初始化配置,本文就來介紹一下Vue+Vite項目初建(axios+Unocss+iconify)的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • 淺談將three項目遷移至vue項目遇到的問題

    淺談將three項目遷移至vue項目遇到的問題

    本文主要介紹了將three項目遷移至vue項目遇到的問題,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01

最新評論