vue3项目(六)---detail

2023-10-14 00:30
文章标签 项目 vue3 detail

本文主要是介绍vue3项目(六)---detail,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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) returnconsole.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来获取鼠标的位置。

这篇关于vue3项目(六)---detail的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/206911

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

SpringBoot项目是如何启动

启动步骤 概念 运行main方法,初始化SpringApplication 从spring.factories读取listener ApplicationContentInitializer运行run方法读取环境变量,配置信息创建SpringApplication上下文预初始化上下文,将启动类作为配置类进行读取调用 refresh 加载 IOC容器,加载所有的自动配置类,创建容器在这个过程

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免

2. 下载rknn-toolkit2项目

官网链接: https://github.com/airockchip/rknn-toolkit2 安装好git:[[1. Git的安装]] 下载项目: git clone https://github.com/airockchip/rknn-toolkit2.git 或者直接去github下载压缩文件,解压即可。

9.8javaweb项目总结

1.主界面用户信息显示 登录成功后,将用户信息存储在记录在 localStorage中,然后进入界面之前通过js来渲染主界面 存储用户信息 将用户信息渲染在主界面上,并且头像设置跳转,到个人资料界面 这里数据库中还没有设置相关信息 2.模糊查找 检测输入框是否有变更,有的话调用方法,进行查找 发送检测请求,然后接收的时候设置最多显示四个类似的搜索结果

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令

maven发布项目到私服-snapshot快照库和release发布库的区别和作用及maven常用命令 在日常的工作中由于各种原因,会出现这样一种情况,某些项目并没有打包至mvnrepository。如果采用原始直接打包放到lib目录的方式进行处理,便对项目的管理带来一些不必要的麻烦。例如版本升级后需要重新打包并,替换原有jar包等等一些额外的工作量和麻烦。为了避免这些不必要的麻烦,通常我们