Swift基础语法&SnapKit自动布局库的使用

这篇具有很好参考价值的文章主要介绍了Swift基础语法&SnapKit自动布局库的使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

文章涵盖了Swift的基础语法、元组、字符串、字典、数组、闭包、枚举、类和对象、属性、UI、懒加载等多个方面的内容,是一篇全面而深入的Swift学习笔记。

最近在学习swift和写项目,给我的感受,语言简洁和安全,在学习了基础的语法和一些必要的知识之后,因为OC的UI也用到了自动布局,所以也去探索了swift的自动布局库SnapKit,简单记录一下。

playground

开playground练习语法比较方便
Swift基础语法,Swift教程,SnapKit自动布局库的使用
有时候有些东西编译不出来记得

var 和 let-元组

import UIKit

var greeting = "Hello, playground"var str = "hello"str += "11"print(str)var a:Int = 1, b: String = "2", c:Double = 3.0print(a, b, c)print("b.count =", b.count, "sss")var smile = "smile\n"print(smile)// 不能数字命名开头//var 1x = 12;//print(1x)// 元组var person:(name:String, age:Int) = ("iOS", 19)print(person.name)var car:(String, Int) = ("Benz", 10000)var (theName, thePrice) = carprint(theName, thePrice)// 匿名// 在Swift语言中,常常使用符号“_”来表示匿名的概念,因此“_”也被称为匿名标识符。var (theName1, _) = car

var obj: String? // 在普通类型后面添加符号“?”,即可将普通类型包装为Optional类型。// 在Swift语言中,未做初始化的普通类型是不允许使用的if obj == nil {
    print("!obj")}// 在使用“!”进行Optional值的拆包操作时,必须保证要#包的值不为nil,否则程序运行会出错。可以在拆包前使用if语句进行安全判断//声明obj为String?类型var obj2: String? = "safe"if obj != nil {
   obj!}//  if-let结构中也可以同时进行多个Optional类型值的绑定// 只有所有Optional值都不为nil,绑定才会成功,代码执行才会进入if为真的代码块中var curObj: Int? = 9if let temp = curObj {
    print(temp)} else {
    curObj = 10;}// 当我们明确某个变量初始时为nil,并且在之后使用之前一定会被赋值时,我们可以将其声明为隐式解析的可选值,再对这个变量进行使用,就不需要进行拆包操作了// 声明obj4为隐式解析的变量var obj4:Int!obj4 = 3// 在使用时,无须再进行拆包操作,Swift会自动帮我们拆包print(obj4 + 1)

string-字典-数组

import UIKit

var greeting = "Hello, playground"var str = String(describing: Int.self)var a = Int(1.9)var my = "jackDao"// 符串插值方法// \()”结构可以将其他数据类型转换为字符串类型并且插入字符串数据的相应位置,也可以进行简单的运算逻辑后将结果插入原字符串中var myself = "my name is \(my)"print(myself)MemoryLayout<String>.size  //16个字节 获取String类型占用的内存空间var e:Character = "a"var e2: [Character] = ["H", "E", "L", "L", "O"]var e3 = String(e2)// 使用for-in遍历可以将字符串中的字符拆解出来,这种方法有时十分好用,for-in遍历是Swift语言中一种重要的代码流程结构。String类型默认实现了迭代器相关协议,直接对其进行遍历可以取出字符串中的每一个字符元素for charceter in e2 {
    print(charceter)}//判断字符串是否为空var obj1 = ""if obj1.isEmpty {
   print("字符串为空字符串")}// 在比较两个字符串的大小时,会逐个对字符的大小进行比较,直至遇到不相等的字符为止var cp1 = "comp1", cp2 = "comp2"
    if cp1 < cp2 {
        print("cp1 is Small")
    }var string2 = "My name is Jaki"//全部转换为大写string2 = string2.uppercased() //结果为"MY NAME IS JAKI"//全部转换为小写string2 = string2.lowercased() //结果为"my name is jaki"//检查字符串是否有My前缀string2.hasPrefix("My")//检查字符串是否有jaki后缀string2.hasSuffix("jaki")var array: Array<Int>var array2: [Int]array = []array2 = Array()array = [1, 2, 3]array2 = Array(arrayLiteral: 1, 3, 4)var array3 = [String](repeating: "Hello", count: 10);var array4 = Array(repeating: 1, count: 10)//声明字典[param1:param2],这种结构用于表示字典类型,param1为键类型,param2为值类型var dic1:[Int:String]//这种方式和[:]效果一样,dic2与dic1为相同的类型var dic2:Dictionary<Int,String>//字典创建与赋值dic1 = [1: "1", 2: "2", 3: "3"]dic2 = Dictionary(dictionaryLiteral: (1, "1"),(2, "2"),(3, "3"))//在创建字典时,也可以不显式声明字典的类型,可以通过赋初值的方式来使编译器自动推断var dic3 = ["1": "one"]//创建空字典var dic4: [Int:Int] = [:]var dic5: Dictionary<Int,Int> = Dictionary()1==2 //等于比较,返回false1<2  //小于比较,返回true1>2  //大于比较,返回false1 != 2 //不等于比较,返回true1<=2  //小于等于比较,返回true1>=2  //大于等于比较,返回falsefor index in 1...10 {
    print(index)}var sum = 0for _ in 1...10 {
    sum += 1}
  • swift的字典和OC的差距还是比较大的,swift中的任何类型在声明时都必须明确其类型,通过对ArraySet的学习,读者应该知道,对于集合类型,在声明时务必明确其内部元素的类型,字典也不例外

  • 今天测试了一下知乎日报的接口,发现不能类似于OC的多级直接访问某个元素,会报错。

  • 对于循环访问字典里嵌套的数组需要如下操作,但是还是难以实现多级一次性访问,后面还是需要学习swift的JSONModel库,也是第三方库,应该和OC区别不大。

if let stories = dict["stories"] as? [[String: Any]] {
    for story in stories {
        if let title = story["title"] as? String {
            print("Title: \(title)")
        }
        
        if let content = story["content"] as? String {
            print("Content: \(content)")
        }
        
        if let tags = story["tags"] as? [String] {
            for tag in tags {
                print("Tag: \(tag)")
            }
        }
        
        // 其他键值对的访问...
    }}

闭包

import UIKit

var greeting = "Hello, playground"// 一个完整的函数包含函数名、参数列表、返回值和函数体,示例如下://标准函数,这个函数的功能是计算某个整数的平方func myFunc(param: Int) -> Int {
   return param * param}// 将上面函数的功能使用闭包来实现,代码如下://闭包的实现方式let myClosures = {(param1: Int) -> Int in    return param1 * param1}/*闭包在语法上有这样的标准结构:{(参数列表)->返回值in闭包体}。首先闭包的最外层由大括号包围,内部由闭包关键字in来进行分割,关键字in前面为闭包结构的参数列表和返回值,其书写规则与函数一致,关键字in后面为闭包体,用于实现具体功能*///对函数进行调用,将返回9myFunc(param: 3)//对闭包进行调用,将返回9myClosures(3)// 闭包的返回值是可以省略的//闭包的实现方式let myClosures2 = {(param:Int) in   return param * param}var x = myClosures2(2)var x1 = myClosures(2)// 自定义前缀运算符prefix operator ++;prefix func ++(param1: Int) -> Int {
    return param1 + 1;}var num = 10++num // num++ error

enum

import UIKit

var greeting = "Hello, playground"enum Surname {
    case 赵, 钱, 孙, 李}//var sur: Surnamevar sur = Surname.孙

类和对象

import UIKit

var greeting = "Hello, playground"struct Car {
    var price: Int
    var brand: String
    var pertol: Int
    
    mutating func addPertol() {
        if pertol <= 0 {
            pertol += 1
            print("add Pertol")
        }
    }
    //在默认情况下,结构体和枚举的实例方法是不允许修改实例属性的,除非将方法标记为mutating。使用mutating关键字修饰的方法可以在方法内部修改实例属性,并且在方法执行完毕后,这些修改将会保持在实例中。
    mutating func drive() {
        if pertol > 0 {
            pertol -= 1
            print("drive 10 kilometers")
        }
    }}var car = Car(price: 10000, brand: "Benz", pertol: 5)print("this \(car.brand) price is \(car.price), have \(car.pertol) pertol")for _ in 1...10 {
    if car.pertol == 0 {
        car.addPertol()
    } else {
        car.drive()
    }}// 在默认情况下,结构体和枚举的实例方法是不允许修改实例属性的,除非将方法标记为mutating。使用mutating关键字修饰的方法可以在方法内部修改实例属性,并且在方法执行完毕后,这些修改将会保持在实例中。// 对引用类型进行比较操作,应使用等同运算符“===”// Array、String、Dictionary、Set这些数据类型都是采用结构体来实现的,这点和Objective-C有着很大的区别。因此,在Swift语言中,Array、String、Dictionary、Set在数据传递时总是会被复制

属性

import UIKit//  监听var greeting = "Hello, playground"class Teacher {
    var name: String {
        willSet(new) {
            print("将要设施的新名字:\(new)")
        } didSet(old) {
            print("旧名字\(old)")
        }
    }
    var age: Int    init(name: String, age: Int) {
        self.name = name
        self.age = age    }}var teacher = Teacher(name: "jackLi", age: 19)teacher.name = "lyt"// 对比类属性,Swift语言中的类方法也是通过static和class关键字来声明的,static关键字声明的类方法又被称为静态方法,其不能被子类覆写,而class关键字声明的类方法可以被类的子类覆写

import UIKit

var greeting = "Hello, playground"// 对于有继承关系的类,类型检查有如下原则:子类实例进行父类类型的检查可以检查成功。父类实例进行子类类型的检查不可以检查成功。var str = "Hello ios"if str is String {
    print("greeting is String")}// 其实如果数组中的元素是不同类型,并且这些类型没有一个共同的基类,那么开发者可以使用AnyObject来作为引用类型的通用类型// AnyObject是通用的引用类型class myClassOne {
    }class myClassTwo {
    }class myClassthree {
    }var c1 = myClassOne()var c2 = myClassTwo()var c3 = myClassthree()var classArray: Array<AnyObject> = [c1, c2, c3]for objclass in classArray {
    print(objclass)}// 在Swift语言中还提供了一种更加通用的类型Any,它可以用来描述任意类型,包括值类型和引用类型print("anyClass")var anyClassArray: Array<Any> = [c1, c2, c3, (1, 1), "anyType"]for objclass in anyClassArray {
    print(objclass)}

UI

和OC的区别,更简洁

首先语言在初始的时候没有了接口文件,接口和实现是在一个文件里面的,并且我在某些界面不需要写头文件也能引用某些ViewController,除非特定的第三方库。
Swift基础语法,Swift教程,SnapKit自动布局库的使用

懒加载

  • 延续懒加载的思想

  • 语法简单 直接+lazy关键字 需要var不能let

  • 在最上面的init方法里面匿名调用方法即可

lazy var mainBackImageView: UIImageView = {
        let image1: UIImage = UIImage(named: "MainBack.png")!
        let imageView: UIImageView = UIImageView(image: image1)
        self.addSubview(imageView)
        imageView.snp .makeConstraints { make in
            make.width.equalTo(SIZE_WIDTH + 17)
            make.height.equalTo(SIZE_HEIGHT + 17)
            make.left.equalTo(-7)
            make.top.equalTo(-7)
        }
        return imageView    }

()Swift基础语法,Swift教程,SnapKit自动布局库的使用

Swift基础语法,Swift教程,SnapKit自动布局库的使用

全局文件

在swift的时候,本来宏定义屏幕的尺寸等,接着就发现了全局文件。

Swift基础语法,Swift教程,SnapKit自动布局库的使用
全局文件定义的内容可以在多个文件使用,随时访问。Swift基础语法,Swift教程,SnapKit自动布局库的使用

  • 例如我在全局文件定义了一些项目里面要用到的背景颜色,长宽。

  • 今天在写通知传值的时候发现可以在这里定义name,也挺方便。

snap kit的使用

和以前的使用第三方库一样,都是pod下来就能用。
Swift基础语法,Swift教程,SnapKit自动布局库的使用
和masonry感觉没有区别。

toptopMargin

在 SnapKit 中,toptopMargin 是两种不同的约束属性,用于设置视图的顶部边距。

  1. top 属性:

    • top 属性表示视图的顶部边距相对于其父视图或参考视图的顶部边距的距离。

    • 它是相对于父视图或参考视图的真实顶部边距进行约束计算的。

    • 通常在设置约束时,需要将视图与其父视图或参考视图的顶部边距之间的距离设置为特定值。

  2. topMargin 属性:

    • topMargin 属性表示视图的顶部边距相对于其父视图的布局边距的距离。

    • 它是相对于父视图的布局边距进行约束计算的。

    • top 属性相比,topMargin 属性会考虑到布局边距的影响,使得视图的位置更具适应性和灵活性。

    • 在一些布局中,特别是在使用自动布局和边距布局时,使用 topMargin 属性可以更好地处理边距的变化和调整。

总的来说,top 属性是基于视图的真实顶部边距进行约束计算的,而 topMargin 属性是基于父视图的布局边距进行约束计算的。根据你的布局需求和使用场景,选择合适的属性来设置视图的顶部边距约束。

我感觉区别不是很大,一直用的top没啥问题。

总结

swift的字典和数组,元组在写项目的时候感觉没有用到很多,字典那块的问题好像还挺多的,包括如何多层读取不报错,和OC还是有区别,研究了再来总结文章来源地址https://www.toymoban.com/news/detail-478805.html

到了这里,关于Swift基础语法&SnapKit自动布局库的使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Swift学习笔记(一)基础语法

    浅学一下Swift,这篇笔记做个记录 依然是Xcode,关于Xcode就不多介绍了。 let和var分别用来表示常量和变量,无论是let还是var,作用都是为某个具体量值取了一个名字,这种方式叫做量值的声明。在量值的有效作用域内,开发者可以使用这些名称来获取具体的量值

    2024年01月17日
    浏览(24)
  • python接口自动化测试 requests库的基础使用

    目录 简单介绍 Get请求 Post请求 其他类型请求 自定义headers和cookies SSL 证书验证 响应内容 获取header 获取cookies requests库简单易用的HTTP库   格式:  requests.get(url)  注意: 若需要传请求参数,可直接在 url 最后的 ? 后面,也可以调用 get() 时多加一个参数 params ,传入请求

    2023年04月26日
    浏览(21)
  • flutter基础入门教程(Dart语法+UI布局+页面路由+后端连接)

    1、环境安装 1基础安装步骤教程 Android Studio安装与配置 https://juejin.cn/post/6844904054569582605 安装Android Studio前,需要先选择安装Java环境,Java需要到Oracle官网上下载安装,需要注册一个Oracle账号。 https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html Windows 10 配置Java 环境变量

    2024年02月03日
    浏览(18)
  • 第4天:基础入门-30余种加密编码进制&;Web&;数据库&;系统&;代码&;参数值

    1.了解加密编码进制在安全测试中的存在 2.掌握常见的加密解密编码解码进制互转的操作 3.了解常见的加密解密编码解密进制互转的影响 旨在解决类似疑问,提供思路: 你是否碰到不知道的加密方式? 你是否碰到无法找到的解密平台? 你是否碰到不知道如何解密的字符串?

    2024年02月06日
    浏览(25)
  • 010-基础入门-HTTP数据包&;Postman构造&;请求方法&;请求头修改&;状态码判断

    2、Cookie-身份替换 见上图 首先抓取PC浏览器网站登录上去的数据包 再抓取模拟机上登录失败的数据包 把数据包中的cookie进行替换,发现模拟机上从登陆失败变成登陆成功 结论: Response状态码 选中抓取数据包,发送至repeater( Repeater 是一个手动修改并补发个别 HTTP 请求,并分

    2024年04月23日
    浏览(19)
  • OC和Swift混合开发(Pod私有库的相互引用)

    环境 Xcode 12.4,    Swift:5.0 概述:该文档主要介绍OC和Swift混合开发相互调用,包括3大类情况和12种具体情形。 1. 主工程内的混合互调, 2. 主工程和Pod三方库之间的混合互调, 3. Pod三方库和其他Pod三方库之间的混合互调。 1. 主工程内的OC 调用 主工程内的OC: #import \\\"NSObject.

    2024年03月09日
    浏览(18)
  • swift ui 布局 ——Stack(HStack、VStack、ZStack)

    将其子视图排列在水平线上 默认子视图是水平中心对齐的,可添加alignment  修改位置,alignmet 的值有 bottom   top  center等,可自己查看api 将其子视图排列在垂直线上 默认子视图是垂直中心中心对齐的,可添加alignment  修改位置,alignmet 的值有 leading   trailing  center等 用于覆盖

    2024年02月05日
    浏览(20)
  • 阿里P8解析自动化测试工具 —— Selenium&;Appium(1)

    (4)测试活动开展初期制定自动化测试策略; (5)有足够的人力/财力投入 根据被测系统的结构形式,目前业内主要有两款开源的基于UI层面的自动化测试工具应用较为广泛,一是测试Web结构的Selenium,二是测试移动应用结构的Appium。商用的自动化测试工具则是HP公司生产的

    2024年04月17日
    浏览(20)
  • python自动定时任务schedule库的使用方法

    当你需要在 Python 中定期执行任务时, schedule 库是一个非常实用的工具。它可以帮助你自动化定时任务。以下是一些使用示例: 基本使用 : 上面的代码表示每隔 10 分钟执行一次 job 函数,非常简单方便。 更多调度任务例子 : 只运行一次任务 : 参数传递给作业 : 获取目前

    2024年02月21日
    浏览(19)
  • Python自动化测试--xlwings库的使用(适合新手)

    xlwings目录 前言 一、xlwings是什么? 二、xlwings的下载 三、xlwings的使用 1.引入库 2.打开excel 3、获取sheet对象 4、对单元格的操作

    2024年02月14日
    浏览(23)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包