怎么使用React列表栏及购物车组件
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,本篇内容介绍了"怎么使用React列表栏及购物车组件"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一
千家信息网最后更新 2025年02月01日怎么使用React列表栏及购物车组件
); }}export default AddCut;本篇内容介绍了"怎么使用React列表栏及购物车组件"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
一、组件介绍
商家详细界面(StoreDetail组件):
import React from 'react';import axios from 'axios';import GoBack from '../smallPage/GoBack';import '../../Assets/css/storeDetail.css';import MenuList from '../../Mock/MenuList';import Order from '../menuPage/Order';import Evaluate from '../menuPage/Evaluate';import Business from '../menuPage/Business';class StoreDetail extends React.Component { constructor(props) { super(props); this.state = { food:null, menulist:MenuList }; } componentDidMount(){ axios.get("/food").then((res)=>{ this.setState({ food:res.data.result.data }); console.log(this.state.food); }); } userSelect=(index)=>{ MenuList.forEach((val,key)=>{ val.isshow=false; if(key===index){ val.isshow=true; } }); this.setState({ menulist:MenuList }); } render() { return ( this.state.food?:'' ); }}export default StoreDetail; {this.state.food.poi_info.name}{ this.state.menulist.map((value,index)=>{ if(value.isshow&&index===0){ return{ this.state.menulist.map((value,index)=>{ return (
- {value.title}
) }) }}else if(value.isshow&&index===1){ return }else if(value.isshow&&index===2){ return }else{ return ''; } }) }
点单界面(Order组件):
import React from 'react';import '../../Assets/css/order.css';import AddCut from '../smallPage/AddCut';import Cart from '../smallPage/Cart';class Order extends React.Component { constructor(props) { super(props); this.state = { list:[], leftindex:0 }; } scrollRight=(e)=>{ let scrolltop=e.target.scrollTop; let listheight=this.state.list; for(let i=0;i=listheight[i]&&scrolltop =listheight.length/2){ // 获取左边的ul,让其scrollTop往下顶 this.refs.leftul.scrollTop=listheight[i+1]; }else{ // 让其scrollTop往上顶 this.refs.leftul.scrollTop=0; } this.setState({ leftindex:i+1 }); break; } } } // 用户点击时,让当前索引变色 userClick=(index)=>{ this.setState({ leftindex:index }); this.refs.order_scroll.scrollTop=index-1>=0?this.state.list[index-1]:0; } componentDidMount(){ let order_block=document.getElementsByClassName("order_block"); let listinfo=this.state.list; // 循环遍历div,拿到每个div的偏移量,再将其push进this.state中进行修改显示,修改后得到listinfo // 若为第一个div,则只拿其自身的偏移量;否则,则拿其自身+listinfo[i-1]的偏移量 for(let i=0;i { let ele=this.refs.cart; ele.update(); } render() { return ( ); }}export default Order;{ this.props.orderlist.map((value,index)=>{ return ( // 按照索引来判断左边li的颜色
- {value.name}
) }) }{ this.props.orderlist.map((value,index)=>{ return () }) }{ value.spus.map((v,k)=>{ return (
- ) }) }
{v.name}{v.praise_content}¥{v.min_price}/份
加减页面(AddCut组件):
import React from 'react';import '../../Assets/css/addCut.css';import CartData from '../../Mock/CartData';class AddCut extends React.Component { constructor(props) { super(props); this.state = { num:0 }; } userAdd=()=>{ let addnum=this.state.num; addnum++; this.setState({ num:addnum }); this.addCart(addnum); this.props.parent.refComponent(); } userCut=()=>{ let cutnum=this.state.num; cutnum--; if(cutnum<0){ cutnum=0; } this.setState({ num:cutnum }); this.addCart(cutnum); this.props.parent.refComponent(); } addCart=(num)=>{ // 产生一个对象集合 let list={ name:this.props.name, price:this.props.price, num:num }; let same=false; if(CartData.length===0){ CartData.push(list); } for(let i=0;i0?'show':'showhidden'} src={require("../../Assets/image/minus.edae56b865f90527f2657782f67d9c3e.png")} alt=""/> 0?'show':'showhidden'}>{this.state.num}
购物车页面(Cart组件):
import React from 'react';import '../../Assets/css/cart.css';import CartData from '../../Mock/CartData';class Cart extends React.Component { constructor(props) { super(props); this.state = { cart:[], totalprice:0 }; } update=()=>{ // 读取数据 this.setState({ cart:CartData }); // 计算总价 let prices=0; for(let i=0;i ¥{this.state.totalprice}
另需{this.props.toprice}去结算
二、效果展示
"怎么使用React列表栏及购物车组件"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
组件
购物车
购物
偏移
内容
更多
界面
知识
页面
实用
学有所成
接下来
商家
困境
实际
对象
总价
情况
效果
数据
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
服务器监控接线
数据库原理与应用数学
吴忠网络技术选择
我的世界远程服务器管理
软件开发计价规范重庆
网络安全海报得奖
信息软件开发监理服务要点
护苗网络安全课堂材料
软件开发专业实地调研报告
汽车网络技术公司
图片地址写入数据库
苏联足球数据库
怎么模拟数据库表空间满了
组织开展网络安全应急
游戏服务器断开请重试是什么意思
合肥万户网络技术公司
江西省网络安全法专场竞赛答案
反洗钱宣传网络安全
工业控制网络安全系列之一
知秋数据库
幼儿园网络安全工作记录
数据库技术应用哪方面
关于青少年网络安全的文章
iphone软件开发笔记本
服务器废纸箱
天津常见软件开发代理价钱
数据库如果被删除了
数据库中的外键是怎么产生的
中小学校对网络安全渗透要求
宁夏惠普服务器维修哪家便宜