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

相关推荐
枫,为落叶2 分钟前
【vue】导出excel
前端·vue.js·excel
转转技术团队3 分钟前
当 AI 走进前端开发:代理插件的全流程开发实践
前端·javascript·ai编程
慧一居士5 分钟前
Quill 富文本编辑器 功能介绍,使用场景说明,使用示例演示
前端
FinClip7 分钟前
100%关税与软件封锁下,信创为何是破局关键?
前端
晴殇i9 分钟前
一行生成绝对唯一 ID:别再依赖 Date.now() 了!
前端·javascript·vue.js
CrabXin25 分钟前
前端如何用 CDN 加速网站性能全解析
前端
beckyyy26 分钟前
WebSSH的简单实现
前端·ssh
GISer_Jing32 分钟前
透过浏览器原理学习前端三剑客:HTML、CSS与JavaScript
前端·javascript·css·html
长空任鸟飞_阿康35 分钟前
提示词管理器设计:从需求到用户体验的高效落地逻辑
前端·人工智能·ux
零點壹度ideality42 分钟前
鸿蒙实现可以上下左右滑动的表格-摆脱大量ListScroller
前端·harmonyos