zoukankan      html  css  js  c++  java
  • IOS UITableView拖动排序功能

      UITbableView作为列表展示信息。除了展示的功能,有时还会用到删除。排序等功能。以下就来解说一下怎样实现排序。

      排序是当表格进入编辑状态后,在单元格的右側会出现一个button。点击button,就能够拖动单元格。移动位置。进行手动排序。

    使用系统自带拖动排序功能的步骤:

    1、让tableView进入编辑状态,也就是设置它的editing为YES

    2、返回编辑模式,也就是实现UITableViewDelegate中的tableview:editingStyleForRowAtIndexPath:方法,在里面返回UITableViewCellEditingStyleNone模式。

    假设不实现,默认返回的就是删除模式

    3、实现tableView:moveRowAtIndexPath:toIndexPath方法,仅仅要实现该方法,就能实现单元格的拖动排序。但仅仅是实现了表面的排序,并没有改动真实地数据

    4、在方法中完毕数据模型的更新

    代码:

    //  ViewController.m
    //  JRTableView删除
    //
    //  Created by jerehedu on 15/6/11.
    //  Copyright (c) 2015年 jerehedu. All rights reserved.
    //
    
    #import "ViewController.h"
    #import "Goods.h"
    
    @interface ViewController ()<UITableViewDataSource, UITableViewDelegate>
    
    {
        UITableView *_tableView; //列表
        
        NSMutableArray *_goodsAry; //商品数组
        
        UIButton *_editBtn; //编辑button
    }
    @end
    
    @implementation ViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
        
        //加入标题
        UILabel *titleLabel = [[UILabel alloc] initWithFrame:CGRectMake(0, 20, self.view.frame.size.width, 44)];
        titleLabel.text = @"购物车";
        titleLabel.textAlignment = NSTextAlignmentCenter;
        titleLabel.backgroundColor = [UIColor redColor];
        titleLabel.textColor = [UIColor whiteColor];
        [self.view addSubview:titleLabel];
        
        //加入编辑button
        _editBtn = [UIButton buttonWithType:UIButtonTypeCustom];
        _editBtn.frame = CGRectMake(self.view.frame.size.width-60, 25, 50, 34);
        [_editBtn setTitle:@"编辑" forState:UIControlStateNormal];
        [_editBtn setTitle:@"完毕" forState:UIControlStateSelected];
        _editBtn.titleLabel.font = [UIFont systemFontOfSize:15];
        _editBtn.backgroundColor = [UIColor colorWithRed:0.8 green:0.8 blue:0.8 alpha:0.5];
        [self.view addSubview:_editBtn];
        [_editBtn addTarget:self action:@selector(clickEditBtn:) forControlEvents:UIControlEventTouchUpInside];
        
        //加入tableview
        _tableView = [[UITableView alloc] initWithFrame:CGRectMake(0, 64, self.view.frame.size.width, self.view.frame.size.height-64)];
        _tableView.dataSource = self;
        _tableView.delegate = self;
        [self.view addSubview:_tableView];
        
        //取数据
        NSArray *ary = [NSArray arrayWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"ShoppingGoodsList" ofType:@"plist"]];
        
        //把数据存到模型对象中,然后把对象存到数组中
        _goodsAry = [NSMutableArray array];
        for (int i=0; i<ary.count; i++) {
            Goods *good = [Goods goodsWithDic:ary[i]];
            [_goodsAry addObject:good];
        }
    }
    
    #pragma mark 数据源  返回有几行
    -(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
    {
        return _goodsAry.count;
    }
    
    #pragma mark 每行显示内容
    -(UITableViewCell*)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
    {
        static NSString *idGood = @"goods";
        
        UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:idGood];
        
        if (cell==nil) {
            cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:idGood];
        }
        
        Goods *good = _goodsAry[indexPath.row];
        
        cell.imageView.image = [UIImage imageNamed:good.icon];
        cell.textLabel.text = good.name;
        cell.detailTextLabel.text = good.details;
        cell.detailTextLabel.numberOfLines = 6;
        cell.detailTextLabel.textColor = [UIColor brownColor];
        
        return cell;
    }
    
    #pragma mark 选中行
    -(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
    {
        // 取消选中状态
        [tableView deselectRowAtIndexPath:indexPath animated:YES];
    }
    
    #pragma mark 设置行高
    -(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
    {
        return 110;
    }
    
    #pragma mark 点击编辑button
    - (IBAction)clickEditBtn:(UIButton *)sender {
        
        //设置tableview编辑状态
        BOOL flag = !_tableView.editing;
        [_tableView setEditing:flag animated:YES];
        _editBtn.selected = flag;
    }
    
    #pragma mark 选择编辑模式,加入模式非常少用,默认是删除
    -(UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath:(NSIndexPath *)indexPath
    {
        return UITableViewCellEditingStyleNone;
    }
    
    #pragma mark 排序 当移动了某一行时候会调用
    //编辑状态下。仅仅要实现这种方法,就能实现拖动排序
    -(void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)sourceIndexPath toIndexPath:(NSIndexPath *)destinationIndexPath
    {
        // 取出要拖动的模型数据
        Goods *goods = _goodsAry[sourceIndexPath.row];
        //删除之前行的数据
        [_goodsAry removeObject:goods];
        // 插入数据到新的位置
        [_goodsAry insertObject:goods atIndex:destinationIndexPath.row];
    }
    
    @end

      想要了解很多其它内容的小伙伴。能够点击查看源代码,亲自执行測试。

      疑问咨询或技术交流,请增加官方QQ群:JRedu技术交流 (452379712)

    作者:杰瑞教育
    出处:http://blog.csdn.net/jerehedu/ 
    本文版权归烟台杰瑞教育科技有限公司和CSDN共同拥有,欢迎转载,但未经作者允许必须保留此段声明。且在文章页面明显位置给出原文连接。否则保留追究法律责任的权利。
     
  • 相关阅读:
    ie6的兼容性问题?
    localstorage,sessionstorage,cookie的比较?
    vuex与localstorage的比较?
    当数据量大时的加载原理?
    input控件的兼容性问题?
    京东数科Java实习面试(offer到手含面试经验及答案)
    车好多Java实习面试(offer到手含面试经验及答案)
    小屋信息Java实习面试(offer到手含面试经验及答案)
    比特大陆Java实习面试(offer到手含面试经验及答案)
    微众银行Java实习面试(offer到手含面试经验及答案)
  • 原文地址:https://www.cnblogs.com/yfceshi/p/6856021.html
Copyright © 2011-2022 走看看