学习日志-Swift
程序员文章站
2022-04-11 17:49:52
...
2017年度
7月 Swift
7月4号
- 学习swiift版约束库 -- SnapKit
简单易用,上手很快,语法也跟masonry很像,会用masonry,使用这个就不成问题
grayview.snp.makeConstraints { (make) in
make.size.equalTo(greenview)
make.centerX.equalTo(greenview)
}
- 创建单糖Demo
创建工程的同时,创建远程仓库
拉取的时候采用
git pull origin master --allow-unrelated-histories
以此来合并本地仓库和远端仓库 参考:通过xcode创建远程仓库
7月5号
- 学习
Alamofire
swift版网络解析库
Alamofire.request("http://japi.juhe.cn/joke/content/list.from", method: .get, parameters: nil, encoding: URLEncoding.default, headers: nil).responseJSON { (response) in
guard let json = response.result.value else{
return
}
print("JSON: \(json)")
}
Alamofire.request("https://api.500px.com/v1/photos", method: .get, parameters: ["consumer_key":"fHd2MvJL2xgDBk0MFhBBPuTZuefR7iXOKgoz7B0f"], encoding: URLEncoding.default, headers: nil).responseJSON { (response) in
guard let json = response.result.value else{
return
}
print("JSON: \(json)")
}
- 学习Kingfisher
Kingfisher是一个开源处理图片加载、缓存的开源库,它的灵感来源于SDWebImage(OC的一个框架,现在也提供了Swfit版本)。Kingfisher给你提供了一个使用纯Swift构建App的机会
var url = String()
url = "http://img.lenovomm.com/s3/img/icon/app/app-img-lestore/8814-2015-07-07034344-1436255024442.png"
blueview.kf.setImage(with: ImageResource(downloadURL: NSURL.init(string: url)! as URL))
blueview.contentMode = UIViewContentMode.scaleAspectFill
7月6号
-
构建单糖项目
各个修饰符区别(fileprivate,private,internal,public,open)
1,private
private访问级别所修饰的属性或者方法只能在当前类里访问。
2,fileprivate
fileprivate访问级别所修饰的属性或者方法在当前的Swift源文件里可以访问。(比如上门样例把private改成fileprivate就不会报错了)
3,internal(默认访问级别,internal修饰符可写可不写)
internal访问级别所修饰的属性或方法在源代码所在的整个模块都可以访问。
如果是框架或者库代码,则在整个框架内部都可以访问,框架由外部代码所引用时,则不可以访问。
如果是App代码,也是在整个App代码,也是在整个App内部可以访问。
4,public
可以被任何人访问。但其他module中不可以被override和继承,而在module内可以被override和继承。
5,open
可以被任何人使用,包括override和继承。
5种修饰符访问权限排序
从高到低排序如下:
open > public > interal > fileprivate > private
原文出自:[www.hangge.com](http://www.hangge.com/) 转载请保留原文链接:[http://www.hangge.com/blog/cache/detail_524.html](http://www.hangge.com/blog/cache/detail_524.html)
- SVProgressHUD学习
- ReactiveSwift学习,这个真是极其坑爹的
7月7号
- ps,今天睡过头了,晕
- 继续swift项目-单糖
swift2.0下重写setter和getter
重写属性的setter方法
willSet在设置新的值之前调用
didSet在新的值被设置之后立即调用
- swift - 懒加载
Swift - 懒加载(lazy initialization)
懒加载的写法本质上是定义并执行一个闭包
private lazy var leftButton :UIButton = {
let leftButton = UIButton.init()
leftButton.setTitle("喜欢的商品", for: .normal)
return leftButton
}()
- selecter初始化
swift 中如何使用selector
action:Selector = #selector(ViewController.test)
7月10号
- 继续单糖demo
- 闭包
Swift3.0 闭包整理
起别名: typealias AddBlock = (Int, Int) -> (Int)
var block: AddBlock?
7月11号
- for in 循环
let list = [1,3,5,7,"string test"]
for i in list{
print(i)
}
let dict = ["name":"key name","name1":"key1 name","name2":"key 2 name"]
for key in dict{
print(key)
}
反向遍历
for i in (0...10).reverse(){
print(i)<br> // 打印结果为10-0
}
- 单例
//单例
static let shareSingleOne = SingleOne()
- 闭包 @escaping
在之前,一个函数的参数的闭包的捕捉策略默认是escaping,如果是一个非逃逸闭包需要显示的添加声明@noescape。感兴趣的可以看我以前写过一篇介绍:Swift中被忽略的@noescape。简单的介绍就是如果这个闭包是在这个函数结束前内被调用,就是非逃逸的即noescape。如果这个闭包是在函数执行完后才被调用,调用的地方超过了这函数的范围,所以叫逃逸闭包。
Swift 3必看:@noescape走了, @escaping来了 - 下划线的作用
Swift——(三)Swift神奇的下划线
7.12号--至今
写公司项目
7.18号总结
- 从小细节做起,因为设置tag值的重复,导致了bug的产生,这是一个深刻的教训
上一篇: 《Swift 4.0 语言学习之路》第一章 语法基础篇(2)
下一篇: Redis面试必备(一)