vue基础教程(7)——构建项目级首页

同学们可以私信我加入学习群!


正文开始

  • 前言
  • 一、页面结构
  • 二、侧边栏
  • 三、主体部分
  • 总结


前言

前面我们学习了vue的路由和登录页搭建,本文将和大家共同学习首页的搭建。

首页示例如图:
在这里插入图片描述
很多项目经验比较少的同学,一般都是对某些语法很熟悉,但是对整个项目是如何从零开始搭建的,页面布局是如何通过代码实现的,可能并未过多关注。

也许有人会说,这些ui框架或者开源项目,都会开箱即用,可如果框架提供的布局无法满足要求呢,如果开源项目存在bug呢,如果企业做大做强需要UI重新设计web端呢?

我们有太多的理由去了解这些基础知识,我们可以永远不做,但是不能不会!


一、页面结构

通过上图可以看出,首页大体分为三个部分:
1.左侧侧边栏

2.上侧面包屑、标签

3.右侧页面主体

如果每块代码都解析一遍,没有必要,文章也会显得又臭又长。本文主要还是想在前面router讲解的基础上,和大家一起学习一下,项目中侧边栏和右侧主体部分,是如何设计跳转逻辑的。

所以本文重点讲解侧边栏与右侧页面主体。

二、侧边栏

在博主项目,页面结构设计代码都在main.vue中,其中侧边栏基于viewui提供的Menu组件,右侧主体则主要在layout组件中。

代码结构如下:

 <Sider>
 	<side-menu>
 		侧边栏,主要基于Menu实现
 	</side-menu>
 </Sider>

<Layout>
 <Content>
 主体
 </Content>
</Layout>

可以看出,我们Sider部分的代码主要是一个自定义的side-menu组件,代码结构如图:
在这里插入图片描述
可以看出主要由三部分组成:

1.slot,用来通过父组件,放一些简单的元素,比如网站名,比如logo图片等,在最上面。

2.menu,主要代码,用来渲染左侧的菜单。

3.div,这部分是当左侧收起来后的代码。我们可以暂时不去关注。

menu部分组件代码:

     <Menu
        ref="menu"
        v-show="!collapsed"
        :active-name="activeName"
        :open-names="openedNames"
        :accordion="accordion"
        :theme="theme"
        width="auto"
        @on-select="handleSelect">
        <template v-for="item in menuList">
            <template v-if="item.children && item.children.length === 1">
                <side-menu-item
                    v-if="showChildren(item)"
                    :key="`menu-${item.name}`"
                    :parent-item="item"></side-menu-item>
                <menu-item
                    v-else
                    :name="getNameOrHref(item, true)"
                    :key="`menu-${item.children[0].name}`">
                    <common-icon :type="item.children[0].icon || ''" />
                    <span>{{ showTitle(item.children[0]) }}</span>
                </menu-item>
            </template>
            <template v-else>
                <side-menu-item
                    v-if="showChildren(item)"
                    :key="`menu-${item.name}`"
                    :parent-item="item"></side-menu-item>
                <menu-item
                    v-else
                    :name="getNameOrHref(item)"
                    :key="`menu-${item.name}`">
                    <common-icon :type="item.icon || ''" />
                    <span>{{ showTitle(item) }}</span>
                </menu-item>
            </template>
        </template>
    </Menu>

这部分代码拆分出来后,就不难理解了,这里就是一个对menuList的循环渲染,menuList是通过我们的路由数组得到的。

循环时,判断元素是否有children对象,如果有,并且只有一个子元素,那么就不展开了,子元素的名称就是左侧侧边栏的名称。比如下图的联系我。
在这里插入图片描述
它的router结构如下:
在这里插入图片描述
因为qrCode这个节点有且只有一个子路由,那就是qrCode_contetn,所以根据上面那段代码的判断,它不再显示层级关系,直接显示【联系我】这个菜单。

把这个情况单独处理,是因为它的特殊性,它并不是显示的自身节点的信息,而是显示了唯一一个子路由的信息。其他的情况,不论是没有子路由的情况,还是多个子路由的情况,都是显示自身节点的信息。

通过上面的代码也能看出,这个判断影响的只是:

    <common-icon :type="item.icon || ''" />
    <span>{{ showTitle(item) }}</span></menu-item

而上面代码的核心组件是side-menu-item,也就是如何通过menuList中的每一个元素,渲染成对应的菜单:

<side-menu-item v-if="showChildren(item)" :key="`menu-${item.name}`" :parent-item="item"></side-menu-item>

这里有个判断,当路由节点有子路由时,才会渲染子路由组件,否则,直接显示路由的信息。

子路由,也就是side-menu-item组件代码如下:

       <Submenu :name="`${parentName}`">
        <template v-slot:title>
            <common-icon :type="parentItem.icon || ''" />
            <span>{{ showTitle(parentItem) }}</span>
        </template>
        <template v-for="item in children">
            <template v-if="item.children && item.children.length === 1">
                <side-menu-item
                    v-if="showChildren(item)"
                    :key="`menu-${item.name}`"
                    :parent-item="item"></side-menu-item>
                <menu-item
                    v-else
                    :name="getNameOrHref(item, true)"
                    :key="`menu-${item.children[0].name}`">
                    <common-icon :type="item.children[0].icon || ''" />
                    <span>{{ showTitle(item.children[0]) }}</span>
                </menu-item>
            </template>
            <template v-else>
                <side-menu-item
                    v-if="showChildren(item)"
                    :key="`menu-${item.name}`"
                    :parent-item="item"></side-menu-item>
                <menu-item
                    v-else
                    :name="getNameOrHref(item)"
                    :key="`menu-${item.name}`">
                    <common-icon :type="item.icon || ''" />
                    <span>{{ showTitle(item) }}</span>
                </menu-item>
            </template>
        </template>
    </Submenu>

这个里面就是最后一步,处理子路由节点了。根据子路由节点配置的属性值,在这里判断后进行相应的操作,如果子路由还有子节点,那就递归调用side-menu-item组件,最终完成多层路由的渲染。

三、主体部分

主体部分相较于侧边栏,要简单很多。

主体用layout布局,包含上方的标签导航和下方的内容展示部分。

代码如下:

      <Content class="main-content-con">
        <Layout class="main-layout-con">
          <div class="tag-nav-wrapper">
            <tags-nav :value="$route" @input="handleClick" :list="tagNavList" @on-close="handleCloseTag"/>
          </div>
          <Content class="content-wrapper">
            <router-view v-slot="{Component}">
              <keep-alive :include="cacheList">
                <component :is="Component"></component>
              </keep-alive>
            </router-view>
            <ABackTop :height="100" :bottom="80" :right="50" container=".content-wrapper"></ABackTop>
          </Content>
        </Layout>
      </Content>

最终效果如图:
在这里插入图片描述
因为内容展示部分是用router-view实现,所以每次路由更改后,页面内容重新渲染的部分,只有这里的内容展示部分,页面其它部位都是固定元素渲染。

路由部分的代码简单讲解下,具体的知识点,如果有兴趣请参照官网理解,如果没兴趣,暂时不去理解,并不影响简单的项目开发。

router-view是插件router提供的用法,后面Component等属性,都是router提供的用法。

keep-alive是vue3提供的组件,这是在缓存组件,符合条件的路由节点,可以按照我们的规则进入缓存数组cacheList中,缓存的数组,每次切换页面,不会重新渲染,这在有些场景下十分有用。

比如,有两个经常互相切换的页面,都有一些筛选查询功能,如果切换后,填写的查询条件就被清空,那用户体验会很糟糕,所以这里留个可以缓存的规则,当用户不想在切换某些页面时,丢失页面数据,就可以把页面对应的路由扔进cacheList中。

component组件也是vue3提供的,这是在动态渲染组件。子路由的节点那么多,有些可能是通过权限动态获取的,我们不可能把每个路由对应的组件都通过import引入到这个页面中,然后去渲染。所以就需要动态渲染的逻辑,is属性对应的就是组件,把哪个组件赋值给is,component就会渲染成对应的组件。由此,实现在这一个位置,渲染所有组件的目的。

最终首页效果图如下:
在这里插入图片描述


总结

获取资源,查看代码示例,或者联系我:

https://lizetoolbox.top:8080/#/qrCode_contact

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/573627.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

架构师系列-消息中间件(八)- RocketMQ 进阶(二)-生产端消息保障

5. RocketMQ消息保障 下面我们详细说下如何保障消息不丢失以及消息幂等性问题 5.1 生产端保障 生产端保障需要从一下几个方面来保障 使用可靠的消息发送方式注意生产端重试生产禁止自动创建topic 5.1.1 消息发送保障 5.1.1.1 同步发送 发送者向MQ执行发送消息API时&#xff0…

springBoot集成flowable

前言 Flowable可以十分灵活地加入你的应用/服务/构架。可以将JAR形式发布的Flowable库加入应用或服务&#xff0c;来嵌入引擎。 以JAR形式发布使Flowable可以轻易加入任何Java环境&#xff1a;Java SE&#xff1b;Tomcat、Jetty或Spring之类的servlet容器&#xff1b; JBoss…

网工内推 | 上市公司网络运维,大专可投,NA/NP认证优先

01 珠海世纪鼎利科技股份有限公司 招聘岗位&#xff1a;网络运维工程师 职责描述&#xff1a; 1、负责服务器安装、维护和设备管理&#xff1b; 2、负责应用系统的部署&#xff0c;升级&#xff0c;维护&#xff1b; 3、分析网络数据&#xff0c;排查网络故障及事务的应急响应…

百度网盘svip白嫖永久手机2024最新教程

百度网盘&#xff08;原名百度云&#xff09;是百度推出的一项云存储服务&#xff0c;已覆盖主流PC和手机操作系统&#xff0c;包含Web版、Windows版、Mac版、Android版、iPhone版和Windows Phone版。用户将可以轻松将自己的文件上传到网盘上&#xff0c;并可跨终端随时随地查看…

【C语言】红黑树详解以及C语言模拟

一、红黑树的性质二、红黑树的旋转操作三、红黑树的插入操作四、红黑树的删除操作五、红黑树的应用六、C语言模拟红黑树七、总结 红黑树是一种自平衡二叉查找树&#xff0c;它能够保持树的平衡&#xff0c;从而确保查找、插入和删除的最坏情况时间复杂度为O( l o g n log_n log…

软考-系统集成项目管理中级--项目人力资源管理(输入输出很重要!!!本章可能包含案例题)

本章历年考题分值统计 本章重点常考知识点汇总清单(学握部分可直接理解记忆) 10、项目沟通管理计划一般应包括以下内容:(掌握)12上59&#xff0c;10下59&#xff0c;13上53&#xff0c;13上57,14下58&#xff0c;15下58&#xff0c;16上59 考题 (1)干系人的沟通需求。 (2)针对沟…

爬虫抓取网站数据

Fiddler 配置fiddler工具结合浏览器插件 配置fiddler Tools--Options 抓包技巧 谷歌浏览器开启无痕浏览,使用SwitchyOmega配置好代理端口 Ctrl x 清理所有请求记录,可以删除指定不需要日志方便观察 设置按请求顺序 观察cookie,观察请求hesder cookie和row返回结果 Swit…

C++/QT + Mysql + Tcp 企业协作管理系统

目录 一、项目介绍 二、项目展示 三、源码获取 一、项目介绍 1、项目概要&#xff1a;C/S架构、数据库Mysql、C、QT&#xff1b;支持实时通信、局域网内通信&#xff0c;可多个客户端同时登录&#xff1b; 2、&#xff08;Server&#xff09;管理端&#xff1a;用户管理、…

科技云报道:AIGC掀算力需求革命,边缘计算将不再“边缘”

科技云报道原创。 随着以大模型为代表的AIGC时代拉开序幕&#xff0c;算力需求持续爆发&#xff0c;AI与边缘深度融合已是大势所趋&#xff0c;越来越多的企业开始积极布局GenAI。 GenAI技术的商用化部署和应用成为企业竞逐的新阵地&#xff0c;勾勒出大模型从“技术力”转向…

数组模拟几种基本的数据结构

文章目录 数组模拟单链表数组模拟双链表数组实现栈数组模拟队列总结 数组模拟单链表 首先类比结构体存储单链表&#xff0c;我们需要一个存放下一个节点下标的数组&#xff0c;还需要一个存储当前节点的值的数组&#xff0c;其次就是一个int类型的索引&#xff0c;这个索引指向…

挑战一周完成Vue3实战项目硅谷甄选Day1:项目初始化、项目配置、项目集成

一、项目初始化 node v16.4.0以上&#xff08;查看node版本 : node -v&#xff09; pnpm 8.0.0&#xff08;npm i -g pnpm8.0.0&#xff09; 在想创建的位置新建文件夹自己命名 在此文件夹下cmd:pnpm create vite 选择如下配置 Project name&#xff08;项目名称&#xff0…

Java设计模式 _创建者模式_工厂模式(普通工厂和抽象工厂)

一、工厂模式 属于Java设计模式创建者模式的一种。在创建对象时不会对客户端暴露创建逻辑&#xff0c;并且是通过使用一个共同的接口来指向新创建的对象。 二、代码示例 场景&#xff1a;花店有不同的花&#xff0c;通过工厂模式来获取花。 1、普通工厂模式 逻辑步骤&#…

Spring - 5 ( 8000 字 Spring 入门级教程 )

一&#xff1a;Spring IoC&DI 1.1 方法注解 Bean 类注解是添加到某个类上的&#xff0c; 但是存在两个问题: 使用外部包里的类, 没办法添加类注解⼀个类, 需要多个对象, ⽐如多个数据源 这种场景, 我们就需要使用方法注解 Bean 我们先来看方法注解如何使用: public c…

AI-数学-高中-42导数的概念与意义

原作者视频&#xff1a;【导数】【一数辞典】1导数的概念与意义_哔哩哔哩_bilibili .a是加速度&#xff1b;

OpenAI 笔记:获取embedding

1 输入openai的api key from openai import OpenAIclient OpenAI(api_key**) 2 举例 response client.embeddings.create(input"Hello",model"text-embedding-3-small" )print(response.data[0].embedding) 默认情况下&#xff0c;text-embedding-3-s…

配置Linux【虚拟机】与 windows【宿主机】网络互通 (面向小白,简单操作)

1. 启动虚拟机&#xff0c;运行Linux系统 这里我使用 VMware Workstation Pro 来运行Linux系统&#xff08;cent-os7&#xff09;2. 鼠标右键打开终端 3. 输入 cd /etc/sysconfig/network-scripts , 然后输入ls &#xff0c;查看当前目录下的网卡 一般来说&#xff0c;虚拟机的…

计算机网络基础认识

本篇文章是我在B站上看到关于计算机网络的介绍视频收到的启发。本篇文章的内容来自【网络】半小时看懂<计算机网络>_哔哩哔哩_bilibili 一、物理层 从常理来说&#xff0c;进行连个设备之间的通讯&#xff0c;首先最容易想到的就是使用一根线连接两个设备进行通讯。但是…

Docker的数据管理、网络通信和dockerfile

目录 一、Docker的数据管理 1. 数据卷 1.1 数据卷定义 1.2 数据卷配置 2. 数据卷容器 2.1 创建数据卷容器 2.2 使用--volume-from来挂载test1 二、端口映射 三、容器互联 1. 创建容器互联 ​编辑2. 进入test2测试&#xff08;ping 容器名/别名&#xff09; 四、Dock…

【弱监督点云分割】All Points Matter:用于弱监督三维分割的熵细化分布对齐

All Points Matter: Entropy-Regularized Distribution Alignment for Weakly-supervised 3D Segmentation 摘要&#xff1a; 伪标签被广泛应用于弱监督三维分割任务中&#xff0c;在这种任务中&#xff0c;只有稀疏的地面真实标签可供学习使用。现有方法通常依赖经验标签选择…