###第一步 :首先电脑上已经安装react的脚手架

cnpm  install    create-react-app   -g

###第二步 :创建项目

creact-react-app   项目名(shopping)

###第三步:进入项目,看看项目是否可以正常运行

cd   shopping    ======> npm  start  或   cnpm   install   yarn   --save  后   yarn   start 

###第四步:创建两个文件夹App和shop  

将App.js和App.css移入到App文件夹中   ====》要在index.js中修改一下引入App.js的路径  

创建两个文件sp.css和sp.js 移入到shop文件夹中   

###第五步:在sp.js中写入代码 

import React, {Component} from 'react'; //---->引入react模块
import "./sp.css" //引入sp.css样式
class Sp extends Component {
constructor(props) {
super(props);
this.state={//定义一个初始化状态
good:[//将页面的数据写入good中用数组的方式保存
{img:"1.png",txt:"手工",jq:12,num:1,checked:false},//这里的图片都是本地图片,需要你本人自己替换,样式里也有一张需要替换
{img:"2.png",txt:"桌",jq:20,num:1,checked:false},
{img:"3.png",txt:"椅",jq:32,num:1,checked:false},
{img:"1.png",txt:"板凳",jq:40,num:1,checked:false}
],
c:false //定义一个状态,后面用来判断 多选框 }
}
zj(){//--->总价
var list=this.state.good;//获取list中的数据
var s=0;//声明一个s变量用来保存总价
list.forEach((v,i)=>{//循环它里面的数据
if(v.checked){//判断,当多选框被选中的时候
s+=(v.jq*v.num);//总价等于当前被选中的数据的单价*数量
}
});
return s
} jj(n){//+加按钮
var list=this.state.good;
list[n].num++;//n为当前的下标,点击后,每次数量加1
this.setState({good:list})//在更新当前的状态
}
jian(n){//-减按钮
var list=this.state.good;
list[n].num--;//n为当前的下标,点击后,每次减1
if(list[n].num<=0){判断,当数量减到0的时候,弹出“最少买一个”,后面不在执行,最低的数量是1
alert("最少买一个");
list[n].num=1;
}
this.setState({good:list})//在更新当前的状态
}
tg(n){//--->点击切换按钮 多选框 目前做了三种方法可以实现
var list=this.state.good;
list[n].checked=!list[n].checked;//取反值
// ===================================第一种方法
// var ler=list.filter((v,i)=>{//数组过滤的方法
// return v.checked//--->返回 该多选框为被选中
// });
// if(ler.length==list.length){//--->判断选中的多选框的长度和数组中的数据长度是否相同
// this.setState({good:list,c:true})//--->如果是,把全选的属性false更新为true
// }else{
// this.setState({good:list,c:false})//--->如果不是,全选属性为false
// }
// ==============================================第二种方法
// var ler=list.every((v,i)=>{//--->every当多选框都被选中的时候,条件都满足true
// return v.checked;//--->单个被选中返回false
// })
// // console.log(ler)
// this.setState({good:list,c:ler})//更新cc的状态为ler,当ler为false时,cc就是false,反之亦然
// ====================================================第三种方法
var sun=0;//声明一个sun ,用来保存数值
var ff=true;//声明一个状态 true false 判断
list.forEach((v,i)=>{//循环加判断
if(v.checked){//如果多选框被选中的时候,就让sun加1
sun++
}
})
if(sun==list.length){//当sun被选中的数量等于它当前整体的长度的时候
ff=true;//输出ff的状态为true
}else{//反之
ff=false
}
this.setState({good:list,c:ff})//让cc的状态等于当前ff的状态
} qx(){//--->全选
var list=this.state.good;
var c=!this.state.c;//--->先改变当前的全选状态为true
list.forEach((v,i)=>{//--->循环当前的list数组
v.checked=c;//--->把全选的状态true赋值给good中的checked
}); this.setState({good:list,c})//更新状态
}
js(){//--->结算
var list=this.state.good;
var a=list.filter((v,i)=>{//数组过滤的方法 满足条件,输出新的数组,把不满足条件的过滤掉
return v.checked//当多选框被选中的时候 })
console.log(a)//在控制台输出当前被选中的数据,价格,数量 等
}
render() {
return (
<div className="box">
<ul>
{
this.state.good.map((v,i)=>{//数组的map方法 修该数据后,返回一个行的新的数组
return <li key={i}>
{/*<span className={(v.checked?"active":"")+" d1"} onClick={this.tg.bind(this,i)}></span>*/}
<img src={v.checked?"/ab.png":"/aa.png"} alt="" onClick={this.tg.bind(this,i)}/>
<img src={v.img} alt=""/>
<div className="box1">
<p>{v.txt}</p>
<i>${v.jq}</i>
<input type="button" value="+" onClick={this.jj.bind(this,i)}/>
<input type="text" value={v.num} style={{width:"20px"}}/> {/*注:style后要加双花括号{{}}*/}
<input type="button" value="-" onClick={this.jian.bind(this,i)}/>
</div>
</li>
})
}
</ul>
<div className="box2">
<span className={(this.state.c?"active":"")+" d1"} onClick={this.qx.bind(this)}><b>全选</b></span>
<span>合计${this.zj()}</span>
<input type="button" value="结算" onClick={this.js.bind(this)}/>
</div>
</div>
);
}
} export default Sp;//导出

###在sp.css中写样式

.box ul{
list-style: none;
}
.box ul li{
width: 400px;
height: 150px;
line-height: 10px;
}
.box ul li:hover{
background: #ccc;
}
.box ul li>img{
margin: 10px 0;
width: 100px;
height: 100px;
float: left;
}
.d1{
float: left;
display: block;
width: 40px;
height: 40px;
border: 1px solid #000;
border-radius:50%;
}
.active{
background:url(/ab.png) no-repeat;
background-size:40px 40px;
}
.box1{
float: right;
}

###在App.js中写入代码

import React from 'react';//引入react模块
import Sp from "../shop/sp"//引入sp.js文件 class App extends React.Component {
constructor(props) {
super(props); } render() { return (
<div>
<Sp></Sp>{/* sp.js的组件*/}
</div>
);
}
} export default App;//导出

###以上一个简单的购物车已经完成了 ,欢迎联系我,一起交流学习!!!

react做的简单的购物车的更多相关文章

  1. react做的简单的选项卡

    ### 首先安装react的脚手架 cnpm    install   create-react-app   -g    只需要在电脑下载安装一次即可  ###创建项目 create-react-ap ...

  2. 使用React并做一个简单的to-do-list

    1. 前言 说到React,我从一年之前就开始试着了解并且看了相关的入门教程,而且还买过一本<React:引领未来的用户界面开发框架 >拜读.React的轻量组件化的思想及其virtual ...

  3. JavaScript做简单的购物车效果(增、删、改、查、克隆)

    比如有时候遇到下面这种情况,点击加入购物车,然后在上方的购物车中动态的添加商品以及商品的信息,我们就可以通过JavaScript实现简单的这些操作. 首先我们需要在html文档中,通过css对页面的布 ...

  4. angular做的简单购物车

    虽然本人也是刚刚才开始学习angular.js,并不是非常会,但是这并不能阻止我对angular的喜爱.因为它太省代码了,比如说一个比较简单的购物车,就是只有商品名称,单价,数量,小计,总计和删除功能 ...

  5. 使用MongoDB和JSP实现一个简单的购物车系统

    目录 1 问题描述  2 解决方案  2.1  实现功能  2.2  最终运行效果图  2.3  系统功能框架示意图  2.4  有关MongoDB简介及系统环境配置  2.5  核心功能代码讲解  ...

  6. React Native超简单完整示例-tabs、页面导航、热更新、用户行为分析

    初学React Native,如果没有人指引,会发现好多东西无从下手,但当有人指引后,会发现其实很简单.这也是本人写这篇博客的主要原因,希望能帮到初学者. 本文不会介绍如何搭建开发环境,如果你还没有搭 ...

  7. react UI交互 简单实例

    <body><!-- React 真实 DOM 将会插入到这里 --><div id="example"></div> <!- ...

  8. 【Bugly干货分享】一起用 HTML5 Canvas 做一个简单又骚气的粒子引擎

    Bugly 技术干货系列内容主要涉及移动开发方向,是由Bugly邀请腾讯内部各位技术大咖,通过日常工作经验的总结以及感悟撰写而成,内容均属原创,转载请标明出处. 前言 好吧,说是“粒子引擎”还是大言不 ...

  9. FineUI小技巧(1)简单的购物车页面

    起因 最初是一位 FineUI 网友对购物车功能的需求,需要根据产品单价和数量来计算所有选中商品的总价. 这个逻辑最好在前台使用JavaScript实现,如果把这个逻辑移动到后台C#实现,则会导致过多 ...

随机推荐

  1. [2019南昌邀请赛网络赛D][dp]

    https://nanti.jisuanke.com/t/38223 Xiao Ming recently indulges in match stick game and he thinks he ...

  2. IDEA控制台中文乱码解决

    关于IDEA中文乱码的解决方法,如下. 1.打开idea安装目录,选择 打开文件,末尾添加-Dfile.encoding=UTF-8 2.打开IntelliJ IDEA>File>Sett ...

  3. 2019 ICPC Asia Yinchuan Regional

    目录 Contest Info Solutions A. Girls Band Party B. So Easy D. Easy Problem E. XOR Tree F. Function! G. ...

  4. CSP 2019 退役记

    声明:博主不会时空穿越,也没有造成恐慌,不应禁赛三年 Day0 上午:打板子 Polya定理; exkmp; exbsgs; 乘法逆元; 矩阵快速幂; 扫描线; ST表; excrt; Dirichl ...

  5. 搭建自己的博客(十七):添加每日阅读量并使用highcharts通过图表显示

    之前写了单篇博客的阅读量统计,今天添加了博客总阅读量统计,并且使用highcharts图表显示. 1.变化的部分

  6. RSYNC @ERROR: AUTH FAILED ON MODULE XXX 解决思路及附录RSYNC常见问题及解决办法

    使用rsync往服务器上传文件时,client报如下异常: @ERROR: auth failed on module XXX rsync error: error starting client-s ...

  7. vue日常学习

    1.$refs可以用来进行父子级间通信.ref被用于作为子组件的索引ID,用以方便的在js中直接访问子组件.用法如下parent.$refs.idname 使用方法: 在父级元素上加上ref属性 &l ...

  8. vmware如何克隆多个linux系统

    安装一次系统相对来说耗时较长,且还要做各种配置,那么克隆就不失为一种好的选择.接下来我把我做系统克隆的步骤写下来,供大家参考: 右键点击已经安装的虚拟机,选择管理-->克隆,接下来弹出一个窗口 ...

  9. 位于0/nut文件里的'Calculated'边界条件是什么意思?【翻译】

    翻译自:CFD-online 帖子地址:http://www.cfd-online.com/Forums/openfoam-pre-processing/140984-what-does-calcul ...

  10. Hibernate---进度1

    关联映射:http://www.cnblogs.com/huxi/archive/2009/12/15/1624988.html 关联映射,hibernate查询方式:http://www.cnblo ...