Object-C--->Swift之(十)存储属性

简介: 计算属性相当于Object-C的getter、setter合成的属性,在Swift中结构体、类都可以定义计算属性定义计算属性[修饰符] var 计算属性名:属性类型{ get{ //getter方法执行体,该方法必须有返回值 } [set(形参名) {...

计算属性相当于Object-C的getter、setter合成的属性,在Swift中结构体、类都可以定义计算属性

定义计算属性

[修饰符] var 计算属性名:属性类型{
 get{
 //getter方法执行体,该方法必须有返回值
 }
 [set(形参名)
 {
 //setter方法执行体,该方法一定不能有返回值
 }]
}

注意:var计算属性只能定义成变量形式

enum Season
{
case Spring,Summer,Fall,Winter
var info:String
{
  get{
  print("正在执行getter方法")
    switch(self)
    {
     case .Spring:
     return "春暖花开"
     }
     default:
     return "此恨绵绵无绝期"
}
}
set(newValue)
{
print("正在执行setter方法,传入参数为:\(newValue)")
}
}
}
var s=Season.Spring
print(s.info)//访问info属性,实际就是调用对应的getter方法
s.info="秋高气爽"//对info属性赋值,实际就是调用对应的setter方法
}

再举一个类的例子

class User
{
  var first:String=""
  var last:String=""
  var fullName:String
  {
   get {
     return first + "-" + last
   }
   set(newValue)
   {
     var names=newValue.componentsSeparatedByString("-")
     self.first=names[0]
     self.last=name[1]
   }
  }
  init(first:String,last:String)
  {
  self.first=first
  self.last=last
  }
}
    let s=User(first:"六小龄童",last:"孙悟空")
    print(s.fullName)
    s.fullName="甄子丹-悟空"
    print(s.first)//输出甄子丹
    print(s.last)//输出悟空

setter方法简化

计算属性的setter方法总是只有一个形参,且该形参的类型与该计算属性的类型相同,因此Swift允许在定义计算属性时省略set部分的形参名。
如果程序省略计算属性的set部分的形参名,程序将为该形参提供一个隐式的形参名:newValue。所以可以改为

set{
   var names=newValue.componentsSeparatedByString("-")
   self.first=name[0]
   self.last=name[1]
}

只读的计算属性

只有get部分的话称为只读的计算属性。我们可以省略get关键字和花括号
如上面的可以改为

 var fullName:String{
  return first + "-" + last
 }

注意即使是只读属性也必须用var关键字

相关文章
|
7月前
|
前端开发 容器
使用 object-fit 属性完美过渡图片
这篇文章介绍了CSS属性object-fit的用法。object-fit属性用于指定元素的内容如何适应指定容器的高度和宽度。该属性一般适用于img和video标签,可以进行剪切、缩放或拉伸操作。文章中展示了通过object-fit属性来统一设置多张图片的样式,保持原始比例并改变显示位置的示例,以及使用object-position属性实现简单的过渡效果。
使用 object-fit 属性完美过渡图片
|
7月前
|
JavaScript
vue2中$set的原理_它对object属性做了啥?
vue2中$set的原理_它对object属性做了啥?
66 1
|
7月前
|
前端开发 Java 编译器
Object c/swift,java,c/c++在32位和64位各个平台上基本数据类型 所占有的字节数
Object c/swift,java,c/c++在32位和64位各个平台上基本数据类型 所占有的字节数
50 0
|
前端开发
前端学习笔记202306学习笔记第四十一天-Es6-object.defineProperty监听属性的访问和设置1
前端学习笔记202306学习笔记第四十一天-Es6-object.defineProperty监听属性的访问和设置1
45 0
|
前端开发
前端学习笔记202306学习笔记第四十一天-Es6-object.defineProperty监听属性的访问和设置3
前端学习笔记202306学习笔记第四十一天-Es6-object.defineProperty监听属性的访问和设置3
50 0
|
前端开发
前端学习笔记202306学习笔记第四十一天-Es6-object.defineProperty监听属性的访问和设置4
前端学习笔记202306学习笔记第四十一天-Es6-object.defineProperty监听属性的访问和设置4
42 0
|
前端开发
前端学习笔记202306学习笔记第四十一天-Es6-object.defineProperty监听属性的访问和设置2
前端学习笔记202306学习笔记第四十一天-Es6-object.defineProperty监听属性的访问和设置2
46 0
|
JavaScript 前端开发
熬夜整理的 Object 对象的静态方法、实例属性和实例方法
熬夜整理的 Object 对象的静态方法、实例属性和实例方法,用于理解 Object 对象的静态方法和实例方法的区别,以及 Object 对象的静态方法和实例方法的使用。
97 0
|
前端开发
实用CSS属性——object-fit
我们常常将图片或者视频放在一个盒子内,那么就经常在业务上考虑适配的问题,而object-fit能帮助我们设定图片在盒子中的显示方法
271 6
|
JavaScript
js获取对象属性的两种方法,object.属性名,[‘属性名’ ]
js获取对象属性的两种方法,object.属性名,[‘属性名’ ]
1004 0
js获取对象属性的两种方法,object.属性名,[‘属性名’ ]

相关课程

更多