91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

Vue頁面監聽用戶預覽時間功能如何實現

發布時間:2022-10-12 15:00:15 來源:億速云 閱讀:271 作者:iii 欄目:web開發

這篇文章主要介紹“Vue頁面監聽用戶預覽時間功能如何實現”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Vue頁面監聽用戶預覽時間功能如何實現”文章能幫助大家解決問題。

首先想到借助 Vue 頁面的生命周期函數 mounted 和 destroyed,分別在其中加入開始計時和清除計時的邏輯,通過后臺的接口上報對應的培訓素材的時間數據,即可達到目的。

定義開始結束計時函數

在 data 中定義我們通過變量定義計時器,這樣可以通過 this.timer 隨處可訪問,便于后面銷毀頁面的時候清除它。

duration 為時長的計數變量,初始化為 0,可根據計時器的第二個時間間隔參數,決定單位是秒還是毫秒。

export default {
  data() {
    return {
      timer: null,
      duration: 0
    }
  },
  methods: {
    startTimer() {
      this.timer = setInterval(() => {
        console.log("觀看時長: ", this.duration)
        this.duration++
      }, 1000)
    },
    stopTimer() {
      clearInterval(this.timer)
      this.updateViewHistory() // 上報數據接口
    },
    updateViewHistory() {
    // 上報接口邏輯代碼
    ....
    }
  }
}

在 startTimer 函數中我們順便打印出 duration 變量來驗證顯示的時間是否正確。

如何以及在哪調用

定義好了開始結束的方法,我們就要開始想在哪調用它們。因為預覽的頁面內容不是唯一的,是根據素材的 id 來獲取詳情進行渲染的。如果我們把 startTimer 寫在 mounted 生命周期里,那么當我們訪問不同 id 的頁面的時候,無法正常切換我們想要的邏輯。

所以我選擇了通過監聽路由中的 id 參數,來達到在預覽不同頁面時候來切換開始和結束的邏輯

watch: {
    $route: {
      immediate: true,
      handler(to, from) {
        if (to.params.id) this.trainingId = to.params.id
        this.startTimer()
      }
    }
  }

調用了開始計時的方法,終于我們可以在 console 的 log 中可以看到輸出了當前的時長

Vue頁面監聽用戶預覽時間功能如何實現

然后也是最后一步,我們需要在頁面銷毀的時候調用 stopTimer 函數來清除定時器,上報數據。

由于我們的預覽頁面是通過 window.open 打開的獨立的標簽頁,所以這里是通過 destroyed 生命周期函數監聽。如果是通過路由方法進行的跳轉,那么我們需要在離開頁面的時候進行銷毀,方可再通過 destroyed 監聽到。

mounted() {
    window.addEventListener("beforeunload", e => this.beforeunloadHandler(e))
  },
  destroyed() {
    window.removeEventListener("beforeunload", e => this.beforeunloadHandler(e))
  }

通過 window 的監聽器方法來來間接調用 stopTimer 方法

methods: {
    beforeunloadHandler (e) {
      this.stopTimer()
    }
}

這里有人會問為什么不直接在 destroyed 中調用 stopTimer 方法,這樣可以分離出特有的邏輯,不與 destroyed 中其它的邏輯混在一起。提高代碼的可讀性和維護性。

關于“Vue頁面監聽用戶預覽時間功能如何實現”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

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

vue
AI

鸡泽县| 轮台县| 西乌珠穆沁旗| 嘉祥县| 浦江县| 喀什市| 台东县| 偃师市| 皋兰县| 南康市| 桐庐县| 嘉荫县| 赤城县| 阜康市| 平度市| 阿荣旗| 惠东县| 迁安市| 凤台县| 河池市| 陵川县| 诸暨市| 江安县| 和田县| 龙岩市| 新建县| 郸城县| 商丘市| 新竹市| 聂荣县| 绿春县| 深水埗区| 五家渠市| 湟中县| 德昌县| 许昌市| 宜都市| 宁安市| 从江县| 文登市| 朝阳区|