国产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 + Vuex 如何使用 vm.$nextTick

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

詳解Vue + Vuex 如何使用 vm.$nextTick

詳解Vue + Vuex 如何使用 vm.$nextTick:vm.$nextTick 簡單說,因為DOM至少會在當前tick里面的代碼全部執行完畢再更新。所以不可能做到在修改數據后并且DOM更新后再執行,要保證在DOM更新以后再執行某一塊代碼,就必須把這塊代碼放到下一次事件循環里面,比如setTimeout(fn, 0),這樣D
推薦度:
導讀詳解Vue + Vuex 如何使用 vm.$nextTick:vm.$nextTick 簡單說,因為DOM至少會在當前tick里面的代碼全部執行完畢再更新。所以不可能做到在修改數據后并且DOM更新后再執行,要保證在DOM更新以后再執行某一塊代碼,就必須把這塊代碼放到下一次事件循環里面,比如setTimeout(fn, 0),這樣D

vm.$nextTick

簡單說,因為DOM至少會在當前tick里面的代碼全部執行完畢再更新。所以不可能做到在修改數據后并且DOM更新后再執行,要保證在DOM更新以后再執行某一塊代碼,就必須把這塊代碼放到下一次事件循環里面,比如setTimeout(fn, 0),這樣DOM更新后,就會立即執行這塊代碼。

//改變數據 
vm.message = 'changed' 
 
//想要立即使用更新后的DOM。這樣不行,因為設置message后DOM還沒有更新 
console.log(vm.$el.textContent) // 并不會得到'changed' 
 
//這樣可以,nextTick里面的代碼會在DOM更新后執行 
Vue.nextTick(function(){ 
 console.log(vm.$el.textContent) //可以得到'changed' 
}) 

vm.$nextTick 的作用是將回調延遲到下次 DOM 更新循環之后執行。

正常在 ready/mounted 中獲取數據, 那么操作是很簡單的

ready() { // vue2 為 mounted() {
 var request = $.ajax({
 type: "POST",
 dataType: 'json',
 url: "api.php"
 });
 request.then((json) => {
 // balabala
 this.$nextTick(function () {
 // balabala
 })
 });
}

如果是用 vuex 的話, 由于vuex的數據操作都在 action 和 mutations, 然后在 ready/mounted 中調用 action 里的函數, 那么這時候該怎么用 vm.$nextTick 呢?

這時候我們就需要用到 Promise 了, 具體代碼如下:

首頁是api.js

export default {
 getFromConfig(config) {
 return $.ajax({ data: config })
 }
}

然后是action.js

export const getArticleList = ({dispatch}, config) => {
 return api.getFromConfig(config).then(({data}) => {
 dispatch(types.RECEIVE_ARTICLE, data, config.page)
 })
}

這里一定要加上return, 這樣就可以返回一個Promise對象

最后是vue組件

methods: {
 loadMore(page = this.page) {
 var id = this.$route.params.id || ""
 Promise.all([
 this.getArticleList({
 id: id,
 page: page
 })
 ]).then(() => {
 this.$nextTick(function () {
 // balabala
 })
 })
 }
}

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

文檔

詳解Vue + Vuex 如何使用 vm.$nextTick

詳解Vue + Vuex 如何使用 vm.$nextTick:vm.$nextTick 簡單說,因為DOM至少會在當前tick里面的代碼全部執行完畢再更新。所以不可能做到在修改數據后并且DOM更新后再執行,要保證在DOM更新以后再執行某一塊代碼,就必須把這塊代碼放到下一次事件循環里面,比如setTimeout(fn, 0),這樣D
推薦度:
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 精品国产一区二区三区久久影院 | a男人的天堂久久a毛片 | 国产 日韩 欧美在线 | 91中文字幕在线观看 | 特级全黄一级毛片视频 | 亚洲欧美综合另类 | 97久久综合区小说区图片专区 | 欧美精品一区二区三区视频 | 欧美韩国日本一区 | 国产va在线视频观看 | 国产午夜久久影院 | 亚洲图欧美 | 另类专区 亚洲 | 国产99在线 | 美女视频黄a视频免费全过程在线 | 爽妇网s | 99久久国产亚洲综合精品 | 国产色在线视频 | 日韩三级电影网站 | 九九久久国产 | 国产网站在线免费观看 | 国产精品v一区二区三区 | 日韩欧美一二三区 | 国产全黄a一级毛片 | 久久精品无遮挡一级毛片 | 欧美日韩国产在线观看 | 一区二区三区视频在线 | 欧美国产日韩另类 | 香蕉久久一区二区不卡无毒影院 | 免费一区 | 亚洲综合视频 | 国产精品一区二区三区四区五区 | 亚洲欧洲日韩 | 精品一区二区在线欧美日韩 | 国产精品va在线播放 | 欧美激情伊人 | 国产欧美综合在线观看第七页 | 亚洲精品视频免费在线观看 | 国产精品不卡 | 亚洲伊人国产 | 精品国产综合区久久久久99 |