Vue3 - 自定义hook函数请求数据

<template>
  <div id="nav">
      <h2>坐标为:</h2>
      <h3>x:{{x}},y:{{y}}</h3>
      <h3 v-if="loading">正在加载中</h3>
      <h3 v-else-if="errorMsg">错误信息:{{errorMsg}}</h3>
<!--      <ul v-else>-->
<!--          <li>{{data.id}}</li>-->
<!--          <li>{{data.address}}</li>-->
<!--          <li>{{data.distance}}</li>-->
<!--      </ul>-->
      <ul v-else v-for="item in data" :key="item.id">
          <li>{{item.id}}</li>
          <li>{{item.title}}</li>
          <li>{{item.price}}</li>
      </ul>
  </div>
</template>

<script lang="ts">
    // 定义接口,约束对象的类型
    interface IAddressData {
        id: number,
        address: string,
        distance: string
    }

    interface IProductData {
        id: number,
        title: string,
        price: number
    }

    // 需求1:用户在页面中点击页面,把点击位置的横纵坐标收集并展示出来
    import {defineComponent,watch} from "vue";
    import useRequest from "@/hooks/useRequest";
    import useMousePosition from "@/hooks/useMousePosition";


    export default defineComponent({
        setup() {
            const {x,y} = useMousePosition();
            // 获取对象数据
            // const {loading,data,errorMsg} = useRequest<IAddressData>('./data/address.json')
            // 获取数组数据,因为是个数组所以要初始化
            const {loading,data,errorMsg} = useRequest<IProductData[]>('./data/product.json');
            // 监视
            watch(data,()=> {
                if (data.value) {
                    console.log(data.value.length)
                }
            })
            return {
                x,
                y,
                loading,
                data,
                errorMsg
            }
        }
    })
</script>

<style>

</style>

在这里插入图片描述
知识点
泛型就是解决类、接口、方法的复用性以及对不特定类型的数据的支持。
泛型表示传递一个T类型,在new的时候才把具体类型传入。其中T是变量可改,但通常比较常见就是写T

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值