it-swarm.com.ru

Как получить все текстовые поля из представления в Swift

У меня есть мнение, которое имеет более 15 UITextFields. Я должен установить bottomBorder (расширение) для всех UITextFields. Я могу установить его один за другим для всех UITextFields и его работы тоже. Я хочу установить нижнюю границу для всех UITextFields одновременно. Вот код, который я пытаюсь, но кажется, что цикл for не выполняется. Я даже пробовал это в viewDidLayoutSubViews, но цикл не выполняется там тоже.

 override func viewDidLoad() 
{
    super.viewDidLoad()

    /** setting bottom border of textfield**/

    for case let textField as UITextField in self.view.subviews {
        textField.setBottomBorder()
    }
}
9
Kunal Kumar

Я заставил это работать, но все еще нуждаюсь в объяснении почему рассматриваемый код не работает
Я получил это от где-то на форуме, не могу ответить за ответ. 

/** extract all the textfield from view **/
func getTextfield(view: UIView) -> [UITextField] {
var results = [UITextField]()
for subview in view.subviews as [UIView] {
    if let textField = subview as? UITextField {
        results += [textField]
    } else {
        results += getTextfield(view: subview)
    }
}
return results  

Вызовите вышеуказанную функцию в viewDidLoad или viewDidLayoutSubviews.

override func viewDidLayoutSubviews() {
    super.viewDidLayoutSubviews()

/** setting bottom border to the textfield **/
    let allTextField = getTextfield(view: self.view)
    for txtField in allTextField
    {
        txtField.setBottomBorder()
    }
}
8
Kunal Kumar

Swift : эта функция вернет все текстовые поля в представлении. Не имеет значения, существует ли поле в каком-либо подпредставлении. ;-)

func getAllTextFields(fromView view: UIView)-> [UITextField] {
    return view.subviews.flatMap { (view) -> [UITextField]? in
        if view is UITextField {
            return [(view as! UITextField)]
        } else {
            return getAllTextFields(fromView: view)
        }
    }.flatMap({$0})
}

Использование:

_=getAllTextFields(fromView : self.view).map{($0.text = "Hey dude!")}
12
Gurjit Singh

попробуй это

for aSubView: Any in self.view.subviews {
if (aSubView is UITextField) {
    var textField = (aSubView as! UITextField)
    textField. setBottomBorder()
}
}     

или попробуйте это

for view in self.view.subviews {
if (view is UITextField) {
     var textField = view as! UITextField
      textField. setBottomBorder()
}
}
2
Anbu.Karthik

Это сработало для меня.

var textFieldsArray = [UITextField]()

for view in self.view.subviews {
    if view is UITextField {
        textFieldsArray.append(view as! UITextField)
    }
}

textFieldsArray.forEach { $0.setBottomBorder() }

Если вы хотите получить результат применения функции в новом массиве, используйте вместо этого map ().

1
GBaeOne

Попробуй это :)

for view in self.view.subviews as! [UIView] {
    if let textField = view as? UITextField {
        textField.setBottomBorder()
    }
}
1
Kevin Sabbe

расширение:

extension UIView {
    func viewOfType<T:UIView>(type:T.Type, process: (_ view:T) -> Void)
    {        
        if let view = self as? T
        {
            process(view)
        }
        else {
            for subView in subviews
            {
                subView.viewOfType(type:type, process:process)
            }
        }
    }
}

Использование:

view.viewOfType(type:UITextField.self) {
        view in

        view.text = "123"
}
1
Chen Jiling
func getTextFields() {
    for textField in view.subviews where view is UITextField {
       (textField as? UITextField).setBottomBorder()
    }
}
1
Jamal

Свифт 4 и Свифт 3: -
Очень простой ответ, который вы можете легко понять : - Вы можете обрабатывать все виды объектов, таких как UILable, UITextfields, UIButtons, UIView, UIImages. любой вид предметов и т. д.

for subviews in self.view.subviews
    {
        if subviews is UITextField
        {
            //MARK: - if the sub view is UITextField you can handle here
            funtextfieldsetting(textfield: subviews as! UITextField)
        }
        if subviews is UIButton
        {
         //MARK: - if the sub view is UIButton you can handle here
           funbuttonsetting(button: subviews as! UIButton)
        }
        if subviews is UILabel
        {
         //MARK: - if the sub view is UILabel you can handle here
         //Any thing you can do it with label or textfield etc

        }
    }
0
Shakeel Ahmed