【前端】列表页点进某个详情页,详情页可按顺序跳转到上一条/下一条的实现思路(2种)

需求概述

  • 列表页展示列表,点击某个列表可以跳转到对应的详情页,点击上一页下一页可以按列表顺序跳转到对应详情页。
  • 比如点击列表2进入到详情2,我点上一页可以跳转到详情1,点击下一页可以跳转到详情3。
  • 难点:详情页如何按顺序切换
    在这里插入图片描述
    在这里插入图片描述

一开始我是从网上搜索答案,发现关于这部分的答案很少,所以自己思考了一下,总结了两个方案出来,有其他方法的可以评论区分享

方案1:id是按顺序递增递减

  • 列表页思路:循环展示列表,点击携带id跳转到详情页;
  • 详情页思路:根据传过来的id在数据列表中请求对应数据,上一页/下一页用类似/detail/id-1 / /detail/id+1的方式请求数据

缺点:id要是非递增顺序?而且除非第一个id是确定的,不然无法判断当前是第一/最后一页
js代码示例:

  /**
   * 上一页
   */
  prev() {
    if (this.currentIndex > 0) {
      this.currentIndex= this.currentIndex - 1
      // 获取对应详情数据
      this.getData(this.currentIndex)
    }
  },
  /**
   * 下一页
   */
  next() {
  // detailList是所有数据
    if (this.currentIndex < this.detailList.length - 1) {
      this.currentIndex=this.currentIndex + 1,
   	// 获取对应详情数据
      this.getData(this.currentIndex)
    }
  },

方案2:id乱序无规律

  • 列表页思路:循环展示列表,点击携带id跳转到详情页;

  • 详情页思路:

    • 1.获取所有id的详情数据,把所有id提取出来放在一个数组(或map)里面,
    • 2.根据传过来的id用indexOf获取此id数据列表中的下标索引index
    • 3.根据此id获取当前页面详情
    • 4.下一页:先用index==id数组.length判断是不是最后一页;用index+1获取下一个的id,获取对应详情;
    • 5.上一页:先用index==0判断是不是第一页;用index-1获取下一个的id,获取对应详情;
  • 缺点:需要获取所有id然后检索,如果数据非常非常多,可能会卡顿

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在Vue中实现列表跳转详情页后进行上一条一条,可以采用如下的步骤: 1. 首先,你需要创建一个列表页面,用来展示多个条目,并提供跳转详情页的链接或按钮。可以使用Vue Router来管理页面的路由。 2. 在列表页面的数据中,你需要保存列表数据以及当前选中的索引号。可以使用data属性来定义列表数据和当前选中索引的变量。 3. 在跳转详情页时,将当前选中索引作为参数传递给详情页。可以使用Vue Router的动态路由来传递参数。 4. 在详情页中,接收传递过来的参数,并根据参数获取对应的详情数据。可以使用created钩子函数来获取参数,并根据参数请求对应的数据。 5. 在详情页中,你可以通过计算属性来获取上一条和下一条的索引。计算属性可以根据当前选中索引和列表数据的长度计算得出。在计算属性中,你需要考虑边界条件,例如第一条和最后一条。 6. 在详情页中,你可以通过computed属性获取上一条和下一条详情数据。根据上一步计算得到的索引,从列表数据中获取对应的详情数据。 7. 最后,你可以在详情页中展示上一条和下一条的链接或按钮,并绑定相应的事件。当点击链接或按钮时,通过Vue Router的push方法跳转到对应的详情页。 通过以上步骤,你就可以在Vue中实现列表跳转详情页后进行上一条一条的功能了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

coderYYY

请简单粗暴地爱我,一元一元的赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值