vue3前端开发-小兔鲜项目-封装一下产品展示模块组件

vue3前端开发-小兔鲜项目-封装一下产品展示模块组件!因为这种产品展示信息的模块组件,后面我还会在其他的页面内反复使用到,所以,使用模块化开发的思路,把它单独设计成一个组件,这样可以代码复用。以后在其他的页在遇到这样的业务需求,直接调用组件就行了,里面显示什么内容,我们给他传入一个动态数据对象就行了。


1:第一步,新增一个组件,名字叫ProductItem.vue

复制代码
<script setup>
defineProps({
  goods: {
    type: Object,
    default: () => { }
  }
})
</script>

<template>
  <RouterLink to="/" class="goods-item">
    <img :src="goods.picture" alt="" />
    <p class="name ellipsis">{{ goods.name }}</p>
    <p class="desc ellipsis">{{ goods.desc }}</p>
    <p class="price">&yen;{{ goods.price }}</p>
  </RouterLink>
</template>


<style scoped lang="scss">
.goods-item {
  display: block;
  width: 220px;
  padding: 20px 30px;
  text-align: center;
  transition: all .5s;

  &:hover {
    transform: translate3d(0, -3px, 0);
    box-shadow: 0 3px 8px rgb(0 0 0 / 20%);
  }

  img {
    width: 160px;
    height: 160px;
  }

  p {
    padding-top: 10px;
  }

  .name {
    font-size: 16px;
  }

  .desc {
    color: #999;
    height: 29px;
  }

  .price {
    color: $priceColor;
    font-size: 20px;
  }
}
</style>

2:第二步,修改之前的HomeProduct.vue的子集合渲染列表的内容。

如图,我们调用了自己刚刚定义好的一个组件。这样就可以实现代码复用了。

相关推荐
一 乐3 分钟前
二手车销售|汽车销售|基于SprinBoot+vue的二手车交易系统(源码+数据库+文档)
java·前端·数据库·vue.js·后端·汽车
Giant1009 分钟前
如果要做优化,CSS提高性能的方法有哪些?
前端
dllxhcjla11 分钟前
html初学
前端·javascript·html
只会写Bug的程序员12 分钟前
【职业方向】2026小目标,从web开发转型web3开发【一】
前端·web3
LBuffer14 分钟前
破解入门学习笔记题二十五
服务器·前端·microsoft
kuxku17 分钟前
使用 SSE 与 Streamdown 实现 Markdown 流式渲染
前端·javascript·node.js
Sheldon一蓑烟雨任平生17 分钟前
Vue 用户管理系统(路由相关练习)
vue.js·vue3·axios·json-server·vue-router·vue 路由·vue-link
Sherry00728 分钟前
【译】🔥如何居中一个 Div?看这篇就够了
前端·css·面试
前端小咸鱼一条29 分钟前
18. React的受控和非受控组件
前端·react.js·前端框架
一枚前端小能手34 分钟前
🛠️ Service Worker API深度解析 - 生命周期、缓存与离线实战
前端·javascript