hooks 小demo练习

这篇博客介绍了如何在Vue中编写和使用自定义hooks,具体是一个简单的`useGetScreenWH` hooks,用于获取并展示当前页面的宽度和高度。通过在组件中引入并解构hooks,实现了点击按钮动态更新页面上的宽度和高度信息。该示例展示了如何将业务逻辑从视图层分离,提高代码复用性和可维护性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

刚写了一个hooks小demo练习,这边快速简单记录一下
要求是 在页面展示 当前屏幕的宽度高度,通过点击按钮来显示
最后通过hooks函数来运行
简陋无比的展示图如下
在这里插入图片描述
核心思想就是 从展示页面 抽离逻辑代码 抽离出去到hooks,然后引用在本页面引用hooks函数来调用

//index.vue
<template>
  <div class="box1">
    <div class="box2">
      <h1>hooks</h1>
      <h2>页面宽度{{ screen.width }}</h2>
      <h2>页面高度{{ screen.height }}</h2>
      <button @click="getWH">获取页面宽度高度</button>
    </div>
  </div>
</template>

<script setup>
import { reactive } from "vue";
import useGetScreenWH from "@/hooks/demo/useGetScreenWH";
let { screen, getWH } = useGetScreenWH();
</script>

<style lang="less" scoped>
.box1 {
  width: 300px;
  height: 300px;
  // border: 1px solid black;
  // background-color: #fff;
  position: reactive;

  .box2 {
    position: absolute;
    width: 200px;
    height: 200px;
    background-color: red;
    left: 50%;
    top: 50%;
    transform: translate(-6.25rem, -6.25rem);
  }
}
</style>

这是展示页面
然后创建hooks文件夹,在里面编写hooks函数

import { reactive } from "vue";
export default function() {
  const screen = reactive({ width: 0, height: 0 });

  const getWH = () => {
    screen.width = document.documentElement.clientWidth;
    screen.height = document.documentElement.clientHeight;
  };
  return {
    screen,
    getWH,
  };
}

hooks函数里面要用的api还是要引入的,比如reactive,export 导出一个function(){ }
,里面就是逻辑代码,最后一定一定要return 导出 变量 以及 函数方法。

然后回到 展示页面,引入这个hooks函数,然后解构赋值
在这里插入图片描述
解构出来才能在当前页面使用,好了就这样

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值