10. Vue3中模块化深入-实现随机出现美女服务员

目录
文章目录隐藏
  1. 编写远程调用 API 组件
  2. 随机美女 API 介绍
  3. App.vue 的实现

这时候“北海九号”餐厅的老板有了新的项目,要求来的顾客可以随机选择一位美女服务员,增加刺激性,我们的任务也是作一个随机选择的菜单,每次刷新都会随机出现小红、小李或者是小张。趁这个机会,我们正好也练习一下 Vue3.x 中的模块化。

编写远程调用 API 组件

这里我们使用 axios 来进行远程随机获得图片,但是我们这里作的不是远程随机获得图片,而是模块化一个通用的远程调用 API 的组件,这个组件可以远程请求一个指定的 URL,并且返回所得到的值。 先用npm的方式安装axios

npm install axios --save

在 P09 节我们在 src 下新建了一个 hooks 文件夹,在里面我们新建一个文件,叫做useURLAxios.ts,然后先引入refaxios.在文件里写一个useUrlAxios方法,在方法里声明四个响应式变量resultloadingloadederror。声明好后,使用axios进行访问远程链接。最后记得要进行returnexport default

import { ref } from 'vue'
import axios from 'axios'

function useUrlAxios(url: string) {
    const result = ref(null)
    const loading = ref(true)
    const loaded = ref(false)
    const error = ref(null)

    axios.get(url).then((res) => {
        loading.value = false
        loaded.value = true
        result.value = res.data
    }).catch(e => {

        error.value = e
        loading.value = false
    })
    return {
        result,
        loading,
        loaded,
        error
    }
}

export default useUrlAxios

随机美女 API 介绍

这个随机美女的 API,下去大家在 mock 模拟数据平台做过一个就可以,不用传任何参数,只要进行 get 请求就可以得到随机出现小红、小李和小张的图片的地址即可。

App.vue 的实现

我们先来实现进入页面随机显示一个美女图片,然后刷新会出现不同的美女。

<template>
  <div>
    <h2>欢迎光北海九号主题餐厅</h2>
     <div>随机选择一位美女服务员</div>
    <div v-if="loading">Loading.....</div>
    <img v-if="loaded" :src="result.imgUrl" />
    <div></div>
  </div>
</template>
<script lang="ts">
import { ref } from "vue";
import useUrlAxios from "../src/hooks/useUrlAxios";
const app = {
  name: "App",
  setup() {
    const { result, loading, loaded } = useUrlAxios(
      "https://dog.ceo/api/breeds/image/random"
    );

    return { result, loading, loaded };
  },
};
export default app;
</script>

好了,我们只要刷新,都可以随机显示一张美女服务员的照片。但这不是重点,重点是我们要学会这种独立模块化的方式,让我们的代码可以复用。建议这个代码要多写两边,养成这种模块化的思维方式。

「点点赞赏,手留余香」

0

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
码云笔记 » 10. Vue3中模块化深入-实现随机出现美女服务员

发表回复