码迷,mamicode.com
首页 > 其他好文 > 详细

JRoll、React滑删

时间:2017-12-11 14:12:22      阅读:179      评论:0      收藏:0      [点我收藏+]

标签:amp   select   效果图   style   else   call   creat   def   scrollto   

import React, { Component } from ‘react‘;
import ‘../src/css/reset.css‘;
import ‘../src/css/delete.css‘;
import JRoll from ‘jroll‘;


class Mall extends Component {
  constructor(){
    super();
    this.state = {
      arr: [
        {id: ‘01‘,name:‘lily1‘},
        {id: ‘02‘,name:‘lily2‘},
        {id: ‘03‘,name:‘lily3‘},
        {id: ‘04‘,name:‘lily4‘},
        {id: ‘05‘,name:‘lily5‘},
        {id: ‘06‘,name:‘lily6‘},
        {id: ‘07‘,name:‘lily7‘},
        {id: ‘08‘,name:‘lily8‘},
        {id: ‘09‘,name:‘lily9‘},
        {id: ‘10‘,name:‘lily10‘},
        {id: ‘11‘,name:‘lily11‘},
        {id: ‘12‘,name:‘lily12‘},
        {id: ‘13‘,name:‘lily13‘},
        {id: ‘14‘,name:‘lily14‘},
        {id: ‘15‘,name:‘lily15‘},
        {id: ‘16‘,name:‘lily16‘},
        {id: ‘17‘,name:‘lily17‘},
        {id: ‘18‘,name:‘lily18‘},
        {id: ‘19‘,name:‘lily19‘},
        {id: ‘20‘,name:‘lily20‘}
      ]
    };
    this.deleteOne = this.deleteOne.bind(this);
    this.createJroll = this.createJroll.bind(this);
  }
  createJroll(){
    var w = Math.floor(document.getElementsByClassName(‘del‘)[0].offsetWidth / 2);
    console.log(w);//‘删除’按钮的一半宽度。
     // 创建外层jroll实例
    var jroll = new JRoll("#wrapper", {
        scrollBarY:true
    });

    var items = document.querySelectorAll(".item");
    var current = null; //保存当前滑开的item

    for (var i=0,l=items.length; i<l; i++) {
        // 每行创建jroll实例
        var j = new JRoll(items[i], {
            scrollX:true,
            bounce:false
        });

    j.on("scrollStart", function() {
        if (current && current !== this) {
            current.scrollTo(0, 0, 100);
            current = null;
        }
    });

    j.on("scroll", function(e) {
        if (this.x === 0 && !current) {
            this.call(jroll, e);
        } else {
            current = this;
        }
    });

    j.on("scrollEnd", function() {
        if (this.x > -w) {
            this.scrollTo(0, 0, 100);
            current = null;
        } else {
            this.scrollTo(this.maxScrollX, 0, 100);
        }
    })
  }
  //添加点击删除按钮的事件
  // for (let i=0; i<items.length; i++) {
  //   let item = items[i];
  //   let index = i;
  //   item.onclick = (e)=>{
  //     // console.log(item);
  //     if (e.target.className === "del") {
  //           console.log(item);
  //           console.log(index);
  //           item.style.display = ‘none‘;
  //       }
  //   };
  // }
}
  deleteOne(id){
    let arr = [];
    let items = document.querySelectorAll(".item");
    for(let i = 0; i < this.state.arr.length; i ++){
      if(this.state.arr[i].id !== id){
        arr.push(this.state.arr[i]);
      }else{
        items[i].style.display = ‘none‘;
      }
    }

    //发起请求

    this.setState({arr},()=>{
      console.log(this.state.arr);
    });
    
  }
  componentDidMount() {
    this.createJroll();
  }
render(){
  return <div id="wrapper">
  <div className="scroller">
      <div id="valid">
        {
          this.state.arr.map((item,index)=>{
            return <div key={index} className="item">
              <div className="item-scroller">
                <div className="content">列表内容</div>
                <div className="del" onClick={()=>this.deleteOne(item.id)}>删除</div>
              </div>
            </div>
          })
        }
      </div>
      <div className="invalid_tit">失效商品</div>
      <div id="invalid">
        {
          this.state.arr.map((item,index)=>{
            return <div key={index} className="item">
              <div className="item-scroller">
                <div className="content">列表内容2</div>
                <div className="del">删除2</div>
              </div>
            </div>
          })
        }
      </div>
    </div>
  </div>
}
}

class Item extends Component {
  
}


class App extends Component {
  render(){
    return <Mall />;
  }
}



export default App;

 效果图

技术分享图片

 

技术分享图片

 

JRoll、React滑删

标签:amp   select   效果图   style   else   call   creat   def   scrollto   

原文地址:http://www.cnblogs.com/LLLLily/p/8021968.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!