最近重新拿起了iOS的开发,使用OC和Swift混编,碰到了一些比较棘手的问题,在这里记录下来,方便自己以后或他人不再入坑。这篇文章的内容包含:

UITableViewCell的真实结构
在iOS的环境下使用正则表达式
如何优雅的隐藏tabbar
如何修改navigationbar的颜色
运行时修改使用autolayout的view
navigation controller子view偏移问题
CoreData的使用总结
解决git的Xcode冲突
1.UITableViewCell的真实结构

目标是想把UITableview在editing模式下的drag按钮去掉,换成自己的样式,但又想保留原生拖动排序的行为,所以研究了很多方法,最后还是找到了UITableViewCell的结构,并将拖动按钮替换。不多说,上代码。

//打印出来的自定义的cell在editing模式下的结构
(lldb) po self
<QKZhi_iOS.EditingCell: 0x7c148800; baseClass = UITableViewCell; frame = (0 0; 320 56); autoresize = W; layer = <CALayer: 0x7d086b40>>

(lldb) po self.subviews
5 elements
- [0] : <UITableViewCellContentView: 0x7d086d10; frame = (38 0; 242 55.5); opaque = NO; gestureRecognizers = <NSArray: 0x7d0882b0>; layer = <CALayer: 0x7d086de0>>
- [1] : <_UITableViewCellSeparatorView: 0x7d087c40; frame = (15 55; 305 1); layer = <CALayer: 0x7d0852c0>>
- [2] : <_UITableViewCellSeparatorView: 0x7b163240; frame = (15 55.5; 305 0.5); layer = <CALayer: 0x7b162de0>>
- [3] : <UITableViewCellEditControl: 0x7b164700; frame = (0 0; 47 56); opaque = NO; layer = <CALayer: 0x7b164950>>
- [4] : <UITableViewCellReorderControl: 0x7b164d10; frame = (268 0; 52 56); opaque = NO; autoresize = LM; layer = <CALayer: 0x7b164f60>>

(lldb) po self.subviews.last
Optional<UIView>
- Some : <UITableViewCellReorderControl: 0x7b164d10; frame = (268 0; 52 56); opaque = NO; autoresize = LM; layer = <CALayer: 0x7b164f60>>

(lldb) po self.subviews.last?.subviews
Optional<Array<UIView>>
Some : 1 elements
- [0] : <UIImageView: 0x7b165130; frame = (15 24; 22 8.5); opaque = NO; userInteractionEnabled = NO; tag = 1; layer = <CALayer: 0x7b165210>>

(lldb)
可以看到此时contentView左右都向内缩进了一定的距离,最后有一个view叫UITableViewCellReorderControl,我想就是它了,然后看它的subviews,竟然包含了一个UIImageView,果断替换之,代码如下。

override func layoutSubviews() {
super.layoutSubviews()
setupReorderControl()
}

func setupReorderControl() {
if (self.reorderControl != nil) {
return;
}

for view in self.subviews {

if view.description.containsString("UITableViewCellReorderControl") {
self.reorderControl = view
}
}

if ((self.reorderControl) != nil)
{
let imageOfReorder = self.reorderControl?.subviews[0] as? UIImageView
imageOfReorder?.removeFromSuperview()
}
}
此时就完成了将拖动按钮隐藏的功能,但是注意,在这里如果想通过设置reorderControl的frame去改变它的位置是不成功的,我想可能它的布局使用autolayout,并没有深入的再去研究。

2. 在iOS的环境下使用正则表达式

在iOS下使用正则似乎挺麻烦的,如果只是想用正则判断格式,那么可以使用NSPredicate:

let string = "abcd"
let predicate = NSPredicate.init(format: "self matches %@", "^a(b|c)d$")
predicate.evaluateWithObject(string)
如果要使用正则判断格式,然后获取group的子字符串,就比较麻烦了,并没有Swift的原生方法来做,必须使用NSRegularExpression,话不多说,上代码:

let reg = try! NSRegularExpression.init(pattern: "^a(b|c)d$", options: NSRegularExpressionOptions.CaseInsensitive)
let matches = reg.matchesInString(string, options: NSMatchingOptions.init(rawValue: 0), range: NSMakeRange(0, string.characters.count))
if matches?.count > 0 {
let returnString = (string as NSString).substringWithRange(matches![0].rangeAtIndex(1))
}
3. 如何优雅的隐藏tabbar

很多APP都使用TabBarController套NavigationController的方法来作为应用的框架,那么隐藏TabBar就成了一个必要的功能,目前最简单的方法还是使用hidesBottomBarWhenPushed来实现,最简单的方法就是在要隐藏tab bar的Controller里写入下面的方法,来覆默认值。

- (BOOL) hidesBottomBarWhenPushed {
return (self.navigationController.topViewController == self);
}
4. 如何修改navigationbar的颜色

[self.navigationController.navigationBar setTranslucent:NO];
self.navigationController.navigationBar.barTintColor = [UIColor redColor];

//在此方法中还原颜色
-(void)viewWillDisappear:(BOOL)animated{
self.navigationController.navigationBar.barTintColor = [UIColor whiteColor];
[super viewWillDisappear:animated];
}
5. 运行时修改使用autolayout的view

方案是运行时给view添加constraint。

NSLayoutConstraint *c = [NSLayoutConstraint constraintWithItem:view1
attribute:NSLayoutAttributeTop
relatedBy:NSLayoutRelationEqual
toItem: view2
attribute: NSLayoutAttributeTop
multiplier:1
constant:2];
view1(的顶部) = view2(的顶部) * 1 + 2
这个代码的意思是把view1的顶部放在view2的顶部向下两个像素的地方(因为此时view1是view2 的subview,所以达到的效果就是view1在view2顶部向下2个像素的地方)

如下是所有属性:

NSLayoutAttributeLeft 视图的左边
NSLayoutAttributeRight 视图的右边
NSLayoutAttributeTop 视图的上边
NSLayoutAttributeBottom 视图的下边
NSLayoutAttributeLeading 视图的前边
NSLayoutAttributeTrailing 视图的后边
NSLayoutAttributeWidth 视图的宽度
NSLayoutAttributeHeight 视图的高度
NSLayoutAttributeCenterX 视图的中点的X值
NSLayoutAttributeCenterY 视图中点的Y值
NSLayoutAttributeBaseline 视图的基准线
NSLayoutAttributeNotAnAttribute 无属性
6. navigation controller子view偏移问题

场景是这样的:页面使用UItableview布局,由于页面比较复杂,在push进去再出来时第一个cell会向下偏移。解决方案:

//在viewDidLoad中加入:
if ([self respondsToSelector:@selector(edgesForExtendedLayout)]){

self.edgesForExtendedLayout = UIRectEdgeNone;

}
7. CoreData的使用总结

//
// CoreDataHelper.swift
// TestCode
//
// Created by lk on 16/7/6.
// Copyright © 2016年 lk. All rights reserved.
//

import Foundation
import CoreData

@objc class CoreDataHelper: NSObject {

static let KEY_OF_MAX_ORDER_NUMBER_OF_I = "MIK"
static let KEY_OF_MAX_ORDER_NUMBER_OF_O = "MOK"

var context : NSManagedObjectContext!
static let sharedInstance = CoreDataHelper()

private func fetchQuery(request request : NSFetchRequest) -> [NSManagedObject] {
do{
let fetchResults = try context?.executeFetchRequest(request) as! [NSManagedObject]!
return fetchResults
}catch let error as NSError {
print("查询失败: \\(error)")
}
return []
}

private func save() -> Void {
//保存
do{
try context.save()
} catch let error as NSError {
print("保存失败: \\(error)")
}
}

//TODO: - 这里可能存在溢出漏洞,以后再说
private func addIncrement(key _key : String, newNumber : Int) -> Void {
if _key == CoreDataHelper. KEY_OF_MAX_ORDER_NUMBER_OF_O || _key == CoreDataHelper.KEY_OF_MAX_ORDER_NUMBER_OF_I {
NSUserDefaults.standardUserDefaults().setInteger(newNumber, forKey: _key)
}
}

//Mark: - 重新计算最大值
func recaculateOptionalMaxOrder() -> Void {
let topOptinal = getOptionals(count: 1)
if topOptinal.count > 0 {
NSUserDefaults.standardUserDefaults().setInteger(topOptinal[0].order!.integerValue, forKey: CoreDataHelper.KEY_OF_MAX_ORDER_NUMBER_OF_O)
}
}

//MARK: - 添加
func addXXX(code code: String, name: String) -> Void {
if (context == nil) {
print("添加失败,context为nil")
return
}
let s = NSEntityDescription.insertNewObjectForEntityForName("S", inManagedObjectContext: context) as! S

//对象赋值
s.code = code
s.name = name
s.numericalCode = info.code
s.type = info.type

save()
}

//MARK: - 删除
func removeAll() -> Void {
let fetchRequest = NSFetchRequest(entityName: "S")

let fetchResults = fetchQuery(request: fetchRequest)
for info:NSManagedObject in fetchResults {
//删除对象
context.deleteObject(info)
}
save()

}

//MARK: - 查询
func getObject(code code : String) -> S? {
if (context == nil) {
print("查询失败,context为nil")
return nil;
}

let fetchRequest = NSFetchRequest(entityName: "S")
let predicate = NSPredicate(format: "code == %@ || numericalCode == %@", code, code)
fetchRequest.predicate = predicate
let fetchResults = fetchQuery(request: fetchRequest)
if let ses = fetchResults as? [S] {
if ses.count > 0{
return ses[0]
}else{
return nil
}
}
return nil
}

//MARK: - 搜索
func searchStocks(filterString : String) -> [Stock] {
var attribute = "code";
let num = Int(filterString)

if filterString.lengthOfBytesUsingEncoding(NSUTF8StringEncoding) <= 0 {
return []
} else if num == nil {
//TODO
attribute = "name"
}
let fetchRequest = NSFetchRequest(entityName: "S")
fetchRequest.predicate = NSPredicate.init(format: "%K CONTAINS %@", attribute, filterString)
let fetchResults = fetchQuery(request: fetchRequest)
print("结果:")
print(fetchResults)
var ses = [S]()
for res in fetchResults {
let s = res as! S
ses.append(s)
}
return ses
}

稿源:微信开发www . qixoo.com

iOS开发的那些坑的更多相关文章

  1. AIR for IOS开发问题小结

    昨天终于成功地向APP STORE提交了应用,个人感觉用AIR做IOS开发就是个坑啊.出了问题之后,问苹果的技术支持,人家说“对于非XCODE环境下开发及发布所造成的问题我们在资料库中无法找到相应的解 ...

  2. 转:【iOS开发每日小笔记(十一)】iOS8更新留下的“坑” NSAttributedString设置下划线 NSUnderlineStyleAttributeName 属性必须为NSNumber

    http://www.bubuko.com/infodetail-382485.html 标签:des   class   style   代码   html   使用   问题   文件   数据 ...

  3. iOS开发中静态库制作 之.a静态库制作及使用篇

    iOS开发中静态库之".a静态库"的制作及使用篇 一.库的简介 1.什么是库? 库是程序代码的集合,是共享程序代码的一种方式 2.库的类型? 根据源代码的公开情况,库可以分为2种类 ...

  4. iOS开发:创建真机调试证书及描述文件

    iOS开发:创建真机调试证书及描述文件 关于苹果iOS开发,笔者也是从小白过来的,经历过各种困难和坑,其中就有关于开发证书,生产证书,in_house证书,add_Hoc证书申请过程中的问题,以及上架 ...

  5. iOS 开发总结(上)

    来源:蝴蝶之梦天使 链接:http://www.jianshu.com/p/d333cf6ae4b0 在iOS开发中经常需要使用的或不常用的知识点的总结,几年的收藏和积累(踩过的坑). 一. iPho ...

  6. iOS开发 Xcode8中遇到的问题及改动

      iOS开发 Xcode8中遇到的问题及改动 新版本发布总会有很多坑,也会有很多改动. 一个一个填吧... 一.遇到的问题 1.权限以及相关设置 iOS10系统下调用系统相册.相机功能,或者苹果健康 ...

  7. 【Swift】iOS开发历险记(二)

    前言 这个系列主要是一些开发中遇到的坑记录分享,有助于初学者跨过这些坑,攒够 7 条发一篇. 声明  欢迎转载,但请保留文章原始出处:)  博客园:http://www.cnblogs.com 农民伯 ...

  8. 深入理解iOS开发中的BitCode功能

    前言 做iOS开发的朋友们都知道,目前最新的Xcode7,新建项目默认就打开了bitcode设置.而且大部分开发者都被这个突如其来的bitcode功能给坑过导致项目编译失败,而这些因为bitcode而 ...

  9. 从零开始学IOS开发

    从今天开始开一个坑,由于业务变动,要开始学习IOS开发进行IOS app开发,其实鄙人本身就是一只菜鸟加大学狗,有过两年的C#,ASP.NET MVC,微信公众平台开发经验,一只在继续努力着,从大三下 ...

随机推荐

  1. 只具备内网的服务器通过yum安装软件

    1.在维护过程中,需要统一安装一些软件,可能有的机器只具有内网,有的机器具备外网,可以直接从yum安装,怎么办呢?答:在具备外网的机器上启用yum缓存,这样安装软件的时候本地也缓存了软件安装包,怎样修 ...

  2. Less 语法特性

                                     ——(原创翻译:译者添加部分解释和代码运行结果) ♥在线Less编译器:LESS2CSS <一>综述 Less作为CSS的 ...

  3. JS execCommand 方法

    document.execCommand()方法处理Html数据时常用语法格式如下: 复制内容到剪贴板 代码: document.execCommand(sCommand[,交互方式, 动态参数]) ...

  4. Mybatis resultMap空值映射问题解决

    Mybatis在使用resultMap来映射查询结果中的列,如果查询结果中包含空值的列(不是null),则Mybatis在映射的时候,不会映射这个字段,例如 查询 name,sex,age,数据库中的 ...

  5. Windows平台上安装搭建iPhone/iPad的开发环境

    http://www.cnblogs.com/hanxianlong/archive/2015/09/20/4824227.html http://blog.csdn.net/yahohi/artic ...

  6. HDU-4003 Find Metal Mineral (树形DP+分组背包)

    题目大意:用m个机器人去遍历有n个节点的有根树,边权代表一个机器人通过这条边的代价,求最小代价. 题目分析:定义状态dp(root,k)表示最终遍历完成后以root为根节点的子树中有k个机器人时产生的 ...

  7. Python应用01 原始Python服务器

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 之前我的Python教程中有人留言,表示只学Python没有用,必须学会一个框架( ...

  8. Flume学习 &amp; Kafka &amp; Storm 等 &amp; Log4J 配置

    正在学习这篇文章: http://blog.csdn.net/ymh198816/article/details/51998085 和工作中接触的电商.订单.分析,可以结合起来. 开宗明义,这幅图片: ...

  9. laravel扩展xls处理maatwebsite/excel

    github地址:https://github.com/Maatwebsite/Laravel-Excel 安装: sudo composer require maatwebsite/excel 配置 ...

  10. 使用HttpURLConnection向服务器发送post和get请求

    一.使用HttpURLConnection向服务器发送get请求 1.向服务器发送get请求 @Test publicvoid sendSms() throws Exception{ String m ...