当前位置:首页 > 网站源码 > 正文内容

黑马商城vue实战项目(黑马javaweb网上商城项目)

网站源码2年前 (2023-04-05)487

今天给各位分享黑马商城vue实战项目的知识,其中也会对黑马javaweb网上商城项目进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

本文目录一览:

Vue实战(六)通用Table组件

本文是 Vue实战 系列的第六篇文章,主要介绍Falcon项目中通用 Table 组件的开发和使用 。Falcon项目地址:

随着业务的发展和功能的增多,我们发现不少页面都具备相似的功能,这里举几个比较俗的例子:可以多选的下拉菜单,带输入的对话框,日期选择器等等,于是我们会想办法将这些共有的功能抽取成一个个公共组件,以便能够在不同的页面或业务中使用。

对于一个中后台类的项目,一个比较常见的展示形式就是Table了,相信大家都不陌生,如下图所示:

一个Table通常由如下几个部分构成:

除此之外,由于 Table 中的数据往往都是从后端获取的,所以这个包含 Table 的页面还需要发起一个请求,并且将最终的内容渲染在表格之内,请求的过程由于是异步的,所以需要给用户展示一个 Loading 动画;当请求数据为空时,需要显示一个占位的空元素控件。

在 Falcon 项目的实践中,我们发现,每一个页面中的 Table 除了行数,列数,及单元格的内容不同之外,其它的地方,包括样式,分页及数据处理逻辑都是一样的,每次新增一个这样的页面无非就是拷贝粘贴了,那么在这种情况下,我们抽取出了一个通用的 Table 组件,取名为:TableBox。

说到这里插一个题外话:

关于这个问题我认为,如果一个功能只出现在了一个或两个页面中,往往是没有必要处理的,因为一两个功能的重复还不足以说明问题,也很难看出其中的共性,如果强行抽取的话,反而会增加维护的负担;如果出现的地方超过了两处,那么我们就需要考虑将这个功能进行抽取了,我也常常和 Team 的人说:“如果一个功能你拷贝粘贴了1次,没关系,不用纠结;2次的话,就得考虑其复用性和组件化了”。

当然,以上内容只适用于那些初期开发过程中无法预测未来变化的项目,如果刚开始产品设计的时候,就能够充分的预见和考虑未来的业务发展,并且给出详细的产品及UI设计方案,那么就另当别论了。

回到我们的主题,抽取这个 TableBox 其实并不是一气呵成的,而是在业务迭代中,不断地发现新的场景,新的问题,带着这些问题我们不断的优化 TableBox,最终达到一个较为完整的状态。这也符合 Vue 本身渐进式的理念。接下来我们花些时间,一起探讨一下这些场景和问题:

我们发现,对于不同的页面,只要带有 Table 的,其数据都需要从远端服务器获取,一般情况下,我们会在每个业务中都去写一下这个网络获取数据的逻辑,但是,如果仔细想想,你就会发现,其实这类列表数据获取和处理的逻辑都是一样的。所以针对这个情况,我们只要和后端协商好列表相关的统一 API 数据结构,如:

那么数据获取,渲染,Loading 动画展示隐藏,分页加载等操作都可以在 TableBox 中完成。

这个组件需要的只是向外暴露出数据请求的 API 地址及各种参数:

然后写好对应的获取数据的 fetchData 方法:

这样对于调用者来说,只需要简单的传入相关 API 地址及参数就可以了,数据加载的事情让 TableBox 去处理就好了,非常的方便。

因为 TableBox 组件本身是和业务无关的,所以其肯定无法知道我的这个 Table 的表头是什么,有多少行,也无法知道每一行展示什么数据,这些内容全部应该由父组件告知 TableBox。

要实现以上的功能,我们可以借助于 Vue 本身提供的强大的工具 Slot,如果简单点说,大家可以把 Slot 理解为一个坑位,因为大多数情况下,组件自己无法预先知道某块区域放置什么内容,那么组件可以先将个区域放置一个 Slot,就是挖个坑,当父组件引入子组件时,会告诉子组件往这个坑位中填充什么样的内容。

回到我们的 TableBox 组件,我们首先挖两个坑(放置两个 Slot ),命名为 ths 和 item ,分别用于表头和行列表内容:

这样对于表头的数据,可以由引入 TableBox 的父组件来指定,用法如下,其中 slot='ths' 就是刚才我们在 TableBox

中放置的 Slot

同样,对于每一行的内容,也是由引入 TableBox 的父组件来指定,用法如下:

在开发业务的过程中,遇到一个场景:当页面数据已经全部加载完毕后,在某些场景下需要改变 Table 中某些数据的状态(删除某列或改变某一列的数据)。

这里具体举个 Falcon 中的实际例子:

我们允许用户给每个项目分配多个环境,以区分测试,生产,开发和各种自定义的场景,在每个环境下,用户可以设置不同的 Git Branch 。用户点击 Choose Branch 按钮后,会触发一个请求到后端,变更当前环境的 Git Branch, 修改成功后该列表项的按钮会显示为 Current Branch 。

由于以上逻辑都是在引入了 TableBox 的父组件中完成的,其能够控制数据的刷新,由于 场景1 中我们已经把数据请求的逻辑都封装在了 TableBox 中,所以我们需要让其向外暴露出一个 Boolean 属性:reloadData,当此属性为 true 时,TableBox 会重新请求一次API,并刷新列表。

同理,由于操作数据是由父组件发起的,所父组件中也需要有同样的属性,并且和 TableBox 中的 reloadData 保持数据同步,这里用到了 Vue 2.3 版本增加的一个 .sync 修饰符进行处理 。

这样,当 reloadData 在数据更新完毕后还原为 false 状态时,我们可以显示的触发一个 emit 事件:

由于目前所有的数据获取都是在 TableBox 内部处理的,所以父组件本身是无法直接获取到数据的。但是在某些情况下,我们又希望父组件能够获取到数据,以便能够在顶层进行更灵活的处理,这时我们就需要在 TableBox 内部将数据抛出。

抛出的方式也很简单,我们可以使用 emit 方法抛出一个事件。根据这个思路我们改造一下上文提到的 fetchData 方法:

然后在父组件中监听这个事件,这样就能获取到完整的数据了。

解决了以上4个场景的问题后,我们这个 TableBox 可以说告一段落了,后续如果有遇到新的场景,新的问题,我们只需要不断的去优化去完善这个组件即可。

到目前为止,TableBox 已经应用到了我们内部的三个后台项目约几十个页面中,可以说大大节省了我们的时间,提升了整体效率。

并且随着这样的组件越来越多,甚至我们的后端工程师经过简短的培训,也可以上手部分前端页面的开发了。

最后附上 TableBox 的地址:

实战项目:基于Vue第三方库element-ui实现的金融后台管理系统

链接:

项目是 vue2.0 + element-ui + node+mongodb 构建的 后台管理系统 ,所有的数据都是从服务器实时获取的真实数据,具有真实的注册、登录、数据显示、新增数据、修改数据、删除数据等功能。

前端 : vue2 + vuex + vue-router + webpack2.0 + ES6/7 + less + element-ui

服务端 :nodejs + express + mongodb

(填写合法 账号和密码 就可以访问)

黑马的Vue项目和千峰的Vue课程谁更好?

不能轻易说谁好谁不好,把事实摆出来你自己品吧。千峰的Vue课程加起来也不超过20天,包括一个功能不齐全的项目。而黑马程序员的Vue课程总天数从2020年下半开始达到了57天,并且包括3个不同行业,不同业务的完整项目。别的不说,就说学57的Vue课程,你不太可能把Vue 学不会吧?你可以采纳我的建议,不懂的可以继续追问哦

Vue黑马头条移动端项目day01

一.开始时的一些步骤

二.具体步骤

1.准备一些字体图标,用到阿里巴巴的矢量图库: 

打开网站登录,在资源管理中找到我的项目,新建项目,将素材里面的svg导入到本地项目中去,去除颜色并提交.

2.引入vant组件库

# Vue 2 项目,安装 Vant 2:npm i vant -S

安装插件后需要重启一下vscode,重新加载.

3.复习移动端适配,rem是相对于html标签的字体大小而言的.

4.安装移动端 REM 适配

Vant 中的样式默认使用 px 作为单位,如果需要使用 rem 单位,推荐使用以下两个工具:

postcss-pxtorem 是一款 postcss 插件,用于将单位转化为 rem

lib-flexible 用于设置 rem 基准值

npm i -S amfe-flexible

main.js中引入:import 'amfe-flexible'

npm uninstall postcss-pxtorem

npm install postcss-pxtorem@5.1.1

vue实战(7):完整开发登录页面(一)

vue实战(1):准备与资料整理

vue实战(2):初始化项目、搭建底部导航路由

vue实战(3):底部导航显示、搭建各模块静态页面、添加登录页页面与路由

vue实战(4):postman测试数据、封装ajax、使用vuex管理状态

vue实战(5):总结一

vue实战(6):异步显示数据、开发Star组件

vue实战(7):完整开发登录页面(一)

vue实战(8):完整开发登录页面(二)

vue实战(9):总结二

vue实战(10):开发店铺详情(一)

vue实战(11):开发店铺详情(二)

vue实战(12):完结 + 附学习视频

这一部分内容,回到之前完成的 Login.vue 页面,做逻辑之前先完成一些必要的效果。

2)判断是否可以发送验证码

3) login.vue 页调用并判断

Vue实战篇|使用路由管理用户权限(动态路由)

权限控制是后台管理系统比较常见的需求,如果我们需要对某些页面的添加权限控制的话,那我们可以在路由管理中的权限做一些校验,没有通过权限校验的给出相应的提示或者直接跳转到报错页面。

跟着我一起来学vue实战篇路由管理权限吧!

getCurrentAuthority()函数用于获取当前用户权限,一般来源于后台数据

check()函数用于权限的校验匹配

isLogin()函数用于检验用户是否登录

路由配置元信息meta:{ authority: ["admin"] }

使用to.matched获取跳转路由的全部信息,包括父路由和子路由

使用lodash中的findLast匹配离跳转路由配置权限的元信息

引入auth.js中check()和isLogin()进行判断是否具有权限或是否已登录

如果没有权限则给出提示信息后跳转到403页面,未登录则返回登录页面

运行结果

当getCurrentAuthority()函数返回admin时,则菜单会显示所有元信息meta:{ authority: ["admin"] }的路由菜单;

如返回值为user时,菜单会显示所有元信息meta:{ authority: ["user"] }的路由菜单

接下来CrabFort会带大家一起实现更加精细化的权限设计(权限组件、权限指令)

黑马商城vue实战项目的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于黑马javaweb网上商城项目、黑马商城vue实战项目的信息别忘了在本站进行查找喔。

扫描二维码推送至手机访问。

版权声明:本文由我的模板布,如需转载请注明出处。


本文链接:http://sdjcht.com/post/8493.html

分享给朋友:

“黑马商城vue实战项目(黑马javaweb网上商城项目)” 的相关文章

如何制作高级电脑病毒(如何制作高级电脑病毒模型)

如何制作高级电脑病毒(如何制作高级电脑病毒模型)

本篇文章给大家谈谈如何制作高级电脑病毒,以及如何制作高级电脑病毒模型对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、电脑病毒是怎么编写的 2、怎样制造电脑病毒? 3...

直播现场照片图片(直播 照片)

直播现场照片图片(直播 照片)

今天给各位分享直播现场照片图片的知识,其中也会对直播 照片进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、baby直播活动现场图曝光,身穿晶钻蝴蝶结公主裙,这...

我的世界mod下载器手机版(我的世界手机版mod免费下载)

我的世界mod下载器手机版(我的世界手机版mod免费下载)

本篇文章给大家谈谈我的世界mod下载器手机版,以及我的世界手机版mod免费下载对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、《我的世界》手机版mod怎么下载? 2、我...

手机QQ简单的病毒编程代码(简单的病毒编程代码)

手机QQ简单的病毒编程代码(简单的病毒编程代码)

今天给各位分享手机QQ简单的病毒编程代码的知识,其中也会对简单的病毒编程代码进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、可以让对方手机QQ崩溃的代码...

Androidstudio音乐播放器源码(Android开发音乐播放器)

Androidstudio音乐播放器源码(Android开发音乐播放器)

今天给各位分享Androidstudio音乐播放器源码的知识,其中也会对Android开发音乐播放器进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、andro...

云服务器探针(探针 服务器)

云服务器探针(探针 服务器)

本篇文章给大家谈谈云服务器探针,以及探针 服务器对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、用云帮手登陆服务器用着怎么自动断开,再连接就连接不上了呢 2、云帮手的探...