如何在项目中定义和使用hooks函数?

1、hooks就是钩子的意思

2、你可以将它想象成用来触发的一种工具

3、hooks是一个独立的文件

4、hooks的逻辑是可复用的,可以想象成是函数的封装

5、hooks可以封装数据和变量

5、hooks的文件名以及函数名以use开头,例如:useTheme.js / useTheme()

封装函数

在项目中经常碰到相同逻辑的功能,有的同学可能会将该功能封装成函数,单独放到utils或者某js文件中,在相同逻辑的地方复用。这种复用的意识其实就是hooks的一种。这里举一个正常函数封装的例子:

javascript 复制代码
// @/utils.js
// 数组去重
  export const arrSet = (v) => {
     return [...new Set(v)]
  }

// 页面
import { arrSet } from "@/utils.js"
// 使用
const getList = () => {
  let arr = [3,4,5,3,7,5,8]
  arr = arrSet(arr); // 使用函数
}

正常的引入import引入对应的函数,你可能在一个页面引入多个工具函数,例如:

javascript 复制代码
import { arrSet, arrObjSet, somethingSet } from "@/utils.js"

hooks其实也是类似的形式,只不过是封装成函数的形式:useTheme()的形式将工具函数解构出来 这里我来展示如何封装hooks

javascript 复制代码
// useTheme.js
export const useTheme = () => {
  
  // 数组去重
  const arrSet = (v) => {
     return [...new Set(v)]
  }

  // 数组对象去重
  const arrObjSet = (v) => {
     return [...new Set(v.map(el=> JSON.stringify(el)))].map(el=> JSON.parse(el))
  }

  // 其它函数...

  return {
    arrSet,
    arrObjSet
    // 其它函数...
  }
}

页面使用:

javascript 复制代码
import { useTheme } from "@/hooks/useTheme.js 

// 使用
const getList = () => {
  let { arrSet } = useTheme();
  let arr = [3,4,5,3,7,5,8]
  arr = arrSet(arr); // 使用函数
}

你可以看到,hooks其实就是函数封装的一种,只不过是另一种实现方式。

封装变量

你可以在hooks内部完成响应式数据封装,通过hooks复用数据,简化页面代码,这里我以vue3项目为例,完成hooks响应式变量的封装

javascript 复制代码
// useList.js
import { reactive, toRefs } from "vue";
export const useList = () => {
  
  const state = reactive({
    // 表格数据
    tableData: [],
    // 分页数据
    pageInfo: {
      // 当前页数
      pageNum: 1,
      // 每页显示条数
      pageSize: 10,
      // 总条数
      total: 0
    },
  });

  // 其它函数...

  return {
     ...toRefs(state),
    // 其它函数...
  }
}

页面使用:

javascript 复制代码
import { useList } from "@/hooks/useList.js 

const {tableData, pageInfo} = useList()
console.log(useList())

这里我用了toRefs将数据转换成响应且可解构的形式,并且用剩余运算符...将数据全部解构出来,在页面中就可以直接使用响应式数据

html 复制代码
<template>
  <div>{{pageInfo}}</div>
</template>

hooks在项目中的角色

过大的单文件是其实是不利于维护的,各种变量、函数混在一起,hooks就可以把它们全部抽出来,将碎片化的变量、函数封装起来,分区分块,你可以把hooks想象成一个钩子,要用的时候触发它,使用hooks就可实现高内聚、低耦合。

相关推荐
有梦想的刺儿5 分钟前
webWorker基本用法
前端·javascript·vue.js
cy玩具26 分钟前
点击评论详情,跳到评论页面,携带对象参数写法:
前端
customer081 小时前
【开源免费】基于SpringBoot+Vue.JS周边产品销售网站(JAVA毕业设计)
java·vue.js·spring boot·后端·spring cloud·java-ee·开源
清灵xmf1 小时前
TypeScript 类型进阶指南
javascript·typescript·泛型·t·infer
小白学大数据1 小时前
JavaScript重定向对网络爬虫的影响及处理
开发语言·javascript·数据库·爬虫
qq_390161771 小时前
防抖函数--应用场景及示例
前端·javascript
334554322 小时前
element动态表头合并表格
开发语言·javascript·ecmascript
John.liu_Test2 小时前
js下载excel示例demo
前端·javascript·excel
Yaml42 小时前
智能化健身房管理:Spring Boot与Vue的创新解决方案
前端·spring boot·后端·mysql·vue·健身房管理
PleaSure乐事2 小时前
【React.js】AntDesignPro左侧菜单栏栏目名称不显示的解决方案
前端·javascript·react.js·前端框架·webstorm·antdesignpro