上集精彩
回顾上集:
- 好了,俺要开始学习React了 (基础一) - 掘金 (juejin.cn);
- 好了,俺要开始学习React了(基础二) - 掘金 (juejin.cn);
- 好啦,俺要开始学React啦(基础三)真是一场酣畅淋漓的写作时刻 - 掘金 (juejin.cn);
- React,你是对Redux情有独钟,还是对Zustand非你不嫁? - 掘金 (juejin.cn);
上集俺讲到了Zustand的使用。
本集继续
😁😁😁,老铁们,俺又来继续唠叨了,别嫌俺烦哈,俺尽量少烦点
data:image/s3,"s3://crabby-images/c6b8f/c6b8fc385720b0fd4e4de801509848f36199f79f" alt=""
美团案例
静态页面不想一步步来的话,可以下载源码:链接:pan.baidu.com/s/1v7ZRxHBb...;
- 下载其他的所需依赖:有不知道的可上网查
cmd
npm i axios json-server lodash zustand
- 添加虚拟服务指令:
json
"scripts": {
"serve": "json-server --watch server/data.json --port 3001"
},
展示商品列表
- 状态管理 zustand
cmd
npm install immer
data:image/s3,"s3://crabby-images/416fd/416fd8a82e45454f59ff7b1167e9900f5d912f20" alt=""
data:image/s3,"s3://crabby-images/58d42/58d423299b9849c640b7962c20f6620c9f1e453a" alt=""
在App.js中引入并log下,看看效果:能行😎(下图商品列表是死数据)
data:image/s3,"s3://crabby-images/c3a8a/c3a8a4e3fae7827605f38d106f77959528a36e31" alt=""
- 启动服务:
cmd
npm run serve
data:image/s3,"s3://crabby-images/62815/628157df80f6bbb965916013dea088383dc7b041" alt=""
- 展示列表:将 foodsList替换为 categories
data:image/s3,"s3://crabby-images/54ba7/54ba771c9f97b24d18346c1bf81d30b4f94f8a2c" alt=""
data:image/s3,"s3://crabby-images/34159/341594822fd06e789169bf487a7642c839c31bd5" alt=""
左侧菜单
- 菜单组件 Menu ,由于右侧已经获得到了列表数据,就不用再菜单组件 Menu 中再获取重新获取一次了,会给后台服务造成负担的,可以通过父传子组件通信来传递给菜单组件 Menu 值:
data:image/s3,"s3://crabby-images/d0a14/d0a14f816d20bf3add82686f04550d942ca866b4" alt=""
data:image/s3,"s3://crabby-images/30f3c/30f3c4afca2ab151c4a5a58e42e7aa53ea59256a" alt=""
data:image/s3,"s3://crabby-images/32f2c/32f2c7d10c2d7a681519ff9f292bb26c642f70f5" alt=""
- 状态管理菜单激活值activeIndex,并定义一个点击菜单项时该值会发生变化的动作:
data:image/s3,"s3://crabby-images/40e7b/40e7b798ea9a4dfbc9d121702e10232d74c54bdd" alt=""
- 在Menu组件中添加下图两段代码:
data:image/s3,"s3://crabby-images/0ff5d/0ff5d7c30df1bf0bc57102ce286e08e1eef223a5" alt=""
点击各个菜单项后,控制台会输出相应的index值,并且同步持久化。
- 动态更新菜单项类名样式:判断activeIndex是否等于当前的index:
js
// Menu/index.js
className={classNames(
"list-menu-item",
activeIndex === index && "active"
)}
data:image/s3,"s3://crabby-images/52358/52358ea83e90c4366ac0c03c0fed25f6efe8cc3a" alt=""
- 将持久化存储修改下,只存储菜单激活
activeIndex
:
js
// store/modules/categorySlice.js
{
name: "categorySlice",
partialize: (state) => ({ activeIndex: state.activeIndex }),
storage: createJSONStorage(() => sessionStorage)
}
- 菜单项对应的商品列表切换显示:如果activeIndex === index && 商品列表视图:
data:image/s3,"s3://crabby-images/bc008/bc008a85973c0a4ab939595f6586511ba310f567" alt=""
data:image/s3,"s3://crabby-images/937c0/937c0cbd31af8d06011dbbb0efc1c70b304d95c0" alt=""
添加购物车实现
- 点击 + 号添加当前商品到购物车列表中,需要对购物车列表进行状态管理:
data:image/s3,"s3://crabby-images/fc551/fc55136d54bbecd5f3d27a2d23ade0c70c6150cf" alt=""
- 在FoodItem组件中的加号添加点击事件:
data:image/s3,"s3://crabby-images/bf6b6/bf6b63729abdb638b1a9155ac588fff0e8ee242a" alt=""
data:image/s3,"s3://crabby-images/041bb/041bbaf793d509daaab609f7ccaaaac1b0760a00" alt=""
购物车数量和总价显示
data:image/s3,"s3://crabby-images/2a658/2a658d0ab78b84545315ebb0d037e6c033ef6f6c" alt=""
data:image/s3,"s3://crabby-images/507cf/507cf53596603bd83e04986fd1ef17197444d92b" alt=""
- 计算总价price*count:
data:image/s3,"s3://crabby-images/70e87/70e870518e03456992292ca7229cceb93a76d8ae" alt=""
data:image/s3,"s3://crabby-images/01b5b/01b5b1733f1f2a0c3c65e982b4410b3b8b2c1261" alt=""
- 购物车高亮显示:
data:image/s3,"s3://crabby-images/fece7/fece7b9d6982a61518e4e34141bdbd39877d64ba" alt=""
data:image/s3,"s3://crabby-images/87b47/87b475f59e5c9234eceb3c5719f4606a700ac43b" alt=""
- 结算起送判断:
data:image/s3,"s3://crabby-images/1b9d8/1b9d81a82b5ce2b8516a0387d4406ab6d403f392" alt=""
data:image/s3,"s3://crabby-images/89886/898867debd4d5294b96ba4166b8257c5dd9a070f" alt=""
购物车列表实现
- 购物车列表渲染:直接把cart改为carts就行了,再添加个类名visible
data:image/s3,"s3://crabby-images/49624/496247e0a6026da77c6cdb67abddad70f81bd8ee" alt=""
data:image/s3,"s3://crabby-images/e86ac/e86acca395dbf56668e9c7530b1e9b785174862f" alt=""
- 修改carts里的count:添加增和减的操作,还有清空的操作
data:image/s3,"s3://crabby-images/b80d0/b80d0f2034615f66a4904f63a934721f55db3fa8" alt=""
data:image/s3,"s3://crabby-images/ef9a4/ef9a4d882ace8955497e652dfdc7eff09adc1db9" alt=""
data:image/s3,"s3://crabby-images/4d656/4d656fc5214292a6ccf875881269211eb2520a56" alt=""
- 显示和隐藏购物车:点击购物车显示购物车列表,点击遮罩层隐藏购物车列表
js
// Cart/index.js
// 控制购物车显示与隐藏
const [visible, setVisible] = useState(false);
{/* 遮罩层 添加visible类名可以显示出来 */}
<div
className={classNames("cartOverlay", visible && "visible")}
onClick={() => setVisible(false)}
/>
{/* 购物车数量 */}
<div
onClick={() => setVisible(true)}
className={classNames("icon", carts.length > 0 && "fill")}
>
{/* 添加visible类名 div会显示出来 */}
<div className={classNames("cartPanel", visible && "visible")}>
data:image/s3,"s3://crabby-images/3c41a/3c41a6edfd5b666de899cd39c5cb920807bb7cf1" alt=""
下集精彩
好了,完事,歇歇了😫
data:image/s3,"s3://crabby-images/37e1c/37e1ce8e7e5c0c077bd7cc8ce0c8b27704cd20cc" alt=""
下篇俺会讲到哪些知识点呢: 如有不当的地方,原谅解。只要懂得这篇的知识点就很棒了。
- React Router;
- CSS Module;
data:image/s3,"s3://crabby-images/f4bc6/f4bc620d94a8c4272dff4990782123b16c29946c" alt=""