如何在项目中定义和使用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就可实现高内聚、低耦合。

相关推荐
HelloReader4 分钟前
Tauri 的 Capabilities 权限管理系统
前端
喵爱吃鱼22 分钟前
关于我明明用了ref还是陷入React闭包陷阱
前端·react.js
an3174224 分钟前
解决 VSCode 中 ESLint 格式化不生效问题:新手也能看懂的配置指南
前端·javascript·vue.js
Lee川2 小时前
🚀《JavaScript 灵魂深处:从 V8 引擎的“双轨并行”看执行上下文的演进之路》
javascript·面试
汪汪队长2 小时前
谷歌浏览器自定义油猴插件
前端
ZFSS2 小时前
SeeDance Tasks API 的对接和使用
前端·人工智能
睿智的仓鼠3 小时前
🦞OpenClaw 快速部署及使用指南
前端·人工智能
前端付豪3 小时前
Nest 项目小实践之图书增删改查
前端·node.js·nestjs
比特鹰3 小时前
手把手带你用Flutter手搓人生K线
前端·javascript·flutter
大雨还洅下3 小时前
前端JS: 数组扁平化
javascript