技能学习:学习使用Node.js + Vue.js,开发前端全栈网站-13-6.卡片组件的封装

简介: DIY一个卡片组件。

本篇文章我们封装一个卡片组件,不使用elementui中的卡片样式而仿照其逻辑制作,我们可以更深入理解并易于修改出自己想要的样式。

1.制作出我们想要的框架
<div class="card p-3 bg-white mt-3">
  <div class="card-header d-flex">
    <div class="fs-xxl flex-1 px-2">最新文章</div>
    <span class="iconfont icon-more text-gray"></span>
  </div>
  <div class="mt-3 mb-1 px-2">
    <div style="width: 100%;height:1px;" class="bg-gray2"></div>
  </div>
  <div class="card-body">
    <div class="nav nav-inverse d-flex jc-between px-2 pt-3 pb-2">
      <div class="nav-item">
        <div class="nav-link active" active-class="active">最热</div>
      </div>
      <div class="nav-item">
        <div class="nav-link" active-class="active">最新</div>
      </div>
      <div class="nav-item">
        <div class="nav-link" active-class="active">学习</div>
      </div>
      <div class="nav-item">
        <div class="nav-link" active-class="active">推荐</div>
      </div>
      <div class="nav-item">
        <div class="nav-link" active-class="active">作品</div>
      </div>
    </div>
    <swiper>
      <swiper-slide v-for="m in 5" :key="m">
        <div class="py-2 px-2 d-flex jc-around" v-for="n in 5" :key="n">
          <span class="text-primary">[最热]</span>
          <span class="px-2  text-gray">|</span>
          <span class="ellipsis">这条新闻好多人看啊啊啊啊啊啊啊啊啊啊啊</span>
          <span class="text-gray">2021-07-13</span>
        </div>
      </swiper-slide>
    </swiper>
  </div>
</div>

在这里插入图片描述

2.制作卡片组件

卡片组件的制作,最终要实现卡片标签,标签中有标签属性。其中属性为组件中的变量。
(1)将刚才制作的通用模板card放入Card.vue
在这里插入图片描述
(2)在主文件main.js中引入Card.vue组件

// 卡片组件
import Card from './components/Card.vue'
Vue.component('m-card', Card)

在这里插入图片描述
此时组件设置成功,因为此card是手机端,故设置标签为m-card。
(3)在Home.vue使用Card组件

<m-card></m-card>

在这里插入图片描述
此时就将组件显示在页面中了:
在这里插入图片描述

3.优化卡片组件

此时Card.vue已经成为组件,使用m-card标签就可以使用,但组件的作用是复用性,所以我们要将组件标签的属性做出,同时使用vue的slot标签进行其内容的填充(往下看就明白了)。
(1)将组件中非固定内容取出,也就是下图所指部分:
在这里插入图片描述
同时用slot标签代替:
在这里插入图片描述
然后将取出的内容放在m-card标签中:
在这里插入图片描述
此时内容部分依旧显示:
在这里插入图片描述
(2)为m-card标签添加属性
就如

标签一样,其中包括了style属性、class属性等等,我们要在标签上添加属性,从而更改组建的标题和图标等内容。
回到Card.vue:
添加prop属性
export default {
  // 设置属性接收
  props: {
    // 其中type表示属性类型,required: true表示必填    可添加默认值default: '卡片组件'
    title: {type: String, required: true},
    icon: {type: String, required: true},
  },
}

在这里插入图片描述
同时,将上方对应的标题和图标进行动态绑定。由于之前没有对标题前加iconfont,现在加一下:
在这里插入图片描述
保存后,此时页面中卡片组件没有标题及图标内容:
在这里插入图片描述
现在我们对m-card组件添加属性:
在这里插入图片描述
页面显示标题和图标:
在这里插入图片描述
成功,再添加一个标签:
在这里插入图片描述
成功,效果还行:
在这里插入图片描述

4.总结

卡片组件,就是封装了一个外部轮廓到.vue组件文件中,然后使用component将其当作标签使用。定义属性的目的是将外部的值传入到.vue组件中的变量上,从而达到标签中属性的效果。

5.延申

在目前封装的卡片组件来看,我们动态绑定的就只有title和icon两项,而其中不管是轮播还是内部数据都需要我们详细写:
在这里插入图片描述
如果我们就可以在m-card外再套一层组件m-list-card来动态填写其轮播框架和内容,就不需要每次详细做一个swiper来显示内容。在不需要轮播的卡片中,我们就只用m-card即可。
创建ListCard.vue组件并引用:
将m-card标签内容全部放入ListCard.vue中,并且引用ListCard.vue以m-list-card标签来使用:
在这里插入图片描述
Home.vue添加m-list-card标签:
在这里插入图片描述
页面依旧会呈现:
在这里插入图片描述
此时我们查看外部哪些内容需要动态设置:
在这里插入图片描述
所以我们需要动态绑定的数据增加了一个分类,categories,以数组形式展现
在这里插入图片描述
同时添加m-list-card外部传值:

<m-list-card icon="list" title="相关文章" :categories="articleData"></m-list-card>

在这里插入图片描述
下方js为categoryData手动添加内容,模仿后台调用的数据json格式:
在这里插入图片描述
将我们之前分的五块分类内容写出来,注意此时categoryData为数组格式:
在这里插入图片描述
最后,将ListCard.vue中的m-card标签内部需要动态传值的内容替换
在这里插入图片描述
此时,active功能暂时删除,待数据完成绑定后我们再给其绑定动态的active。现在观察页面:
在这里插入图片描述
五个分类的标题已经呈现,现在我们需要将每个分类中的文章通过slot标签引入
在这里插入图片描述
外部使用category数据的方式:
在这里插入图片描述
此时页面正常显示了:
在这里插入图片描述
最后,为switer动态添加active
在这里插入图片描述
此时分类标题栏已经可以显示active效果:
在这里插入图片描述
下一步,关联分类下边的内容,与标题active同步:
(1)首先给swiper挂载一个名字,方便分类标题找到其对应的swiper:
在这里插入图片描述
(2)为swiper添加函数,在切换swiper时同时切换swiper的索引值,将其索引值赋值给active:
在这里插入图片描述
(3)最后,利用swiper的slideTo方法,在点击分类标题时将分类标题的索引发送给swiper:
在这里插入图片描述
此时当点击分类标题发送索引到swiper时,swiper接收索引并赋值给active,active变化,则分类标题的样式变化。
(4)如果第一次进入页面,active没有值,此时没有分类标题:
在这里插入图片描述
所以要给active一个初始值0,使其第一次进入页面时就可以效果:
在这里插入图片描述
在这里插入图片描述

下节内容我们调用后台数据接口,获取文章数据到页面中。
相关文章
|
15天前
|
前端开发 JavaScript API
(前端3D模型开发)网页三维CAD中加载和保存STEP模型
本文介绍了如何使用`mxcad3d`库在网页上实现STEP格式三维模型的导入与导出。首先,通过官方教程搭建基本项目环境,了解核心对象如MxCAD3DObject、Mx3dDbDocument等的使用方法。接着,编写了加载和保存STEP模型的具体代码,包括HTML界面设计和TypeScript逻辑实现。最后,通过运行项目验证功能,展示了从模型加载到保存的全过程。此外,`mxcad3d`还支持多种其他格式的三维模型文件操作。
|
2月前
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
55 0
|
2天前
|
开发框架 前端开发 JavaScript
uniapp开发鸿蒙,是前端新出路吗?
相信不少前端从业者一听uniapp支持开发鸿蒙Next后非常振奋。猫林老师作为7年前端er也是非常激动,第一时间体验了下。在这里也给大家分享一下我的看法
32 17
|
8天前
|
机器学习/深度学习 前端开发 算法
婚恋交友系统平台 相亲交友平台系统 婚恋交友系统APP 婚恋系统源码 婚恋交友平台开发流程 婚恋交友系统架构设计 婚恋交友系统前端/后端开发 婚恋交友系统匹配推荐算法优化
婚恋交友系统平台通过线上互动帮助单身男女找到合适伴侣,提供用户注册、个人资料填写、匹配推荐、实时聊天、社区互动等功能。开发流程包括需求分析、技术选型、系统架构设计、功能实现、测试优化和上线运维。匹配推荐算法优化是核心,通过用户行为数据分析和机器学习提高匹配准确性。
36 3
|
6天前
|
前端开发 搜索推荐 安全
陪玩系统架构设计陪玩系统前后端开发,陪玩前端设计是如何让人眼前一亮的?
陪玩系统的架构设计、前后端开发及前端设计是构建吸引用户、功能完善的平台关键。架构需考虑用户需求、技术选型、安全性等,确保稳定性和扩展性。前端可选用React、Vue或Uniapp,后端用Spring Boot或Django,数据库结合MySQL和MongoDB。功能涵盖用户管理、陪玩者管理、订单处理、智能匹配与通讯。安全性方面采用SSL加密和定期漏洞扫描。前端设计注重美观、易用及个性化推荐,提升用户体验和平台粘性。
32 0
|
1月前
|
前端开发 JavaScript 安全
揭秘!前端大牛们如何高效解决跨域问题,提升开发效率!
【10月更文挑战第30天】在Web开发中,跨域问题是一大挑战。本文介绍前端大牛们常用的跨域解决方案,包括JSONP、CORS、postMessage和Nginx/Node.js代理,对比它们的优缺点,帮助初学者提升开发效率。
72 4
|
2月前
|
人工智能 前端开发 测试技术
探索前端与 AI 的结合:如何用 GPT-4 助力开发效率
本文介绍了 GPT-4 如何成为前端开发者的“神队友”,让开发变得更加高效愉快。无论是需求到代码的自动生成、快速调试和性能优化,还是自动化测试和技术选型,GPT-4 都能提供极大的帮助。通过智能生成代码、捕捉 BUG、优化性能、自动化测试生成以及技术支持,GPT-4 成为开发者不可或缺的工具,帮助他们从繁重的手动任务中解脱出来,专注于创新和创意。GPT-4 正在彻底改变开发流程,让开发者从“辛苦码农”转变为“效率王者”。
58 0
探索前端与 AI 的结合:如何用 GPT-4 助力开发效率
|
2月前
|
JavaScript 前端开发 应用服务中间件
Vue开发中,在实现单页面应用(SPA)前端路由时的hash模式和history模式的区别及详细介绍
Vue开发中,在实现单页面应用(SPA)前端路由时的hash模式和history模式的区别及详细介绍
48 0
|
2月前
|
前端开发 JavaScript 程序员
【从前端入门到全栈】Node.js 之核心概念
【从前端入门到全栈】Node.js 之核心概念
|
2月前
|
Web App开发 JavaScript 前端开发
前端Node.js面试题
前端Node.js面试题