基于Vue实现的移动端手机商城项目 电商购物网站 成品源码
📂文章目录
一、📔网站题目
二、✍️网站描述
三、📚网站介绍
四、🌐网站演示
📸部分截图
🎬视频演示
五、⚙️网站代码
🧱项目结构
💒vue代码预览
六、🔧完整源码下载
七、📣更多
一、📔网站题目
⭐基于Vue实现的移动端手机商城项目 电商购物网站 成品源码,共20+页。
❤ 我的主页:【🚀获取更多优质源码】
❤ 更多源码:【🔥Web网页设计作业成品源码分享(持续更新)】
二、✍️网站描述
🏷️本项目是基于Vue2实现的手机端移动端手机商城,电商购物网站。
其中使用到的技术栈为:vue2、vue-router、json、axios、mint-ui、vant、vuex、node.js、webpack、html、css、js、tab切换、等。
其中网页包含:首页、购物车页、个人中心页、商品详情页、订单列表页、订单详情页、作者页、选择页 、自定义订单页、新闻详情页、新闻列表页、配件页、修改页、成功页、我的收藏页、分类页、订单详情 页、支付页、地址管理页、添加地址页、修改地址页、结算页等。
三、📚网站介绍
📔网站布局:采用DIV+CSS进行网页布局,兼容不同尺寸的手机移动端适配;
📘网站素材:图片均采自网络素材,符合了页面主题规范;
📒网站文件:网页采用模块化开发,并且使用.vue文件作为组件;
📙网页编辑:如(DW、HBuilder、NotePAD、VScode、Sublime、Webstorm、Text、Notepad++)都可修改代码。
四、🌐网站演示
📸部分截图
🎬视频演示
基于Vue实现的移动端手机商城项目 电商购物网站 成品演示
五、⚙️网站代码
🧱项目结构
💒vue代码预览
<template><div class="cart"><Cart-Header title="购物车"></Cart-Header><div class="cartMain"><ul><li v-for="(cart, index) in carts" class="cartList" :key="index"><!-- 购物车单选 --><div class="select" @click="chooseone(cart)"><i class="iconfont icon-xuanzekuangmoren" v-show="!cart.danx1uan"></i><i class="iconfont icon-xuanzekuangxuanzhong" v-show="cart.danx1uan" style="color:#25b5fe"></i></div><!-- 购物车商品信息 --><div class="cartImage"><img :src="cart.img"></div><div class="cartInformation"><div class="cartName">{{ cart.name }}<a class="iconfont icon-huishouzhan7" @click="shanchu(index)"></a></div><p class="cartPrice">¥{{ cart.price }}</p></div><!-- 购物车商品数量 --><div class="cartNumber"><a @click.stop="reduce(index)" class="add">-</a><input type="text" v-model="cart.value" readonly="readonly" /><a @click.stop="add(index)" class="reduce">+</a></div></li></ul></div><div class="cartImg" v-if="!carts.length"><img src="/static/img/gouwuche.png" alt="购物车图片"><h1>购物车是空的哦,快去购物吧</h1><router-link :to="{ name: 'Home' }">逛一逛</router-link></div><div class="cartFooter" v-if="carts.length"><div class="checkAll" @click="quanxuan()"><i class="iconfont icon-xuanzekuangmoren" v-show="!qx"></i><i class="iconfont icon-xuanzekuangxuanzhong" v-show="qx" style="color:#25b5fe"></i><span>全选</span></div><div class="Total">合计:<span style="font-size: 0.54rem;color:#E3211E">¥{{ sum }}</span></div><div class="Settlement"><a @click.stop="goPay">结算 {{ sumValue }}</a></div><!-- <div class="Settlementtwo"><router-link :to="{name:'Home'}" >继续购物</router-link></div> --></div></div>
</template>
<script>
import { Toast, MessageBox } from "mint-ui";
import { mapState, mapMutations, mapGetters } from "vuex";
import CartHeader from '../../common/header'
export default {name: "cart",data() {return {qx: false,};},components: {CartHeader},computed: {carts() {return this.$store.state.carts;},sum: function () {var sum = 0;this.$store.state.carts.forEach(cart => {if (cart.danx1uan) {sum += cart.price * cart.value;}});return sum;},sumValue() {var sumValue = 0;this.$store.state.carts.forEach(cart => {if (cart.danx1uan) {sumValue += parseInt(cart.value);}});return sumValue;}},methods: {...mapMutations(["shanchu", "add", "reduce", "settlement"]),chooseone(cart) {cart.danx1uan = !cart.danx1uan;for (var i = 0; i < this.carts.length; i++) {if (this.carts[i].danx1uan == false) {this.qx = false;break;} else {this.qx = true;}}},quanxuan() {console.log((this.$store.state.carts));this.qx = !this.qx;if (this.qx) {this.$store.state.carts.forEach(cart => {cart.danx1uan = true;});} else {this.$store.state.carts.forEach(cart => {cart.danx1uan = false;});}},goPay() {this.$store.state.payGoods = [];if (this.sumValue == 0) {MessageBox('提示', '请选择至少一个商品!')} else {this.$router.push({path: 'pay',})};}},created() {for (var i = 0; i < this.carts.length; i++) {if (this.carts[i].danx1uan == false) {this.qx = false;break;} else {this.qx = true;}}}
};
</script><style>
.select {float: left;margin-top: 1.5rem;padding-left: 0.5rem;
}.select i {font-size: 0.53rem;
}.checkAll {width: 24%;line-height: 1.18rem;float: left;
}.checkAll i {font-size: 0.53rem;padding-left: .5rem;
}.cart {position: absolute;width: 100%;height: 100%;z-index: 999;top: 0;left: 0;background: #f4f4f4;
}.cartheader {position: fixed;width: 100%;box-shadow: 0 0 10px #cecece;height: 1.3rem;line-height: 1.3rem;font-size: 0.35rem;padding-left: 0.3rem;background: white;top: 0;font-size: 0.41rem;
}.cartheader i {display: block;float: left;height: 50px;font-size: 0.71rem;color: black;width: 0.9rem;
}.cartList {width: 100%;height: 4rem;background: white;margin-top: 0.04rem;
}.cartMain {margin-top: 1.3rem;margin-bottom: 1.24rem;
}.cartMain ul li {list-style: none;
}.cartImage img {width: 2.6rem;height: 2.8rem;
}.cartImage {float: left;padding: 0.5rem 0.3rem;
}.cartInformation {width: 7.7rem;font-size: 0.35rem;padding-left: 0.3rem;padding-top: 0.6rem;
}.cartPrice {color: red;margin-top: 0.2rem;font-size: 0.4rem;
}.cartNumber {float: left;margin-top: 0.3rem;
}.cartNumber .add,
.cartNumber .reduce {display: block;width: 0.75rem;height: 0.75rem;line-height: 0.75rem;border: 1px solid #dedede;float: left;color: #b2b2b2;text-align: center;font-size: 0.5rem;
}.cartNumber input {width: 0.96rem;height: 0.76rem;float: left;text-align: center;border: 1px solid #dedede;
}.cartNumber .add {border-right: none;
}.cartNumber .reduce {border-left: none;
}.cartFooter {position: fixed;width: 100%;height: 1.18rem;font-size: 0.35rem;background: white;bottom: 0;display: block;border-top: 1px solid #f4f4f4;
}.cartImg img {width: 4.4rem;height: 5.2rem;display: block;margin: auto;padding-top: 1.5rem;
}.cartImg a {display: block;text-align: center;margin: 0.8rem auto;width: 110px;height: 37px;line-height: 37px;border-radius: 4px;text-align: center;background: #e0524b;color: white;font-weight: 800;font-size: 0.5rem;
}.cartName {width: 9.3rem;font-size: 0.36rem;
}.cartName a {color: black;font-size: 0.57rem;float: right;
}.cartImg h1 {margin-top: 0.5rem;text-align: center;color: #959595;font-size: 0.6rem;
}._box {width: 63%;height: 100%;float: left;
}.Total {float: left;width: 35%;text-align: center;line-height: 1.18rem;font-size: 0.35rem;
}.Settlement {width: 34%;height: 80%;background: #f81200;float: right;margin-top: .1rem;border-radius: 40px;margin-right: 0.3rem;
}.Settlementtwo {width: 50%;height: 100%;background: #e3211e;float: right;
}.Settlement a,
.Settlementtwo a {color: white;text-align: center;line-height: .98rem;display: block;font-size: 0.35rem;
}
</style>
六、🔧完整源码下载
👉🏻点击【下载链接】👈🏻
七、📣更多
👉🏻文章推荐:【修改文件修改日期为最新】
👉🏻文章推荐:【Vue项目运行步骤(详细图解)】
👉🏻文章推荐:【Web网页设计作业成品源码分享(持续更新)】
👉🏻关注我,获取更多源码~
👉🏻html网页设计、web前后端网站制作、大学生网页设计作业、个人网站制作、jQuery网站设计、uniapp小程序、vue网站设计、node.js网站设计、网页成品模板、期末大作业,各种设计应有尽有,持续更新中..
👉🏻如果我的文章对您有帮助,请“👍点赞”“✍️评论”“💗收藏” 一键三连哦!
相关文章:
基于Vue实现的移动端手机商城项目 电商购物网站 成品源码
📂文章目录 一、📔网站题目 二、✍️网站描述 三、📚网站介绍 四、🌐网站演示 📸部分截图 🎬视频演示 五、⚙️网站代码 🧱项目结构 💒vue代码预览 六、🔧完整…...
C语言:数组
数组 数组的概念 引例 如果我们要在程序中表示一个学生的成绩,我们会使用一个int来表示,如:int score。假如我们要在程序中表示一组成绩,此时我们所学的常规的数据类型就无法再表示,这个时候我们就需要使用一种新的…...
时间序列预测之FiLM
没错,就是看电影 文章目录 前言1. 问题描述2. 创新之处3. 贡献 一、时间序列在legende - fourier域的表示1. 勒让德投影2. 傅里叶变换 二、 模型结构1. LPU: Legendre Projection Unit2. FEL: Frequency Enhanced Layer3. 多尺度专家机制的混合 二、实验结果长时预测…...
【机器学习】窥数据之序,悟算法之道:机器学习的初心与远方
文章目录 机器学习入门:从零开始学习基础与应用前言第一部分:什么是机器学习?1.1 机器学习的定义1.1.1 举个例子:垃圾邮件分类器 1.2 机器学习的核心思想1.2.1 数据驱动的模式提取1.2.2 为什么机器学习比传统方法更灵活࿱…...
OpenCL介绍
OpenCL(Open Computing Language)详解 OpenCL 是一个开源的框架,用于编写在异构平台(包括中央处理单元(CPU)、图形处理单元(GPU)、数字信号处理器(DSP)和其他…...
「Mac畅玩鸿蒙与硬件42」UI互动应用篇19 - 数字键盘应用
本篇将带你实现一个数字键盘应用,支持用户通过点击数字键输入数字并实时更新显示内容。我们将展示如何使用按钮组件和状态管理来实现一个简洁且实用的数字键盘。 关键词 UI互动应用数字键盘按钮组件状态管理用户交互 一、功能说明 数字键盘应用将实现以下功能&…...
【前端知识】npm命令行详细说明
npm命令行详细说明 概述一、定义与功能二、基本命令三、配置文件与注册表四、应用场景五、高级特性 环境设置1. 设置镜像源2. 配置全局依赖存储路径3. 配置缓存路径4. 查看所有配置5. 清除缓存6. 升级npm版本 npm组件打包1. 初始化项目2. 安装依赖3. 构建脚本4. 打包项目5. 发布…...
Python网络爬虫技术详解与实践案例
Python网络爬虫技术详解与实践案例 在大数据和人工智能盛行的今天,数据的获取与分析成为许多项目和业务的关键。网络爬虫作为一种自动化的数据采集工具,广泛应用于数据挖掘、市场分析、情报收集等领域。本文将详细介绍Python网络爬虫的基本概念、工作流程、进阶技巧,并附上…...
【遥感目标检测综述】【GRSS】遥感目标检测与深度学习的相遇:挑战与进展的元综述
Remote Sensing Object Detection Meets Deep Learning: A Meta-review of Challenges and Advances 遥感目标检测与深度学习的相遇:挑战与进展的元综述 论文链接 0.论文摘要和作者信息 摘要 遥感目标检测(RSOD)是遥感领域最基…...
【大数据技术基础】 课程 第3章 Hadoop的安装和使用 大数据基础编程、实验和案例教程(第2版)
第3章 Hadoop的安装和使用 3.1 Hadoop简介 Hadoop是Apache软件基金会旗下的一个开源分布式计算平台,为用户提供了系统底层细节透明的分布式基础架构。Hadoop是基于Java语言开发的,具有很好的跨平台特性,并且可以部署在廉价的计算机集群中。H…...
【机器学习】机器学习的基本分类-监督学习-决策树-C4.5 算法
C4.5 是由 Ross Quinlan 提出的决策树算法,是对 ID3 算法的改进版本。它在 ID3 的基础上,解决了以下问题: 处理连续型数据:支持连续型特征,能够通过划分点将连续特征离散化。处理缺失值:能够在特征值缺失的…...
云计算vsphere 服务器上添加主机配置
这里是esxi 主机 先把主机打开 然后 先开启dns 再开启 vcenter 把每台设备桌面再vmware workstation 上显示 同上也是一样 ,因为在esxi 主机的界面可能有些东西不好操作 我们选择主机和集群 左边显示172.16.100.200...
Linux笔记---进程:进程替换
1. 进程替换的概念 进程替换是指在一个正在运行的进程中,用一个新的程序替换当前进程的代码和数据,使得进程开始执行新的程序,而不是原来的程序。 这种技术通常用于在不创建新进程的情况下,改变进程的行为。 我们之前谈到过for…...
量化交易backtrader实践(五)_策略综合篇(1)_股票软件指标回测
在第三章6到9节,我们学习和实践了大部分股票软件指标,且这些指标是backtrader内置指标实践中没有讲到过的。然后,在进行策略综合之前,我们先热个身,把一些可能比较有参考意义的股票软件内置指标在backtrader里给实现了…...
4.STM32通信接口之SPI通信(含源码)---软件SPI与W25Q64存储模块通信实战《精讲》
经过研究SPI协议和W25Q64,逐步了解了SPI的通信过程,接下来,就要进行战场实战了!跟进Whappy步伐! 目标:主要实现基于软件的SPI的STM32对W25Q64存储写入和读取操作! 开胃介绍(代码基本…...
MINDAGENT:游戏交互中的新兴性设计
一、摘要 1.问题/研究背景 LLM具有在多智能体系统中执行复杂调度的能力,并可以协调这些代理以完成需要广泛合作的复杂任务。 但是,目前还没有一个标准的游戏场景和相关的测试指标来评估 LLM 在游戏中的表现以及与人类玩家的合作能力。 2.研究目标/动…...
【工具变量】上市公司企业所在地城市等级直辖市、副省级城市、省会城市 计划单列市(2005-2022年)
一、包含指标: 股票代码 股票代码 股票简称 年份 所属城市 直辖市:企业所在地是否属于直辖市。1是,0否。 副省级城市:企业所在地是否属于副省级城市。1是,0否。 省会城市&a…...
C# 动态类型 Dynamic
文章目录 前言1. 什么是 Dynamic?2. 声明 Dynamic 变量3. Dynamic 的运行时类型检查4. 动态类型与反射的对比5. 使用 Dynamic 进行动态方法调用6. Dynamic 与 原生类型的兼容性7. 动态与 LINQ 的结合8. 结合 DLR 特性9. 动态类型的性能考虑10. 何时使用 Dynamic&…...
Css动画:旋转相册动画效果实现
🌈个人主页:前端青山 🔥系列专栏:Css篇 🔖人终将被年少不可得之物困其一生 依旧青山,本期给大家带来Css篇专栏内容:Css动画:旋转相册动画效果实现 前言 随着Web技术的发展,网页不再局限于静态展示&#…...
Unity 基于Collider 组件在3D 物体表面放置3D 物体
实现 从鼠标点击的屏幕位置发送射线,以射线监测点击到的物体,根据点击物体的法线向量调整放置物体的位置及朝向。 Ray ray Camera.main.ScreenPointToRay(Input.mousePosition); if (Physics.Raycast(ray, out RaycastHit hit, 100)) {obj.transform.…...
变量 varablie 声明- Rust 变量 let mut 声明与 C/C++ 变量声明对比分析
一、变量声明设计:let 与 mut 的哲学解析 Rust 采用 let 声明变量并通过 mut 显式标记可变性,这种设计体现了语言的核心哲学。以下是深度解析: 1.1 设计理念剖析 安全优先原则:默认不可变强制开发者明确声明意图 let x 5; …...
在软件开发中正确使用MySQL日期时间类型的深度解析
在日常软件开发场景中,时间信息的存储是底层且核心的需求。从金融交易的精确记账时间、用户操作的行为日志,到供应链系统的物流节点时间戳,时间数据的准确性直接决定业务逻辑的可靠性。MySQL作为主流关系型数据库,其日期时间类型的…...
在鸿蒙HarmonyOS 5中实现抖音风格的点赞功能
下面我将详细介绍如何使用HarmonyOS SDK在HarmonyOS 5中实现类似抖音的点赞功能,包括动画效果、数据同步和交互优化。 1. 基础点赞功能实现 1.1 创建数据模型 // VideoModel.ets export class VideoModel {id: string "";title: string ""…...
三维GIS开发cesium智慧地铁教程(5)Cesium相机控制
一、环境搭建 <script src"../cesium1.99/Build/Cesium/Cesium.js"></script> <link rel"stylesheet" href"../cesium1.99/Build/Cesium/Widgets/widgets.css"> 关键配置点: 路径验证:确保相对路径.…...
shell脚本--常见案例
1、自动备份文件或目录 2、批量重命名文件 3、查找并删除指定名称的文件: 4、批量删除文件 5、查找并替换文件内容 6、批量创建文件 7、创建文件夹并移动文件 8、在文件夹中查找文件...
spring:实例工厂方法获取bean
spring处理使用静态工厂方法获取bean实例,也可以通过实例工厂方法获取bean实例。 实例工厂方法步骤如下: 定义实例工厂类(Java代码),定义实例工厂(xml),定义调用实例工厂ÿ…...
大模型多显卡多服务器并行计算方法与实践指南
一、分布式训练概述 大规模语言模型的训练通常需要分布式计算技术,以解决单机资源不足的问题。分布式训练主要分为两种模式: 数据并行:将数据分片到不同设备,每个设备拥有完整的模型副本 模型并行:将模型分割到不同设备,每个设备处理部分模型计算 现代大模型训练通常结合…...
全面解析各类VPN技术:GRE、IPsec、L2TP、SSL与MPLS VPN对比
目录 引言 VPN技术概述 GRE VPN 3.1 GRE封装结构 3.2 GRE的应用场景 GRE over IPsec 4.1 GRE over IPsec封装结构 4.2 为什么使用GRE over IPsec? IPsec VPN 5.1 IPsec传输模式(Transport Mode) 5.2 IPsec隧道模式(Tunne…...
微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据
微软PowerBI考试 PL300-在 Power BI 中清理、转换和加载数据 Power Query 具有大量专门帮助您清理和准备数据以供分析的功能。 您将了解如何简化复杂模型、更改数据类型、重命名对象和透视数据。 您还将了解如何分析列,以便知晓哪些列包含有价值的数据,…...
Java线上CPU飙高问题排查全指南
一、引言 在Java应用的线上运行环境中,CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时,通常会导致应用响应缓慢,甚至服务不可用,严重影响用户体验和业务运行。因此,掌握一套科学有效的CPU飙高问题排查方法&…...
