• Swift


    原文出自:www.hangge.com  转载请保留原文链接:http://www.hangge.com/blog/cache/detail_519.html

    属性观察者,类似于触发器。用来监视属性的除初始化之外的属性值变化,当属性值发生改变时可以对此作出响应。有如下特点:
    1,不仅可以在属性值改变后触发didSet,也可以在属性值改变前触发willSet。
    2,给属性添加观察者必须要声明清楚属性类型,否则编译器报错。
    3,willSet可以带一个newName的参数,没有的话,该参数默认命名为newValue。
    4,didSet可以带一个oldName的参数,表示旧的属性,不带的话默认命名为oldValue。
    5,属性初始化时,willSet和didSet不会调用。只有在初始化上下文之外,当设置属性值时才会调用。
    6,即使是设置的值和原来值相同,willSet和didSet也会被调用

    class People
    {
        //普通属性
        var firstName:String = ""
        var lastName:String  = ""
        var nickName:String  = ""
         
        //计算属性
        var fullName:String
        {
            get
            {
                return nickName + " " + firstName + " " + lastName
            }
        }
         
        //带属性监视器的普通属性
        var age:Int = 0
        {
            //我们需要在age属性变化前做点什么
            willSet
            {
                print("Will set an new value (newValue) to age")
            }
            //我们需要在age属性发生变化后,更新一下nickName这个属性
            didSet
            {
                print("age filed changed form (oldValue) to (age)")
                if age<10
                {
                    nickName = "Little"
                }else
                {
                    nickName = "Big"
                }
            }
        }
         
        func toString() -> String
        {
            return "Full Name: (fullName) " + ", Age: (age) "
        }
         
    }
     
    let me = People()
    me.firstName = "Li"
    me.lastName  = "Lei"
    me.age = 30
     
    print(me.toString())
     
    /*程序输出
    Will set an new value 30 to age
    age filed changed form 0 to 30
    Full Name: Big Li Lei , Age: 30
    */
  • 相关阅读:
    JavaScript--DOM修改元素的属性
    JavaScript---DOM文档
    SQL查询语言练习
    SQL Server视图复习
    SQL Server存储过程复习(一)
    SQL Server中的连接查询【内连接,左连接,右连接,。。。】
    Linq查询简介
    CSS--选择器
    csharp:Conversion Between DataTable and List
    csharp: Linq keyword example
  • 原文地址:https://www.cnblogs.com/hero11223/p/5666210.html
Copyright © 2020-2023  润新知