swift UI专项训练41 用纯代码的方式实现stepper的值传递

前端之家收集整理的这篇文章主要介绍了swift UI专项训练41 用纯代码的方式实现stepper的值传递前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

之前讲过通过storyboard的方式捕获控件的值,现在我们来试试通过纯代码的方式来实现同样的功能。首先定义一个stepper和一个label,用label来显示stepper的当前值。

  1. self.priceStepper = UIStepper(frame: CGRectMake(150,120,100,20))
  2. self.priceStepper.minimumValue = 100//最小值
  3. self.priceStepper.maximumValue = 2000//最大值
  4. self.priceStepper.stepValue = 100//步长
  5. self.priceStepper.tintColor = UIColor.orangeColor()
  6. self.priceStepper.addTarget(self,action: "showPrice:",forControlEvents: UIControlEvents.ValueChanged)
  7. dialogContainer.addSubview(priceStepper)

我们使用了addTarget的方式,这跟之前在storyboard中拖动stepper的action中的ValueChanged是一样的,我们给这个步进器增加了一个addTarget,对象是它自己,捕获的是stepper值的变化,每当我们点击+或者-的时候,就会触发这个方法方法捕获了ValueChanged后,调用了一个action:showPrice。showPrice的代码如下:
  1. func showPrice(sender:UIStepper!){
  2. self.tasteLabel.text = "消费上限: \(Int(self.priceStepper.value))"
  3. }

tasteLabel是我们之前定义的用来显示stepper的值的,代码如下:
  1. self.tasteLabel = UILabel(frame: CGRectMake(20,130,10))
  2. // self.tasteLabel.textAlignment = NSTextAlignment.Center
  3. self.tasteLabel.font = UIFont.boldSystemFontOfSize(17)
  4. self.tasteLabel.text = "消费上限: 100"
  5. dialogContainer.addSubview(self.tasteLabel)
运行效果如下,初始状态:


点击stepper后label中的值会发生变化:

猜你在找的Swift相关文章