通讯录的实现

一.搭建界面



二,登录界面

- (void)setupUI {
   // 为 textField 添加 监听事件
    // 当我们需要监听textField文本改变的时候, 需要添加 监听事件: UIControlEventEditingChanged
    [_userNameField addTarget:self
                       action:@selector(valueChanged)
             forControlEvents:UIControlEventEditingChanged];
    
    
    [_passwordField addTarget:self
                       action:@selector(valueChanged)
             forControlEvents:UIControlEventEditingChanged];
    
    
    
    // 读取用户偏好中存储的内容, 对 界面进行设置
    BOOL isRecord = [NSUserDefaults getBoolWithType:SwitchTypeRecord];
    
    if (isRecord) {
        /**
         1. 填充用户名和密码
         2. 修改 记住密码的状态为on
         3. 登录按钮为可用状态
         */
        
        // 取出用户名和密码
        NSString *userName = [NSUserDefaults getObjectWithType:UserInfoTypeUserName];
        
        NSString *userPassword = [NSUserDefaults getObjectWithType:UserInfoTypeUserPassword];
        
        // 为输入框进行赋值
        _userNameField.text = userName;
        
        _passwordField.text= userPassword;
        
        // 修改 记住密码  的 状态
        [_recordSwitch setOn:YES animated:NO];
        
        
        // 登录按钮为可用状态
        _loginButton.enabled = YES;
    }
    
    
    // 对自动登录做判断
    BOOL isAutoLogin = [NSUserDefaults getBoolWithType:SwitchTypeAutoLogin];
    
    if (isAutoLogin) {
        
        // 调用 登录按钮的监听方法
        [self didClickLoginButton:nil];
        
        // 修改 自动登录 按钮的状态
        _autoSwitch.on = YES;
    }
    
    
}

- (IBAction)didClickLoginButton:(id)sender {
    
    // 让键盘消失
    [self.view endEditing:YES];
    
    [MBProgressHUD showLoadingWithMessage:@"正在请求..."];
    
    // 对用户名和密码做判断
    if ([_userNameField.text isEqualToString:@"a"] && [_passwordField.text isEqualToString:@"a"]) {
        
        
        [self showNoticeAfterDelay:2 withBlock:^{
            
            // 在这里 对 用户名和密码完成 存储
            
            if (_recordSwitch.isOn) {
                
                // 记住 用户名和密码
                
                [NSUserDefaults saveUserName:_userNameField.text andPassword:_passwordField.text];
                
                
            }
    
            // 调用方法, 完成跳转
            [self performSegueWithIdentifier:@"loginToList" sender:@"123"];

        }];
        
    } else {

        
        [self showNoticeAfterDelay:2 withBlock:^{
            // block的赋值
            [MBProgressHUD showErrorMessage:@"用户名或者密码错误" afterDelay:2];
        }];
    }
    
}

三.添加联系人

- (void)viewDidLoad {
    [super viewDidLoad];

   // 通过通知 监听 输入框的 文本输入
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(valueChanged) name:UITextFieldTextDidChangeNotification object:nil];
}


#pragma mark
#pragma mark - 监听textField文本变化
- (void)valueChanged {
    
    // 根据文本的输入情况, 来修改 保存按钮的状态
    _saveButton.enabled = (_nameField.text.length != 0 && _numberField.text.length != 0);
    
}


#pragma mark
#pragma mark - 当界面显示之后
- (void)viewDidAppear:(BOOL)animated {
    [super viewDidAppear:animated];
    
    // 让 nameField 成为第一响应者
    [_nameField becomeFirstResponder];
}



- (IBAction)didClickSaveButton:(id)sender {
    
    // 回退键盘
    [self.view endEditing:YES];
    
    // 实例化一个模型对象
    ContactModel *model = [ContactModel new];
    
    model.name = _nameField.text;
    model.number = _numberField.text;
    
    // 通知代理
    if ([self.delegate respondsToSelector:@selector(addViewController:withModel:)]) {
        [self.delegate addViewController:self withModel:model];
    }
    
    // 进行跳转
    [self.navigationController popViewControllerAnimated:YES];
    
}


#pragma mark
#pragma mark - 移除监听者
- (void)dealloc {
    
    [[NSNotificationCenter defaultCenter] removeObserver:self];
}

#pragma mark
#pragma mark - 添加好友的代理方法
- (void)addViewController:(AddViewController *)addController withModel:(ContactModel *)model {
    
    // 让model 显示到  cell中
    // 1. 添加model到数组
    [self.dataArray addObject:model];
    
    // 2. 刷新数据
    NSIndexPath *indexPath = [NSIndexPath indexPathForRow:self.dataArray.count - 1 inSection:0];
    
    
    [self.tableView insertRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationFade];
    
#warning 数据增加了, 需要进行归档
    [NSKeyedArchiver archiveRootObject:self.dataArray toFile:kFilePath(@"user.data")];
}

四.修改页面


#pragma mark
#pragma mark - 点击编辑
- (IBAction)didClickEditItem:(UIBarButtonItem *)sender {
    
    
    if (_saveButton.enabled) {
        // 设置 item 为 编辑
        _editItem.title = @"编辑";
        
//        _saveButton.enabled = NO;
//        
//        _nameField.enabled = NO;
//        _numberField.enabled = NO;
        
        [self changeFieldStatus:NO];
        
        // 如果 内容修改了, 然后点击取消item, 就应该把输入框的内容, 变成 原来的
        _nameField.text = _model.name;
        _numberField.text = _model.number;
        
    } else {
        
        _editItem.title = @"取消";
        
//        [_nameField becomeFirstResponder];
        
//        _saveButton.enabled = YES;
//        
//        // 两个输入框要 可用
//        _nameField.enabled = YES;
//        _numberField.enabled = YES;
        
        [self changeFieldStatus:YES];
    }
    
}


#pragma mark
#pragma mark - 点击保存
- (IBAction)didClickSaveButton:(id)sender {
   
    // 取得当前的修改之后的model
    _model.name = _nameField.text;
    _model.number = _numberField.text;
    
    // 通知 ListController 进行数据的刷新
    // 谁要传递消息, 谁就定义block
    // 谁要传递消息, 谁就是调用方
    
    // 先判断  _editBlock 是否被赋值, 如果有值就直接调用block
    
#warning 在这里 调用block
    if (_editBlock) {
        _editBlock();
    }
    
    // 跳转会 listController
    [self.navigationController popViewControllerAnimated:YES];
}

#pragma mark
#pragma mark - 如果需要对目标控制器做些操作, 需要实现这个方法
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender {
    
    NSString *identifier = segue.identifier;
    
    if ([identifier isEqualToString:@"logToAdd"]) {
        
        // 取出 目标控制器
        AddViewController *addController = segue.destinationViewController;
        
        // 设置当前控制器成为它的代理
        addController.delegate = self;
        
    } else if ([identifier isEqualToString:@"logToEdit"]) {
        // 跳到编辑界面
        EditViewController *editController = segue.destinationViewController;
        
        editController.model = sender;
        
#warning 在这里为 block进行赋值
        
        editController.editBlock = ^{
        // 要执行的代码块
            // 刷新数据
            // 只要刷新, push进 editController 之前的 cell
            // 获取选中cell的indexPath
            NSIndexPath *indexPath = [self.tableView indexPathForSelectedRow];
            
            [self.tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationFade];
            
#warning 数据被修改, 也需要进行归档
            [NSKeyedArchiver archiveRootObject:self.dataArray toFile:kFilePath(@"user.data")];
        };
        
    }
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Python中的xlwt和xlrd模块来读、写Excel文件,同时使用tkinter模块来设计通讯录系统的GUI界面。下面是一个示例代码,用于设计通讯录系统并实现增删改查功能,并将数据录入Excel文档中: ``` import tkinter as tk import xlwt import xlrd class AddressBook: def __init__(self, master): self.master = master master.title("通讯录系统") # 创建GUI界面 self.label_name = tk.Label(master, text="姓名:") self.label_name.grid(row=0, column=0) self.entry_name = tk.Entry(master) self.entry_name.grid(row=0, column=1) self.label_phone = tk.Label(master, text="电话:") self.label_phone.grid(row=1, column=0) self.entry_phone = tk.Entry(master) self.entry_phone.grid(row=1, column=1) self.label_email = tk.Label(master, text="邮箱:") self.label_email.grid(row=2, column=0) self.entry_email = tk.Entry(master) self.entry_email.grid(row=2, column=1) # 添加按钮 self.button_add = tk.Button(master, text="添加", command=self.add_contact) self.button_add.grid(row=3, column=0) # 删除按钮 self.button_delete = tk.Button(master, text="删除", command=self.delete_contact) self.button_delete.grid(row=3, column=1) # 修改按钮 self.button_edit = tk.Button(master, text="修改", command=self.edit_contact) self.button_edit.grid(row=3, column=2) # 查询按钮 self.button_search = tk.Button(master, text="查询", command=self.search_contact) self.button_search.grid(row=3, column=3) # 创建Excel文件和Sheet self.workbook = xlwt.Workbook() self.worksheet = self.workbook.add_sheet("通讯录") self.row = 0 self.col = 0 # 写入表头 self.worksheet.write(self.row, self.col, "姓名") self.col += 1 self.worksheet.write(self.row, self.col, "电话") self.col += 1 self.worksheet.write(self.row, self.col, "邮箱") self.row += 1 self.col = 0 def add_contact(self): # 获取用户输入的信息 name = self.entry_name.get() phone = self.entry_phone.get() email = self.entry_email.get() # 写入数据到Excel文件中 self.worksheet.write(self.row, self.col, name) self.col += 1 self.worksheet.write(self.row, self.col, phone) self.col += 1 self.worksheet.write(self.row, self.col, email) self.row += 1 self.col = 0 # 清空文本框 self.entry_name.delete(0, tk.END) self.entry_phone.delete(0, tk.END) self.entry_email.delete(0, tk.END) # 保存到文件 self.workbook.save("通讯录.xls") def delete_contact(self): # 获取用户输入的姓名 name = self.entry_name.get() # 遍历Excel文件,查找要删除的行 for i in range(1, self.row): if self.worksheet.cell_value(i, 0) == name: # 删除行 self.worksheet._Worksheet__rows.pop(i) self.row -= 1 # 保存到文件 self.workbook.save("通讯录.xls") break # 清空文本框 self.entry_name.delete(0, tk.END) self.entry_phone.delete(0, tk.END) self.entry_email.delete(0, tk.END) def edit_contact(self): # 获取用户输入的姓名 name = self.entry_name.get() # 遍历Excel文件,查找要编辑的行 for i in range(1, self.row): if self.worksheet.cell_value(i, 0) == name: # 获取用户输入的信息 phone = self.entry_phone.get() email = self.entry_email.get() # 修改数据 self.worksheet.write(i, 1, phone) self.worksheet.write(i, 2, email) # 保存到文件 self.workbook.save("通讯录.xls") break # 清空文本框 self.entry_name.delete(0, tk.END) self.entry_phone.delete(0, tk.END) self.entry_email.delete(0, tk.END) def search_contact(self): # 获取用户输入的姓名 name = self.entry_name.get() # 遍历Excel文件,查找要查询的行 for i in range(1, self.row): if self.worksheet.cell_value(i, 0) == name: # 显示查询结果 self.entry_phone.delete(0, tk.END) self.entry_phone.insert(0, self.worksheet.cell_value(i, 1)) self.entry_email.delete(0, tk.END) self.entry_email.insert(0, self.worksheet.cell_value(i, 2)) break def load_contacts(self): # 加载Excel文件中的数据 workbook = xlrd.open_workbook("通讯录.xls") worksheet = workbook.sheet_by_index(0) self.row = worksheet.nrows # 遍历Excel文件中的数据,并显示到GUI界面中 for i in range(1, self.row): name = worksheet.cell_value(i, 0) phone = worksheet.cell_value(i, 1) email = worksheet.cell_value(i, 2) self.worksheet.write(self.row, self.col, name) self.col += 1 self.worksheet.write(self.row, self.col, phone) self.col += 1 self.worksheet.write(self.row, self.col, email) self.row += 1 self.col = 0 root = tk.Tk() address_book = AddressBook(root) address_book.load_contacts() root.mainloop() ``` 在上面的示例代码中,我们使用tkinter模块创建了一个GUI界面,包含文本框和四个按钮,分别对应添加、删除、修改和查询操作。当用户点击这些按钮时,我们会从Excel文件中读取、修改、删除或查询数据,并将结果显示到GUI界面中。 同时,我们也在GUI界面中显示了已经录入的数据,并在程序启动时从Excel文件中读取数据。最后,我们将Excel文件保存到了本地磁盘上。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值