Vue3項目中的hooks的使用教程
今天我們稍微說一下 vue3 項目中的 hooks 的使用,其實這個 hooks 呢是和 vue2 當(dāng)中的 mixin 是類似的,學(xué)習(xí)過 vue2 的小伙伴一定對 mixin 一定比較熟悉,就算沒用過也一定了解過,也就是混入,通過 mixin 混入來分發(fā) vue 組件中的可復(fù)用功能。一個混入對象可以包含任意組件選項。當(dāng)組件使用混入對象時,所有混入對象的選項將被“混合”進入該組件本身的選項。而 vue2 的 hooks 函數(shù)與 mixin 混入的區(qū)別,主要是 hooks 是函數(shù)。
hooks 特點
vue3 中的 hooks 函數(shù)相當(dāng)于 vue2 里面的 mixin 混入,不同在于 hooks 是函數(shù)。
vue3 中的 hooks 函數(shù)可以提高代碼的復(fù)用性,能夠在不同的組件當(dāng)中都利用 hooks 函數(shù)。
hooks 函數(shù)可以與 mixin 連用,但是不建議。
hooks 基本使用
首先我們不管 hooks 哈,我們先寫一個小功能,就是獲取頁面的寬高值,這個是講解 hooks 的常用案例了,都是老演員了,我們也來整一個。
我不啰嗦了,直接寫代碼吧。
<template>
<h3>hooks</h3>
<p>頁面寬度: {{screen.width}}</p>
<p>頁面高度: {{screen.height}}</p>
<el-button @click="getWH">獲取頁面的寬高</el-button>
</template>
<script setup>
import { reactive } from 'vue'
const screen = reactive({
width: 0,
height: 0
})
const getWH = () => {
screen.width = document.documentElement.clientWidth
screen.height = document.documentElement.clientHeight
}
</script>
<style scoped>
</style>
上面的代碼其實很簡單了就,有兩個標(biāo)簽,顯示可視頁面的長度和寬度,然后有一個按鈕獲取最新的長寬進行顯示。

這個功能是可以順利實現(xiàn)的哈。如果我們需要在另一個頁面也想實現(xiàn)這個功能的話,也很簡單,在直接把上面的代碼復(fù)制一下到另一個需要實現(xiàn)的頁面就可以了。
但是
有沒有發(fā)現(xiàn)一個問題,就是一個頁面需要就復(fù)制一遍,一個頁面需要就復(fù)制一遍,如果有一百個頁面就復(fù)制一百遍,代碼一兩行還好,如果是一個超級龐大的工具類,那么在像這樣實現(xiàn)的話,是不是就過于復(fù)雜了,而且還不好實現(xiàn),那這個問題怎么解決呢?啊哈哈哈哈,沒錯了寶子們,就是 hooks 。
我們針對上面的案例,我們使用 hooks 簡單的實現(xiàn)一下。
首先,我們在 src 文件夾下創(chuàng)建一個 hooks 文件夾。

在 hooks 文件夾下創(chuàng)建一個文件,名字就叫做 useScreenWh.js 文件

接下來就很簡單了,我們把獲取可視化界面的代碼放進這個 js 文件,然后導(dǎo)出去,給其他頁面使用就可以了。
import { reactive } from 'vue'
export default function () { // 導(dǎo)出一個默認(rèn)方法
// 創(chuàng)建一個對象,保存寬度和高度值
const screen = reactive({
width: 0,
height: 0
})
// 創(chuàng)建一個方法,獲取可視化界面的寬度和高度值
const getWH = () => {
screen.width = document.documentElement.clientWidth
screen.height = document.documentElement.clientHeight
}
return { screen, getWH } // 方法返回寬高值
}
然后在需要使用 hooks 的文件引入就可以使用了。
<template>
<h3>hooks</h3>
<p>頁面寬度: {{screen.width}}</p>
<p>頁面高度: {{screen.height}}</p>
<el-button @click="getWH">獲取頁面的寬高</el-button>
</template>
<script setup lang="ts">
// 導(dǎo)入 hooks
import screenWH from '../hooks/useScreenWh.js'
// 因為 screenWH 是一個導(dǎo)出的方法,所以需要調(diào)用一下子,然后順便解構(gòu)一下就可以在模板使用了。
let { screen, getWH } = screenWH()
</script>
<style scoped>
</style>
好了,我們保存看一下效果。

和之前是完全一樣的。
到此這篇關(guān)于Vue3項目中的hooks的使用教程的文章就介紹到這了,更多相關(guān)Vue3 hooks內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue自定義指令實現(xiàn)元素滑動移動端適配及邊界處理
這篇文章主要為大家介紹了vue自定義指令實現(xiàn)元素滑動移動端適配及邊界處理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09
vue?watch監(jiān)聽觸發(fā)優(yōu)化搜索框的性能防抖節(jié)流的比較
這篇文章主要為大家介紹了vue?watch監(jiān)聽觸發(fā)優(yōu)化搜索框的性能防抖節(jié)流的比較,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10
vue嵌套路由與404重定向?qū)崿F(xiàn)方法分析
這篇文章主要介紹了vue嵌套路由與404重定向?qū)崿F(xiàn)方法,結(jié)合實例形式分析了vue.js嵌套路由與404重定向的概念、原理、實現(xiàn)步驟與相關(guān)操作技巧,需要的朋友可以參考下2018-05-05
Vue CLI3創(chuàng)建項目部署到Tomcat 使用ngrok映射到外網(wǎng)
這篇文章主要介紹了Vue CLI3創(chuàng)建項目部署到Tomcat 使用ngrok映射到外網(wǎng),本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-05-05
vue單頁應(yīng)用加百度統(tǒng)計代碼(親測有效)
這篇文章主要介紹了vue單頁應(yīng)用加百度統(tǒng)計代碼的解決方法,需要的朋友參考下吧2018-01-01

