react 之自添加属性并获取

react小项目–购物车

效果图如下:
滑稽版购物车
如图所示 美其名曰购物车,实际是一个粗糙的步进器
然后带一丢算法 得出总价
每次‘+’或者“-”的时候 被禁用的输入框默认值会改变
但是在默认值为0是 点击‘-’无效

  • 当时想的思路,在点击‘+’,“-”按钮时怎么获取输入框的值 卡壳了

直到*data-id创建属性, 当点击‘-’或‘+’时 函数操作使用e.target.dataset.id获取值

代码如下:结构

// 环境 react脚手架 
//   jsx抽离
         list(){
             return(
               this.state.list.map((item)=>{return(
                   <li key={item.id}>
                  <span>${item.price}</span><span>{item.goods}</span>
                   <button onClick={this.decrease} data-id={item.id} >-</button > 
                   <input type="text" value={item.x} disabled />
                   <button onClick={this.increase} data-id={item.id}>+</button>
                   <span>$=={item.sum}</span></li>)
                   }
                   )
             )
         }
 //   当点击‘+’
         increase=(e)=>{
           const n=e.target.dataset.id;
           const {list}=this.state
               // console.log(list,'...',n);
      list.map((item)=>{
                   if(item.id===Number(n)){
                       item.x++
                       console.log(item.x);
                   item.sum=item.price*item.x}
                   return 0;
                   //此处疑问哈 标记 必须得return哈子 等有空了再瞅瞅
               })
          this.setState({
              list
          })
         }
           //   当点击‘-’
         decrease=(e)=>{
           const n=e.target.dataset.id;
           const {list}=this.state
               // console.log(list,'...',n);                
      list.map((item)=>{
                   if(item.id===Number(n)){
                       if(item.x===0)return false
                       item.x--
                       console.log(item.x);
                   item.sum=item.price*item.x}
                   return 0;
               })
          this.setState({
              list
          })
         // const {list}=this.state
       }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值