vue3项目(六)---detail

2023-11-16

1. 详情页-页面准备和路由配置

 点击新鲜好物里的商品后,会跳转到详情页,并且会携带参数过去。

1)先准备静态页面

在views下新建一个Detail组件

 2)配置路由

//src/router/index.js
import Detail from '@/views/Detail/index.vue'
const router = createRouter({
  history: createWebHistory(import.meta.env.BASE_URL),
  routes: [
    {
      path:'/',
      component:Layout,
      children:[
            ......
        {
          path:'detail/:id',
          component:Detail
        }
      ]
    },
.........
    
  ],
 
})

3)绑定模版测试跳转

给新鲜好物的商品绑定跳转

 2.详情页-基础数据渲染

同时是封装接口,调用接口获取数据,渲染模板

注意:在渲染模板时会遇到一个问题。

 

错误原因:一开始时goods是空对象,{}.categories读取出来的是undefined

解决方法:

1.可以用可选链语法?.

2.使用v-if手动来控制渲染的时机,保证只有数据存在时才渲染。

 3.详情页-热榜区域实现

 两块热榜相比,结构一致,标题title和列表内容不同。

所以封装一个hot组件,通过传递不同的参数,来生成页面内容。

 1)创建DetailHot组件

2)在Deatil组件中调用DetailHot组件

 

 3)在apis/details.js中封装接口

 4)在DetailHot.vue中获取数据,渲染页面。

为了适配两个不同的标题和内容,需要使用props传参。

 

 4.详情页-图片预览组件封装

通过小图切换大图实现

思路:维护一个数组图片列表, 鼠标划入小图记录当前小图下标值,通过下标值
在数组中取对应图片 ,显示到大图位置。

 1)准备组件的静态模板

在components下创建ImageView

2)声明一个响应值activeIndex,用于存储当前是哪一个图片显示。

给小图绑定鼠标移入事件,当鼠标移入,获取索引值,并把索引值赋值给activeIndex。

把大图片的显示路径改为动态值。

这样就可以获取到是哪一张图片显示了。

3)激活状态显示。当鼠标移出小图时,该图片不变。

通过绑定动态样式,当索引值与activeIndex相等时,就显示样式。

 放大镜效果实现

1)滑块跟随鼠标移动

获取鼠标相对位置------>控制滑块跟随移动

使用useMouseInElement来获取鼠标位置。

import {useMouseInElement} from '@vueuse/core'

// 2.获取鼠标相对位置
const target=ref(null)
// elementX:相对于盒子左侧的距离
// elementY:相对于盒子顶部的距离
// isOutside:判断盒子是否在盒子内
const {elementX,elementY,isOutside}=useMouseInElement(target)
// 3. 控制滑块跟随鼠标移动(监听elementX/Y变化,一旦变化 重新设置left/top)
const left = ref(0)
const top = ref(0)


watch([elementX, elementY, isOutside], () => {
  console.log('xy变化了')
  // 如果鼠标没有移入到盒子里面 直接不执行后面的逻辑
  if (isOutside.value) return
  console.log('后续逻辑执行了')

  // 有效范围内控制滑块距离
  // 横向
  if (elementX.value > 100 && elementX.value < 300) {
    left.value = elementX.value - 100
  }
  // 纵向
  if (elementY.value > 100 && elementY.value < 300) {
    top.value = elementY.value - 100
  }

  // 处理边界
  if (elementX.value > 300) { left.value = 200 }
  if (elementX.value < 100) { left.value = 0 }

  if (elementY.value > 300) { top.value = 200 }
  if (elementY.value < 100) { top.value = 0 }


})

2)大图效果实现

大图的宽高是小图的2倍,移动方向和滑块的相反,并且数值是2倍。

 3)使用v-show和isOutside来控制大图的隐藏和显示

4) 使用props获取组件动态列表

 

 5.SKU组件

SKU:存货单位(英语:stock keeping unit,SKU/ ˌɛ s ˌ ke ɪˈ ju ː /),也翻译为库存单元,是一个会计学名词,定义为 库存管理中的最小可用单元 ,例如纺织品中一个SKU通常表示规格、颜色、款式,而在连锁零售门店中有时称单品为一个SKU
SKU组件的作用: 产出当前用户选择的商品规格 ,为加入购物车操作提供数据信息
熟悉一个三方组件,首先重点看什么?
答:props和emit, props决定了当前组件接收什么数据,emit决定了会产出什么数据

验证组件是否成功使用:

传入必要数据,是否交互功能正常 ------->点击选择规格,是否正常产出数据

 

 6.详情页-通用组件统一注册全局

背景:components目录下有可能还会有很多其他通用型组件,有可能在多个业务模块中共享,所有统一进行全局组件注册比较好。
步骤:
把components目录下的所有组件进行全局注册。
然后在main.js 中注册插件。

先在components下创建一个index.js文件,进行全局注册。

// 把components中的所有组件都进行全局化注册
// 通过插件的方式
import ImageView from './ImageView/index.vue'
import Sku from './XtxSku/index.vue'
export const componentPlugin={
    install(app){
        // app.component('组件的名字',使用的组件)
        app.component('XtxImageView',ImageView)
        app.component('XtxSku',Sku)
    }
}

然后在main.js中注册插件。

// 引入全局组件插件
import {componentPlugin} from '@/components'
// 注册全局组件
app.use(componentPlugin)

之后使用这两个组件时,就不会引入了,直接使用。

总结:

1.可选链(?.):用于无法判断是否存在改参数时使用,如果没有会立即返回undefined,就不会当读取为空时报错。
2.热榜区域实现中,使用了props传参。
通过共用一个组件,传递不同的参数实现。
3.放大镜效果:使用useMouseInelement来获取鼠标的位置。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

vue3项目(六)---detail 的相关文章

随机推荐

  • Koin--适用于Kotlin的超好用依赖注入框架,Dagger替代者,Koin史上最详细解说,一篇就够了,妈妈再也不用担心我不会依赖注入了

    今年呆在家中实在无聊 外面太危险了 还是在家学习比较安全可持续 过年期间 我又复习了几遍依赖注入框架Dagger 诶 什么是依赖注入 说白了就是降低跟类对象之间的耦合 当需要修改类对象的时候 能不修改被依赖的实例 其实我们平常就用到了很多的
  • Flask的使用

    1 创建项目 利用python的包安装工具pip下载wheel pip3 install flask 查看当前项目的环境 pip3 list 1 2 项目构造 static templates app py mtv model templa
  • 网络中,ping命令还能这样玩

    在网络中 ping 是一个十分强大的 TCP IP 工具 它的作用主要为 1 用来检测网络的连通情况和分析网络速度 2 根据域名得到服务器 IP 3 根据 ping 返回的 TTL 值来判断对方所使用的操作系统及数据包经过路由器数量 一般情
  • Linux:PXE批量网络装机及kickstart无人值守安装

    目录 一 pxe简介 二 pxe使用的服务 三 实施过程 四 pxe优点 五 搭建PXE远程安装服务器 六 kickstart无人值守安装 一 pxe简介 PXE 预启动执行环境 是由Inter公司开发的网络引导技术 工作在Client S
  • 集成底座POC方案说明

    企业的信息化建设是伴随企业发展不断延伸 不断升级的过程 而随着信息化体量的不断增大 复杂繁多的业务系统往往又成为信息化建设的瓶颈 而为了消除瓶颈 更便捷的打通系统的关联 针对企业实际业务建立集成底座平台则是非常有效的一种方式 通过集成底座打
  • 【软件开发】MyBatis 理论篇

    MyBatis 理论篇 1 MyBatis 是什么 MyBatis 是一个半 ORM 对象关系映射 框架 它内部封装了 JDBC 开发时只需要关注 SQL 语句本身 不需要花费精力去处理加载驱动 创建连接 创建 statement 等繁杂的
  • 小程序通过子页面选择数据返回父页面更新数据

    问题 这是父页面 首先选择 地址栏默认地址 北京 按钮 进入子页面 这是子页面 这时候点击 其他城市 名称 将 城市 id 和 名称 更新到 父页面 解决方法 var pages getCurrentPages var currPage p
  • Linux小技巧2--git与GitHub学习笔记

    Linux小技巧2 git与GitHub学习笔记 近日学习了git与GitHub 内容是麦子学院老师关于git与GitHub的教程 话不多说先贴在此处以便于自己查看 也便于需要的人学习 后续将逐渐补充一些git常见错误处理相关的知识 1 g
  • 程序员35岁的破局之道

    微信公众号访问地址 程序员35岁的破局之道 近期热推文章 1 springBoot对接kafka 批量 并发 异步获取消息 并动态 批量插入库表 2 SpringBoot用线程池ThreadPoolTaskExecutor异步处理百万级数据
  • 详解java类的生命周期

    引言 最近有位细心的朋友在阅读笔者的文章时 对java类的生命周期问题有一些疑惑 笔者打开百度搜了一下相关的问题 看到网上的资料很少有把这个问题讲明白的 主要是因为目前国内java方面的教材大多只是告诉你 怎样做 但至于 为什么这样做 却不
  • Java如何比较两个日期的先后顺序

    在 Java 中 你可以使用 java util Date 或 java time LocalDate 类来比较两个日期的先后顺序 以下是使用 java util Date 类比较两个日期的先后顺序的示例代码 java import jav
  • 面对kafka频发的rebalance,该如何处理?

    Kafka 是我们最常用的消息队列 它那几万 甚至几十万的处理速度让我们为之欣喜若狂 但是随着使用场景的增加 我们遇到的问题也越来越多 其中一个经常遇到的问题就是 rebalance 重平衡 问题 但是要想了解 rebalance 那就得先
  • java+内存分配及变量存储位置的区别

    Java内存分配与管理是Java的核心技术之一 之前我们曾介绍过Java的内存管理与内存泄露以及Java垃圾回收方面的知识 今天我们再次深入Java核心 详细介绍一下Java在内存分配方面的知识 一般Java在内存分配时会涉及到以下区域 寄
  • Mysql常用的三种数据库引擎比较

    点击上方蓝字 快速关注 ISAM ISAM是一个定义明确且历经时间考验的数据表格管理方法 它在设计之时就考虑到数据库被查询的次数要远大于更新的次数 因此 ISAM执行读取操作的速度很快 而且不占用大量的内存和存储资源 ISAM的两个主要不足
  • ReplicaSet和ReplicationController区别

    ReplicaSet是新一代的ReplicationController ReplicaSet的pod标签选择器的表达能力更强 例如ReplicaSet能同时匹配两种标签 env dev和env pro ReplicationControl
  • ajax请求二进制数据

    var url var xhr new XMLHttpRequest xhr open GET url true 也可以使用POST方式 根据接口 xhr responseType blob 返回类型blob 定义请求完成的处理函数 请求前
  • 使用不同的渲染

    11
  • ubuntu更新源报错--软件包管理器apt在验证密钥时使用了旧的方式

    目录 一 解决报错一 二 解决报错二 一 解决报错一 1 报错原信息 Key is stored in Legacy trusted gpg keyring etc apt trusted gpg see the DEPRECATION S
  • 如何编辑加密的PDF

    在不知道密码的情况下如何编辑打印pdf呢 1使用WPS打开加密的pdf 2点击打印 神奇的事情 明明没有打印权限 选择打印为PDF 3获得一个新的有权限的PDF
  • vue3项目(六)---detail

    1 详情页 页面准备和路由配置 点击新鲜好物里的商品后 会跳转到详情页 并且会携带参数过去 1 先准备静态页面 在views下新建一个Detail组件 2 配置路由 src router index js import Detail fro