国产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
主站蜘蛛池模板: 国产一区二区三区视频在线观看 | 欧洲精品欧美精品 | av毛片免费看 | 国产伊人久久 | 欧美精品在线播放 | 99久久精品国产一区二区成人 | 国产精品久久久久影院色 | 欧美一区二区在线观看 | 亚洲一区二区三区成人 | 国产a国产片| 亚洲第一网站在线观看 | 日本中文字幕有码 | 久艹网| 成人精品视频在线观看完整版 | 国产全黄a一级毛片视频 | 三级网站免费播放国语 | 日本欧美一区二区 | 亚欧乱色视频网站大全 | 国内精品伊人久久久久妇 | 欧美精品一区二区三区免费观看 | 免费又黄又爽又猛大片午夜 | 在线播放精品一区二区啪视频 | 欧美日韩亚洲综合另类ac | 理论片国产 | 亚洲欧美国产精品专区久久 | 亚洲视频一区在线 | 六十路垂乳熟年交尾正在播放 | 国产精品综合色区在线观看 | 国产精品亚洲国产三区 | 久久久国产这里有的是精品 | 久久精品国产99久久99久久久 | 日韩国产一区二区 | 精品欧美一区二区在线观看欧美熟 | 亚洲欧美高清 | 亚洲一二三区在线观看 | 亚洲国产精品日韩在线 | 国产成人精品一区二区 | 亚洲国产婷婷综合在线精品 | 国产一区二区三区 韩国女主播 | 亚洲欧美另类自拍第一页 | 精品久久久久中文字幕日本 |