在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
看了斯坦福老头的课,真心觉得,我的中文怎么也变的这么垃圾了。是关于iOS8的课程,用swift写的,一个计算器应用的制作,看看人家的课,再看看咱们学校的课(不过垃圾学校,纯粹觉得大学浪费了),废话啊,废话,继续废话。那个老头的代码有些我给省略了,不知道会出现什么问题,反正我是没有发现,如果你发现了,请告诉我。还有就是这个计算器的具体操作步骤是,你先4-> 回车-> 5-> 回车 ->乘号 显示计算结果20 首先是界面的搭建,就是0-9一共10个按钮,然后加减乘除四个操作按键,以及,一个回车键(用来将所输入的数存放在栈中,反正老头是这样说的,他把输入进去的数存放到了一个数组中了var operandStack = Array<Double>(),还有就是一个用来显示输入的数以及输入结果的label了。这些都是在故事板中进行的(当然除了那个数组),然后将label与代码关联 @IBOutlet weak var resultLabel: UILabel! //事实上,在这里指明类型被认为是不好的书写方式,如果可以推断出类型 ,你就应该让编译器自己去推断 //var isStart :Bool = false var isStart = false //用户是不是已经输入,那个老外用了一长串的字符userIsInTheMiddleOfTypingANumber
将0-9这10个数的点击事件与代码关联 @IBAction func buttonTap(sender: UIButton) { let digit = sender.titleLabel?.text// 注意这个digit是一个可选值(opentional),就是你点击的按钮上的数字, if isStart{ resultLabel.text = resultLabel.text! + digit! //可选值是不可以拼接字符串的,所以在这个地方,需要进行解包 }else{ resultLabel.text = digit//用户第一次点(我这样理解的),结果框显示你按的那个数 isStart = true//这个是说用户已经开始输入了 } }
var operandStack = Array<Double>() //这个变量是一个内部的栈,去存储你输入的这些数,他的类型是一个数组,这个数组里存放的是Double的变量,注意在这个地方要初始化,(我们不能使用没有经过初始化的,会报错) @IBAction func enter() { isStart = false //因为我们在点完enter的时候,需要将刚才输入的数放到栈里,并且输第二个数,所以需要将这个布尔值设为false // var value = (resultLabel.text! as NSString).doubleValue operandStack.append(resultValue) println("operandStack: \(operandStack)") }
//计算型属性 var resultValue:Double{ get{ return NSNumberFormatter().numberFromString(resultLabel.text!)!.doubleValue } set{ resultLabel.text = "\(newValue)" //newValue是系统的,就是想要设置的那个值 2将double类型转换为字符串 // isStart = false// 这句话写在这不知道是什么意思,该怎么理解呢 }
}
@IBAction func operate(sender: UIButton) { let operation = sender.currentTitle! switch operation{ // case "✖️" : performOperation { $1 * $2 } case "✖️": performOperation { $0 * $1} //这个地方,这地方真心坑,$0 * $1,我还以为传进入随便两个数就行了呢,那老头对这段代码不断的简化简化,才写成了这样,明天把简化的过程单独整理出来(明日复明日啊) case "➗" : performOperation { $1 / $0 } case "➖" : performOperation { $1 - $0 } case "➕" : performOperation { $1 + $0 }
default:break
}
}
func performOperation(operation:(Double,Double)->Double){//函数的参数是一个函数 if operandStack.count >= 2{ resultValue = operation(operandStack.removeLast() , operandStack.removeLast())//operandStack.removeLast()难道说,这个方法删除并返回了最后一个数? }
}
// func multipy(op1:Double,op2:Double)->Double{ // // return op1 * op2 // }
|
请发表评论