Vue3項(xiàng)目中的hooks的使用教程
今天我們稍微說一下 vue3 項(xiàng)目中的 hooks 的使用,其實(shí)這個(gè) hooks 呢是和 vue2 當(dāng)中的 mixin 是類似的,學(xué)習(xí)過 vue2 的小伙伴一定對 mixin 一定比較熟悉,就算沒用過也一定了解過,也就是混入,通過 mixin 混入來分發(fā) vue 組件中的可復(fù)用功能。一個(gè)混入對象可以包含任意組件選項(xiàng)。當(dāng)組件使用混入對象時(shí),所有混入對象的選項(xiàng)將被“混合”進(jìn)入該組件本身的選項(xiàng)。而 vue2 的 hooks 函數(shù)與 mixin 混入的區(qū)別,主要是 hooks 是函數(shù)。
hooks 特點(diǎn)
vue3 中的 hooks 函數(shù)相當(dāng)于 vue2 里面的 mixin 混入,不同在于 hooks 是函數(shù)。
vue3 中的 hooks 函數(shù)可以提高代碼的復(fù)用性,能夠在不同的組件當(dāng)中都利用 hooks 函數(shù)。
hooks 函數(shù)可以與 mixin 連用,但是不建議。
hooks 基本使用
首先我們不管 hooks 哈,我們先寫一個(gè)小功能,就是獲取頁面的寬高值,這個(gè)是講解 hooks 的常用案例了,都是老演員了,我們也來整一個(gè)。
我不啰嗦了,直接寫代碼吧。
<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>
上面的代碼其實(shí)很簡單了就,有兩個(gè)標(biāo)簽,顯示可視頁面的長度和寬度,然后有一個(gè)按鈕獲取最新的長寬進(jìn)行顯示。
這個(gè)功能是可以順利實(shí)現(xiàn)的哈。如果我們需要在另一個(gè)頁面也想實(shí)現(xiàn)這個(gè)功能的話,也很簡單,在直接把上面的代碼復(fù)制一下到另一個(gè)需要實(shí)現(xiàn)的頁面就可以了。
但是
有沒有發(fā)現(xiàn)一個(gè)問題,就是一個(gè)頁面需要就復(fù)制一遍,一個(gè)頁面需要就復(fù)制一遍,如果有一百個(gè)頁面就復(fù)制一百遍,代碼一兩行還好,如果是一個(gè)超級(jí)龐大的工具類,那么在像這樣實(shí)現(xiàn)的話,是不是就過于復(fù)雜了,而且還不好實(shí)現(xiàn),那這個(gè)問題怎么解決呢?啊哈哈哈哈,沒錯(cuò)了寶子們,就是 hooks 。
我們針對上面的案例,我們使用 hooks 簡單的實(shí)現(xiàn)一下。
首先,我們在 src 文件夾下創(chuàng)建一個(gè) hooks 文件夾。
在 hooks 文件夾下創(chuàng)建一個(gè)文件,名字就叫做 useScreenWh.js
文件
接下來就很簡單了,我們把獲取可視化界面的代碼放進(jìn)這個(gè) js 文件,然后導(dǎo)出去,給其他頁面使用就可以了。
import { reactive } from 'vue' export default function () { // 導(dǎo)出一個(gè)默認(rèn)方法 // 創(chuàng)建一個(gè)對象,保存寬度和高度值 const screen = reactive({ width: 0, height: 0 }) // 創(chuàng)建一個(gè)方法,獲取可視化界面的寬度和高度值 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' // 因?yàn)?screenWH 是一個(gè)導(dǎo)出的方法,所以需要調(diào)用一下子,然后順便解構(gòu)一下就可以在模板使用了。 let { screen, getWH } = screenWH() </script> <style scoped> </style>
好了,我們保存看一下效果。
和之前是完全一樣的。
到此這篇關(guān)于Vue3項(xiàng)目中的hooks的使用教程的文章就介紹到這了,更多相關(guān)Vue3 hooks內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue在mounted拿不到props中傳遞的數(shù)據(jù)問題
這篇文章主要介紹了vue在mounted拿不到props中傳遞的數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03深入理解Vue-cli搭建項(xiàng)目后的目錄結(jié)構(gòu)探秘
本篇文章主要介紹了深入理解Vue-cli搭建項(xiàng)目后的目錄結(jié)構(gòu)探秘,具有一定的參考價(jià)值,有興趣的可以了解一下2017-07-07vue.js中使用微信掃一掃解決invalid signature問題(完美解決)
這篇文章主要介紹了vue.js中使用微信掃一掃解決invalid signature問題(推薦),本文通過實(shí)例代碼給出解決方法,代碼簡單易懂非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04element滾動(dòng)條組件el-scrollbar的使用詳解
本文主要介紹了element滾動(dòng)條組件el-scrollbar的使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04Vue中如何進(jìn)行數(shù)據(jù)響應(yīng)式更新
Vue是一款流行的JavaScript框架,它提供了數(shù)據(jù)響應(yīng)式更新的能力,可以讓我們輕松地更新數(shù)據(jù),并自動(dòng)更新視圖,本文將介紹Vue中如何進(jìn)行數(shù)據(jù)響應(yīng)式更新,包括使用Vue的響應(yīng)式系統(tǒng)、使用計(jì)算屬性和使用Vue的watcher,需要的朋友可以參考下2023-06-06基于 Vue.js 之 iView UI 框架非工程化實(shí)踐記錄(推薦)
為了快速體驗(yàn) MVVM 模式,我選擇了非工程化方式來起步,并選擇使用 Vue.js,以及基于它構(gòu)建的 iView UI 框架。本文給大家分享基于 Vue.js 之 iView UI 框架非工程化實(shí)踐記錄,需要的朋友參考下吧2017-11-11