修改单元格——删除、插入、移动(IOS)

插入和删除时序:

client: setEditing: animated: -----> 设定进入表视图

表视图---->委托: (<UITableViewDelegate>)tableView:editingStyleForRowAtIndexPath:方法进行单元格编辑图标的设置

方法进行单元格编辑图标的设置

表视图---->数据源:(<UITableViewDataSource>)tableView:commiEditingStyle:forRowAtIndexPath消息实现删除或者插入的处理

这里由点击insert or delete控件来实现

删除和增加单元格要通过[self.tableView reloadData]来重新加载表视图数!!

移动时序:

client:setEditing:animated:----->设定进入表视图

表视图--->委托:(<UITableViewDelegate>)tableView:editingStyleForRowAtIndexPath:方法进行单元格编辑图标的设置

方法进行单元格编辑图标的设置

表视图---->数据源:(<UITableViewDataSource>)tableView:canMoveRowAtIndexPath 消息允许数据源移动单元格

表视图---->委托:(<UITableViewDelegate>)tableView:moveRowAtIndexPath:toIndexPath:方法对listTeams重新排序

党用户拖动排序控件来实现。

ViewController.h:

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController<UITextFieldDelegate,UITableViewDataSource,UITableViewDelegate>
@property (weak, nonatomic) IBOutlet UINavigationItem *navgationItem;
@property (weak, nonatomic) IBOutlet UITableView *tableView;

@property (strong, nonatomic) IBOutlet UITextField *txtField;

@property (nonatomic, strong) NSMutableArray *listTeams;
@end

ViewController.m:

#import "ViewController.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];

    // 设置导航栏
    // editButtonItem在视图控制器中已经定义好,self.editButtonItem可以获取指针
    // rightBarbuttonitem为导航栏右边的按钮
    self.navgationItem.rightBarButtonItem = self.editButtonItem;
    self.navgationItem.title = @"单元格插入和删除";

    // 设置单元格文本框
    self.txtField.hidden = YES;
    self.txtField.delegate = self;

    // 将当前视图控制器分配给表视图的委托和数据源
    self.tableView.delegate = self;
    self.tableView.dataSource = self;

    self.listTeams = [[NSMutableArray alloc] initWithObjects:@"黑龙江",@"吉林",@"辽宁", nil];

}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

#pragma mark -- UIViewController 生命周期方法,用于响应视图编辑状态变化,判断是否能够进入编辑状态!
- (void)setEditing:(BOOL)editing animated:(BOOL)animated
{
    [super setEditing:editing animated:animated];

    [self.tableView setEditing:editing animated: YES];
    if (editing) {
        self.txtField.hidden = NO;
    }
    else
    {
        self.txtField.hidden = YES;
    }
}

#pragma mark -- UITableViewDataSource 数据源协议方法
- (NSInteger) tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    // 需要增加一个空白单元格
    return [self.listTeams count] + 1;
}

- (UITableViewCell *) tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    static NSString *CellIdentifier = @"Cell";
    BOOL b_addCell;

    // 判断是否为需要插入的单元格
    if (indexPath.row == self.listTeams.count) {
        b_addCell = YES;
    }
    else
    {
        b_addCell = NO;
    }

    // 建立重用Cell
    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
    if (cell == nil) {
        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier];
    }

    if (!b_addCell) {
        // 普通单元格
        cell.accessoryType = UITableViewCellAccessoryDisclosureIndicator;  // 设置为右箭头
        cell.textLabel.text = [self.listTeams objectAtIndex:indexPath.row]; // 获取text
    }
    else{
        // 新插入的单元格
        // 只有进行插入操作时候,才能初始化到这个部分!
        self.txtField.frame = CGRectMake(10, 0, 300, 44);
        self.txtField.text = @"";
        [cell.contentView addSubview:self.txtField]; // 实现文本框的注入
    }
    return cell;
}

#pragma mark -- UITableViewDelegate 委托协议方法
- (UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath:(NSIndexPath *)indexPath
{
    // 编辑图标设定
    // 是删除还是增加
    if (indexPath.row == [self.listTeams count]) {
        return UITableViewCellEditingStyleInsert;
    }
    else{
        return UITableViewCellEditingStyleNone;//重排序控件同时存在。
        //return UITableViewCellEditingStyleDelete;
    }
}
- (BOOL) tableView:(UITableView *)tableView shouldHighlightRowAtIndexPath:(NSIndexPath *)indexPath
{
    if (indexPath.row == [self.listTeams count]) {
        return NO;    // 除了最后一行,都加高亮
    }
    else{
        return YES;
    }
}
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
    return 50;
}

- (BOOL)tableView:(UITableView *)tableView canMoveRowAtIndexPath:(NSIndexPath *)indexPath
{
    return YES;
}

-(void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)sourceIndexPath toIndexPath:(NSIndexPath *)destinationIndexPath
{
    // 先获取目标
    NSString *stringToMove = [self.listTeams objectAtIndex:sourceIndexPath.row];
    // 从目标位置删除
    [self.listTeams removeObjectAtIndex:sourceIndexPath.row];
    // 再目标位置插入数据
    [self.listTeams insertObject:stringToMove atIndex:destinationIndexPath.row];
}

#pragma mark -- UITableViewDataSource协议方法
- (void) tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath *)indexPath
{
    if (editingStyle == UITableViewCellEditingStyleDelete) {
        [self.listTeams removeObjectAtIndex:indexPath.row];
        [self.tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationFade];
        [self.tableView reloadData]; //??
    }
    else
        if (editingStyle == UITableViewCellEditingStyleInsert) {
            // 在最末位添加到listTeams
            // 先添加数据,然后再显示
            [self.listTeams insertObject:self.txtField.text atIndex:[self.listTeams count]];
            [self.tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationFade];
            // 重新加载在表格里的数据
            [self.tableView reloadData];
        }
}

#pragma mark -- UITextFieldDelegate 委托方法,1.关闭键盘 2.避免键盘遮挡文本框
-(BOOL) textFieldShouldReturn:(UITextField *)textField
{
    // 回收键盘
    [textField resignFirstResponder];
    return YES;
}

-(void) textFieldDidBeginEditing:(UITextField *)textField
{
    UITableViewCell *cell = (UITableViewCell *) [[textField superview] superview];
    [self.tableView setContentOffset:CGPointMake(0.0, cell.frame.origin.y) animated:YES];
}

@end
时间: 2024-12-17 05:13:34

修改单元格——删除、插入、移动(IOS)的相关文章

IOS之表视图单元格删除、移动及插入

1.实现单元格的删除,实现效果如下 Cpp代码   - (void)viewDidLoad { [super viewDidLoad]; //设置导航栏 self.editButtonItem.title = @"编辑"; self.navigation.rightBarButtonItem = self.editButtonItem; [self initTableViewData]; // Do any additional setup after loading the view

集算报表通过API修改单元格属性

有时需要在程序中动态修改已做好报表的单元格属性,包括边框.字号.颜色.对齐方式等.润乾集算报表提供了丰富的API,开发人员可以通过提供的接口快速修改报表单元格属性. 修改单元格属性主要修改报表定义ReportDefine,比如下面已经做好的订单信息表如下: 预览效果: 我们通过代码修改该报表单元格属性: //设定边框        for (int i = 2; i <=3; i++) {            for (int j = 1; j <=6; j++) {            

Excle只允许用户输入纯文本,禁止用户修改单元格样式、格式等

背景:自己的模板给别人,让他填完信息上传到系统里,但别人经常不按模板的格式来填写,导致无法程序自动化.能不能在模板上把格式锁住,只允许输入纯文本,但不能改格式? 方法: 步骤一,创建你要的模板 其中,总票房 单元格格式为"千分位数值"型,平均票价,场均人次 为小数位数为0的"数值"型,上映日期 为"日期"型: 步骤二.设置Ctrl+V粘贴动作默认只粘贴纯文本 另存工作簿为 xlsm格式(启用宏的工作簿): Alt+F11打开宏编辑器,插入->

c#在Excel指定单元格中插入图片

方法一: /// 将图片插入到指定的单元格位置,并设置图片的宽度和高度./// 注意:图片必须是绝对物理路径/// </summary>/// <param name="RangeName">单元格名称,例如:B4</param>/// <param name="PicturePath">要插入图片的绝对路径.</param>public void InsertPicture(string RangeNam

jqGrid 修改单元格值或者替换图片及其他

var rowIds = jQuery("#list1").jqGrid('getDataIDs');                for (var k = 0; k < rowIds.length; k++) {                    var curRowData = jQuery("#list1").jqGrid('getRowData', rowIds[k]);                    var cur = $("

Java解析,导出Excel文件(.xlsx跟.xls两种格式)&amp;字体修改&amp;单元格合并

做项目时要用到Excel批量导入导出数据,网上搜了以下大部分都是.xls格式Excel文件的教程. 导入.xlsx跟.xls格式的过程差不了多少,就是导出的时候好像有点不同,而且网上也没教程,于是硬着头皮写了一个(并没有看官方Api文档( ̄▽ ̄)"). 首先是导入Jar包,在上传的项目里面已经将需要用到的Jar文件放在lib文件夹里面了,我们只需要在Eclipse里面设置一下: 这里表格信息用Teacher这个类封装: package JavaBean; public class Teacher

poi 生成word 表格,并向表格单元格中插入多个图片

接这上一篇,导入数据,也要完整导出来.话不多说,直接上代码. 效果图 //根据实体对象 ,生成XWPFDocument public static XWPFDocument exportDataInfoWord(List<DataInfoEntity> list) throws NoSuchFieldException,IllegalAccessException { MyXWPFDocument doc = new MyXWPFDocument(); XWPFTable table = do

elementui修改单元格的样式

<el-table :cell-style="cellStyle" > methods:{ cellStyle (row, column, rowIndex, columnIndex) { if(row.column.label === "标题"){ return 'font-weight:bold' }else{ return '' } } } 原文地址:https://www.cnblogs.com/janney/p/9712308.html

javascript生成表格增删改查 JavaScript动态改变表格单元格内容 动态生成表格 JS获取表格任意单元格 javascript如何动态删除表格某一行

jsp页面表格布局Html代码 <body > <center> <input type="text" value="111" id="mytext"> <table border="1" width="60%" id="mytable"> <tr> <td id="td1">第一行第一列<