【Vue3从零开始-实战】S12:首页列表数据动态化

简介: 【Vue3从零开始-实战】S12:首页列表数据动态化

@@DVBVTGC2D7ROIYF4YK_@O.png


前言


实战已经开始了!之前的文章中,我们把登录注册并且都可以调用接口请求的功能做完了,而且把逻辑和组件都拆分出来单独维护。本篇文章主要是为后面的商家详情页做准

备,在首页中有一个店铺的列表,之前是在页面组件中把数据固定起来的,现在就需要将数据做成动态化了。而且还会将axios初始化的部分拆分出来,定义一些新的数据。


mock接口


🌀 动态化数据最关键的第一步就是把接口配置出来。


👉 在fastmock官网中配置列表接口


VT_5V37VTPYQ1D9J~3CLF1B.png


  • 列表接口无需传参,所以使用get请求。


  • 返回数据中配置了data,就是动态列表数据了。


封装get请求


👉 打开utils目录下面的request.js文件


PG(]NR$I0TG7N_Z25SIT0RN.png


👉 由于get请求也需要配置baseURL,所以需要将baseURL提取出来。


const $axios = axios.create({
  baseURL: 'https://www.fastmock.site/mock/eb925863ecc46f2108cd43d75f96c1cd/pro',
  time: 10000
})
复制代码


  • axios.create方法是初始化axios


  • 初始化的时候,可以传入一个对象。


  • baseURL就可以放在对象里面,time就表示多长时间算请求超时。


👉 get请求函数


export const get = (url, params = {}) => {
  return new Promise((resolve, reject) => {
    $axios.get(url, { params }).then((response) => {
      resolve(response)
    }, err => {
      reject(err)
    })
  })
}
复制代码


  • get请求传入的是一个params。


  • 需要结构出params中的数据才能传入接口,axios中的get函数会自动帮我们拼接解构出来的params。


Nearby.vue组件请求接口


🌀 在组件中请求接口,可以参考之前的Login和Register页面。


👉 引入所需的方法


import { ref } from 'vue'
import { get } from '../../utils/request'
复制代码


👉 在setup函数外层将逻辑封装


const useNearbyListEffect = () => {
  const nearbyList = ref([])
  const getNearbyList = async () => {
    const result = await get('/api/shop/list')
    if (result.data.code === 0 && result.data.data.length) {
      nearbyList.value = result.data.data
    }
  }
  return { nearbyList, getNearbyList }
}
复制代码


👉 setup函数中引用useNearbyListEffect函数


setup () {
    const { nearbyList, getNearbyList } = useNearbyListEffect()
    getNearbyList()
    return { nearbyList }
}
复制代码


  • 进入首页就要获取列表数据,所以需要直接在setup函数中调用getNearbyList函数。


Nearby.vue组件改造


PZ@WQPU`%DJHJXN0[@4$C}D.png


🌀 由于接口定义的数据项和页面中有些部分不太吻合,所以我们需要重新改造一下。


👉 修改适配的数据值


<div class="nearby__item" v-for="item in nearbyList" :key="item.id">
    <img :src="item.imgUrl" class="nearby__item__img">
    <div class="nearby__content">
      <div class="nearby__content__title">{{item.name}}</div>
      <div class="nearby__content__tags">
        <span class="nearby__content__tag">月售:{{item.sales}}</span>
        <span class="nearby__content__tag">起送:{{item.expressLimit}}</span>
        <span class="nearby__content__tag">基础运费:{{item.expressPrice}}</span>
      </div>
      <p class="nearby__content__highlight">{{item.slogan}}</p>
    </div>
</div>
复制代码


  • 中间的tags的数据并没有按照之前的数组形式返回,所以就无须嵌套循环了。


BHX7KLB$R[VV%RFO%WWW9{M.png


总结


由于本篇文章是为了之后的商家详情页的内容做准备,所以内容比较简单,主要是巩固之前学习的请求接口的方式和封装逻辑的方法。

相关文章
|
29天前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
129 64
|
1月前
|
监控 JavaScript 算法
深度剖析 Vue.js 响应式原理:从数据劫持到视图更新的全流程详解
本文深入解析Vue.js的响应式机制,从数据劫持到视图更新的全过程,详细讲解了其实现原理和运作流程。
|
1月前
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
63 1
|
1月前
|
JavaScript 开发者
在 Vue 3 中使用 Proxy 实现数据的双向绑定
【10月更文挑战第23天】Vue 3利用 `Proxy` 实现了数据的双向绑定,无论是使用内置的指令如 `v-model`,还是通过自定义事件或自定义指令,都能够方便地实现数据与视图之间的双向交互,满足不同场景下的开发需求。
64 1
|
JavaScript 前端开发
模拟Vue数据的双向绑定
Vue的数据双向绑定功能一直为人称道, Vue数据的双向数据绑定主要依赖了Object.defineProperty,这里尝试用最简单的代码, 实现数据的双向绑定Demo MVVM ViewModel基本实现原理 Gi...
943 0
|
1月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
8天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
1月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
43 1
vue学习第一章
|
1月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
30 1
|
1月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
38 1
vue学习第四章