zoukankan      html  css  js  c++  java
  • iOS10 UI教程子视图和父视图UI层次结构和Views继承

    iOS10 UI教程子视图和父视图UI层次结构和Views继承

    iOS10 UI教程子视图和父视图UI层次结构和Views继承,本节将讲解与UI层次结构和Views继承相关的内容,其中包括子视图和父视图、管理层次结构、视图和子视图的可见性、层次结构的事件等内容。

    子视图和父视图

    每一个UIView(或者是子类)的实例都可以与其它的视图使用父-子关系的方式进行连接。其中父视图被称为superview(超视图),孩子视图被称为subviews(子视图)。一个视图可以有且仅有一个父视图,但是可以有多个子视图,如图所1.12示。

     

    图1.12  父视图和子视图

    对于父视图的访问开发者可以使用superview属性,其语法形式如下:

    var superview: UIView? { get }
    

    对应子子视图的访问可以使用subviews属性,其语法形式如下:

    var subviews: [UIView] { get }
    

    【示例1-6:SuperViewAndSubView】以下将通过superview属性和subviews属性对空白视图的背景颜色进行设置。具体的操作步骤如下:

    (1)打开Main.storyboard文件,从视图库中拖动View空白视图到View Controller的主视图中,将此空白视图的位置和大小调整为(16, 107, 343, 423)。为此视图声明和关联插座变量view1。

    (2)从视图库中拖到第二个View空白视图到View Controller的主视图中,并将此视图放置在view1视图中,将此视图的位置和大小调整为(51, 147, 240, 128)。为此视图声明和关联插座变量view2。

    (3)打开ViewController.swift文件,编写代码,为视图改变背景颜色。代码如下:

    import UIKit
    
    class ViewController: UIViewController {
    
        @IBOutlet weak var view1: UIView!
    
        @IBOutlet weak var view2: UIView!
    
        override func viewDidLoad() {
    
            super.viewDidLoad()
    
            // Do any additional setup after loading the view, typically from a nib.
    
            let parentView=view2.superview                                                              //获取view2的父视图
    
            let children=view1.subviews                                                                      //获取view1的子视图
    
            parentView?.backgroundColor=UIColor.red
    
            children[0].backgroundColor=UIColor.yellow
    
        }
    
    ……
    
    }
    

    此时运行程序,会看到如图1.13所示的效果。

     

    图1.13  运行效果                                   图1.14  索引

    相关阅读:iOS10 UI教程视图的中心位置

  • 相关阅读:
    失衡天平
    简单 hash 入门题目
    美团codem 数列互质
    最小圆覆盖
    求1-n 中与 m 互质的素因子 (容斥原理)
    格式化输出;while循环;运算符
    python的历史 常量 注释 基础数据类型等基本操作 和if 判断语句
    异常的概念
    isinstance与issubclass
    面向对象——内置函数
  • 原文地址:https://www.cnblogs.com/daxueba-ITdaren/p/6100546.html
Copyright © 2011-2022 走看看