嗨,大家好!欢迎来到 C-Shopping ,这是一场揭开科技面纱的电商之旅。我是 C-Shopping 开源作者“继小鹏”,今天将为你介绍一款基于最新技术的开源电商平台。让我们一同探索吧!
点击 这里,http://shop.huanghanlian.com/,即刻踏上 C-Shopping 体验之旅!
项目传送门:点击 这里,https://github.com/huanghanzhilian/c-shopping,
如果你觉得有帮助,请给我一个 Star ,这会给我更大的鼓励。
背景:
意图:
改进背景中提到的问题。
目的:
打造一个完整的,适合 web 端的良好生态。
首先,让我们了解一下 C-Shopping 的技术背后。我采用了一系列最前沿的技术,包括 Next.js 、Tailwind CSS 、Headless UI 、Redux-Toolkit-RTK Query 、JWT 和 Docker 等。这确保了此项目不仅高效,而且具备强大的可扩展性。我们致力于解决传统电商平台的一些痛点:不美观、不适配不同设备、界面单一,等等。C-Shopping 通过采用最新的技术和设计理念,为用户打造了一场全响应式技术开发体验。
C-Shopping 关注用户体验。我们的界面不仅仅美观,更是响应式设计,让用户可以在任何设备上轻松愉悦地购物。个人中心和订单管理功能也让你的购物更加个性化和方便。
C-Shopping 的亮点之一是我们采用了一系列先进的技术,包括 Next.js 、Tailwind CSS 、Headless UI 、Redux-Toolkit-RTK Query 等,为用户提供了极致的性能和体验。不仅注重美观,更追求技术上的卓越。
Next.js 驱动的极速体验
C-Shopping 采用了 Next.js ,这不仅意味着网页加载速度飞快,而且还支持服务端渲染,让你体验到前所未有的流畅度。
🎨 Tailwind CSS 的时尚设计
采用 Tailwind CSS ,为 C-Shopping 注入了时尚感。每一次的界面都如同艺术品般精致,让购物成为一场视觉的盛宴。
🔧 Headless UI 自由而灵活
C-Shopping 选择了 Headless UI 风格,让用户可以在购物过程中拥有更多自由。不再受限于传统的 UI 框架,为你打开了更多定制的大门。
🔐 JWT 安全无忧
安全至上!采用 JWT 进行用户身份验证,为你的购物行为提供了最强有力的保障,让你可以放心尽情购物。
🐳 Docker 容器化的完美部署
C-Shopping 拥抱 Docker ,使得项目的部署变得前所未有的简单。容器化技术让整个项目在不同环境中都能如鱼得水地运行。
🔄 Redux Toolkit 和 RTK Query 的状态管理艺术
C-Shopping 使用 Redux Toolkit 和 RTK Query ,让状态管理变得更加轻松愉快。你可以更好地追踪应用中的数据流,确保购物体验的稳定性。
现在,让我们来看看 C-Shopping 的一些基本功能。从清晰的导航和商品展示,到方便的搜索和购物车功能,每一个细节都经过精心设计,为用户提供愉悦的购物体验。
用户端
模块 | Desktop devices | Mobile devices |
---|---|---|
首页 | ||
二级分类 | ||
三级分类 | ||
商品详情 | ||
登录 | ||
注册 | ||
搜索 | ||
购物车 | ||
支付页 | ||
个人中心 | ||
我的订单 | ||
我的评论 | ||
地址管理 | ||
近期访问 |
管理端
模块 | Desktop devices | Mobile devices |
---|---|---|
登录 | ||
管理中心 | ||
用户管理 | ||
分类管理 | ||
分类管理树状 | ||
规格管理 | ||
商品管理 | ||
订单管理 | ||
评论管理 | ||
滑块管理 | ||
banner 管理 |
🏗️ C-Shopping 项目结构:
📂 c-shopping
├── 📁 app
│ ├── 📁 main
│ │ ├── 📁 client-layout
│ │ ├── 📁 empty-layout
│ │ ├── 📁 admin
│ │ ├── 📄 layout.js
│ │ └── 📁 profile
│ ├── 📄 StoreProvider.js
│ ├── 📁 api
│ │ ├── 📁 auth
│ │ ├── 📁 banner
│ │ ├── 📁 category
│ │ ├── 📁 details
│ │ ├── 📁 order
│ │ ├── 📁 products
│ │ ├── 📁 reviews
│ │ ├── 📁 slider
│ │ ├── 📁 upload
│ │ └── 📁 user
│ ├── 📄 layout.js
│ └── 📄 not-found.js
├── 📄 commitlint.config.js
├── 📁 components
├── 📄 docker-compose.yml
├── 📁 helpers
│ ├── 📁 api
│ ├── 📄 auth.js
│ ├── 📁 db-repo
│ ├── 📄 db.js
│ ├── 📄 getQuery.js
│ └── 📄 index.js
├── 📁 hooks
├── 📄 jsconfig.json
├── 📁 models
├── 📄 next.config.js
├── 📄 package-lock.json
├── 📄 package.json
├── 📄 postcss.config.js
├── 📂 public
├── 📁 store
├── 📁 styles
├── 📄 tailwind.config.js
└── 📁 utils
主要结构解释:
📁 app: 应用程序的主要代码
📁 components: 可复用的 React 组件
📁 helpers: 辅助函数和工具
📁 hooks: 自定义 React hooks
📁 models: 数据模型定义
📁 public: 静态资源,如图片、字体等
📁 store: Redux 状态管理相关配置
📁 styles: 样式文件
📁 utils: 通用工具
...
这个结构旨在使项目组织有序,易于维护和扩展。每个部分都按照功能和职责进行划分,使团队成员更容易理解和协作。
开发环境
通过在终端运行以下命令克隆或下载存储库:
git clone https://github.com/huanghanzhilian/c-shopping.git
使用 npm 或 yarn 安装项目依赖项:
npm install
or
yarn
修改.env 的文件,在项目根目录,定义所需的环境变量。这个步骤是重要的(图片上传 OSS ):
NEXT_PUBLIC_ALI_REGION=<your ali endpoint>
NEXT_PUBLIC_ALI_BUCKET_NAME=<your ali bucket name>
NEXT_PUBLIC_ALI_ACCESS_KEY=<your ali access key>
NEXT_PUBLIC_ALI_SECRET_KEY=<your ali secret key>
NEXT_PUBLIC_ALI_ACS_RAM_NAME=<your ali acs:ram name>
NEXT_PUBLIC_ALI_FILES_PATH=<your ali files pathname>
在本地机器上安装 MongoDB
运行项目
npm run dev
注册一个账户
http://localhost:3000/register
创建帐户后,在数据库中找到您的帐户,并将 root 字段修改为 true 。role 字段修改为 admin ,这将授予您访问所有管理仪表板功能的权限
http://localhost:3000/admin
操作 MongoDB ,创建根分类
mongo
use choiceshop
db.categories.insert({
"name" : "精选好物",
"slug" : "choiceshop",
"image" : "http://huanghanzhilian-test.oss-cn-beijing.aliyuncs.com/shop/upload/image//icons/zHle_bmdM_dhu2K938MMM.webp",
"colors" : {
"start" : "#EF394E",
"end" : "#EF3F55"
},
"level" : 0
})
docker 部署
项目根目录已经配置好 docker compose ,在安装 docker 环境后,直接运行部署
docker compose up -d --build
关注公众号获得更多资讯,有任何意见或建议都欢迎提 issue ,或者到公众号。
MIT License
Copyright (c) 2024 Jipeng Huang
C-Shopping 是一个开源项目,欢迎更多的开发者加入我们的社区。你可以在我们的 GitHub 仓库中找到项目源码,提出建议或者一同参与开发。
如果你对项目感兴趣,欢迎加入我们的社区,一同为项目添砖加瓦。
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.