不断持续更新中

1、关于返回按钮:

如果是使用push方式跳转页面,返回时使用self.navigationController?.popViewControllerAnimated 方法(默认动画效果是从右往左,返回动画相反)

如果是使用present方式跳转页面,返回时使用self.dismissViewControllerAnimated 方法 (默认动画效果是从下往上,返回动画相反)


2、关于swift中定义类似于OC中block回调方法的定义方式:

第一步:typealiasMenuButtonBlock的回调方法

第二步:在class中定义一个变量,类型为MenuButtonBlock eg:var clickedBlock: MenuButtonBlock?

第三步:使用此属性 eg:func testBlock(action:MenuButtonBlock) {//your code...} action即为testBlock方法的回调函数

在swift中的叫法叫闭包函数 closure


3、关于计算变量:

import UIKit
class Test: NSObject {
    var a:Int = 1
    var b:Int = 2
//    var sum = a + b    这一行会报编译错误
    var sum:Int {
        return a + b
    }
}

其中sum就是计算属性


4、关于?与!的区别:?表示对象接受为nil的情况发生,!类似强制解包的概念

class Test: NSObject {
    var str1:String!
    var str2:String?
    
    func printTest() {
        self.str1 = "测试" //如果注释掉此行时,第一条打印会报error,程序崩溃
        self.str2 = "测试" //如果注释掉此行时,第二条打印结果为 "nil\n",第三条打印会报error,程序崩溃
        print(self.str1) //打印结果为 "测试\n"
        print(self.str2) //打印结果为 "Optional("测试")\n"
        print(self.str2!) //使用!强制解包,打印结果为 "测试\n"
    }
}




5、关于变量setter getter方法的使用,接着上一个例子:

class Test: NSObject {
    var str1:String {
        set{
            print("set str1") //给str1赋值时执行
        }
        get{
            print("get str1") //获取str1时执行,必须要return
           return "123"
        }
        
    }
    
    var tmpStr:String?
    var str2:String = "" { //切忌在内部给str2赋值,要不然会产生死循环,编译也无法通过
        willSet{
            print("willSet str2") //将要给str2赋值时执行
            tmpStr = "1"
        }
        didSet{
            print("didSet str2") //str2赋值结束后执行
            tmpStr = "2"
        }
    }
    
    func printTest() {
        print(str1)    //此处打印结果为  "get str1\n"       "123\n"
        str2 = "345"   //此处打印结果为  "willSet str2\n"   "didSet str2\n"
        print(str2)    //此处打印结果为  "345\n"
        print(tmpStr!) //此处打印结果为  "2\n"
        
        //set和get可以同时存在,willSet和didSet可以同时存在,这2组之间不能有交叉使用
    }
}



6、关于OC中三目运算符的奇怪写法(?: 连到一块)

BOOL flag = (10 == 11) ?: 0;

我是第一次见这种写法,测试的结果flag 为 NO。如果把后台的0换成任意其它数的话,返回YES;如果把条件换成 10==10的话,返回YES;(0为NO,非0为YES)

根据实验得出自己的结论:?和:之间可以缺省,默认为1,因此flag只能是数字或可以接收数字类型的变量

7、关于swift中实现多个代理,比如有这样一个需求:在某一个UIView中,要实现UIScrollViewDelegate,同时也要实现自己的delegate

在OC中有如下代码,在.h文件中:

@property (nonatomic, weak) id <MyViewDelegate, UIScrollViewDelegate> delegate;

以上代码中,MyViewDelegate为自定义protocol,在swift中是不支付这种语法的,那在swift中应该如何实现这种方式呢?

第一步:在自定义protocol MyViewDelegate时,让它继承UIScrollViewDelegate

第二步:不能使用 var delegate:MyViewDelegate? 这种方式,因为delegate这个成员变量与UIScrollView默认的delegate变量名称相同,因此只需要将变量名改变为非delegate名称即可,比如这样定义 var myDelegate:MyViewDelegate?  

8、swift中定义的protocol中的方法默认都是必需要实现的,但是在有些需求中的某些delegate中的方法如果太多,但是又不一定是必须要实现的话,这样就会造成不必要的时间浪费。那应该如果像OC中那样,使其中的某些方法是可选的呢?有2种方式供选择:

第一种方式:

@objc protocol MyViewDelegate {
    func requireMethod()
    optional func optionalMethod()
}


2个关键词:@objc和optional,这2个要配合使用才有效果;标记为optional的方法是可选的方法

第二种方式:

protocol MyViewDelegate {
    func requireMethod()
}
extension MyViewDelegate {
    func optionalMethod(){
    }
}

注意:这种方式的optional方法是必须要实现的,可以是个空方法