Разработка под iOS с Swift2 - Advanced iOS

В этой главе мы рассмотрим некоторые дополнительные функции, такие как создание нескольких представлений в нашем приложении, добавление панелей навигации, добавление табличных представлений, хранение данных в приложении, создание веб-приложений и т. Д.

Пожалуйста, внимательно просмотрите каждый раздел, так как в этой главе содержится большинство вещей, которые нам нужны при разработке приложений.

Контроллер множественного просмотра

В наших предыдущих приложениях мы давали только один контроллер представления / представления. Однако у нас может быть несколько представлений в нашем приложении, и мы можем работать с любым из них независимо.

Поэтому начнем с создания нового проекта; название этого проекта имеет несколько просмотров. Как и любой другой проект, в этом проекте также есть контроллер представления и файл Swift для этого контроллера. (Это можно увидеть, выбрав вид и просмотрев его свойства в Инспекторе удостоверений.)

На следующем снимке экрана показано, как выглядит наш текущий вид -

Справа (инспектор идентичности) мы видим класс, связанный с нашим контроллером представления. Эта стрелка слева - точка входа. Это первое представление нашего приложения, которое будет отображаться после запуска приложения.

Добавление второго контроллера множественного просмотра

Чтобы добавить другие контроллеры представления в наше приложение, мы будем искать контроллер представления в нашей библиотеке объектов. Как только мы его найдем, мы перетащим контроллер представления на нашу main.stroryboard, за пределами любых других представлений.

Вот как должно выглядеть ваше приложение. Теперь мы добавили контроллер представления, но теперь нам также нужно будет создать класс контроллера представления для нашего недавно добавленного представления.

Right click on your project → new File → cocoa Touch Class → Назовите его как хотите, мы назовем его «SecondViewController».

Вот как вы создаете файл класса для вашего контроллера представления. Теперь вернитесь к своему «main.storyboard», щелкните второй контроллер представления и посмотрите его Identity Inspector.

Поле класса сейчас должно быть пустым, поэтому щелкните это поле и начните вводить имя своего класса, которое вы добавили на последнем шаге. Если он появится, нажмите Enter.

Теперь мы создали контроллер с несколькими представлениями и добавили файл класса контроллера для этого представления. Однако, если вы запустите приложение, оно все равно не будет отображать ваше второе представление. Почему?

Потому что мы не добавили функцию, которая приведет нас к этому представлению. Короче говоря, мы еще не добавили навигацию в наше приложение. Не волнуйтесь; мы рассмотрим это в следующем разделе.

Добавление навигации в приложение

Процесс перехода от одного взгляда к другому называется Segueing, т.е. выполняется путем создания перехода между двумя представлениями. Для этого добавьте кнопку в первый контроллер представления и перетащите управление от нее на второе представление. Когда вы отпустите кнопку, вы увидите некоторые параметры, как показано на снимке экрана ниже.

Выберите опцию Показать из перехода к действию. Теперь запустите свое приложение, вы увидите, что при нажатии кнопки появляется второе представление (чтобы более четко видеть, добавьте что-то во втором представлении, чтобы вы могли идентифицировать).

Однако теперь вы не можете вернуться к своему первому просмотру. Для этого у нас естьNavigation controllers.

Добавление контроллера навигации

Выберите свой первый контроллер представления и на верхней панели щелкните Editor → Embed in → Navigation controller.

Теперь наше приложение должно выглядеть как на следующем снимке экрана.

Мы должны позаботиться о том, чтобы сверху вида был небольшой светло-серый ряд. Теперь, когда мы запускаем приложение, мы видим, что в верхней части представления есть панель навигации. Когда мы нажимаем на кнопку, мы переходим ко второму виду, где мы увидим кнопку «Назад» на этой панели навигации. Щелкните по нему, и мы вернемся к исходному виду.

Добавление заголовка и кнопки "Назад" на панель навигации

Чтобы добавить заголовок на панель навигации, щелкните панель навигации и откройте ее инспектор атрибутов. Там мы увидим -

  • Title - Это будет заголовок панели навигации, которая появится в центре.

  • Prompt - Это отображается в верхней части строки заголовка в центре.

  • Back Button - Здесь вы можете изменить текст, отображаемый на кнопке возврата.

В настоящее время кнопка, передающая представление, находится в нашем представлении, что может не подойти, если мы хотим, чтобы на экране отображалось что-то еще. Поэтому мы добавим элемент Bar Button на панель навигации, который перенесет нас во второе представление. Однако для этого мы должны сначала удалить последнюю добавленную кнопку.

Добавление элемента кнопки панели

Найдите элемент кнопки панели в библиотеке объектов и перетащите курсор в правую часть панели навигации. Назовите его - «Далее>», перетащите его от него ко второму представлению, выберите «Показать», как мы сделали с последней добавленной кнопкой.

Теперь запустите приложение, оно будет выглядеть чище и лучше. Это все, что мы сейчас будем делать с навигацией. В следующих главах мы при необходимости изменим панель навигации с помощью кода Swift.

Представления таблиц

Таблица представляет данные в виде списка из одного столбца, содержащего несколько строк, которые можно разделить на разделы. Таблицы следует использовать для четкого и эффективного представления данных.

В этом разделе мы поймем, как добавлять представления таблиц, добавлять ячейки прототипа, добавлять источник данных и делегатов для представления таблицы, изменять свойства таблицы и устанавливать динамические данные для ячеек представления таблицы.

Добавление представления таблицы

Чтобы добавить табличное представление, мы сначала создадим новый проект и назовем его «tableView». Затем перейдите в библиотеку объектов и найдите Table View, мы увидим табличное представление, контроллер табличного представления и многие другие параметры. Однако мы должны выбрать табличное представление, перетащить его и добавить к стандартному представлению Controller.

Добавление прототипа ячейки

Растяните представление таблицы так, чтобы оно охватило все представление, в то время как представление таблицы выделено. Проверьте его инспектор атрибутов, есть поле с именем Prototype cells, которое в настоящее время равно 0. Мы должны изменить его значение на 1, теперь ваше представление должно выглядеть следующим образом:

Изменение идентификатора ячейки

Теперь внутри вашего представления щелкните ячейку своего прототипа (что немного сложно). Итак, в структуре документа щелкните «Контроллер представления» → «Просмотр» → «Просмотр таблицы» → «Ячейка представления таблицы», и теперь в инспекторе его атрибутов есть столбец с именем «Идентификатор», щелкните его и назовите «Ячейка». См. Следующие снимки экрана, чтобы понять описанные выше действия.

Добавление делегата и источника данных

Чтобы сделать наши представления таблиц динамическими, нам нужно, чтобы они загружали динамические данные. Следовательно, для этого нам нужен делегат и источник данных. Чтобы сделать делегацию и источник данных для вашей таблицы, перетащите управление перетаскиванием из представления таблицы в контроллер представления или желтую кнопку в верхней части контроллера представления, как показано на снимке экрана ниже.

Когда мы отпустим курсор, мы увидим там две опции, dataSource и delegate, выберите их один за другим (когда вы выберете любую опцию, всплывающее окно скроется, вам нужно будет повторить вышеуказанный шаг, чтобы добавить второй вариант) . Теперь это должно выглядеть так -

Это все, что мы будем делать с нашим UI / Main.Storyboard прямо сейчас. Теперь переключитесь на файл «ViewController.swift». ДобавитьUITableViewDelegate, UITableViewDataSourceв ваш viewController.swift, как показано ниже -

Однако теперь Xcode покажет ошибку в этой строке.

Это потому, что есть несколько методов, в которых нам нужно использовать UITableView

Чтобы увидеть эти методы, нажмите Command + щелкните UITableViewDataSouce и скопируйте первые два метода с аргументами «numberOfRowsInSection», «cellForRowAtIndex» и вставьте их в ViewController.swift перед нашим viewDidLoad ().

Удалить эту строку @available(iOS 2.0, *), из обоих методов и добавьте открывающую и закрывающую фигурные скобки «{}». Теперь вид будет выглядеть следующим образом -

Xcode должен показывать ошибку в обеих функциях. Однако не беспокойтесь, потому что мы не добавили возвращаемый тип этих функций.

numberOfRowsInSection- Эта функция определяет количество строк, которые будет содержать наш раздел. Так что прямо сейчас добавьте эту строку в свой метод.

return 1 //This will return only one row.

cellForRowAt - Этот метод возвращает содержимое для каждой ячейки, indexPathсодержит индекс каждой ячейки. Мы создадим ячейку, затем присвоим этой ячейке какое-то значение и, наконец, вернем ячейку.

Теперь ваши функции должны выглядеть следующим образом -

internal func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 
   return 1; 
} 
internal func tableView(_ tableView: UITableView, 
   cellForRowAt indexPath: IndexPath) -> UITableViewCell { 
   let cell = UITableViewCell(style: 
   UITableViewCellStyle.default, reuseIdentifier: "Cell") 
   cell.textLabel?.text = "First Row" 
   return cell 
}

В первой строке мы создаем ячейку со стилем по умолчанию и reuseIdentifier это имя изготовленного нами прототипа ячейки.

Cell.textLable?.text - Это определяет текст, который должен отображаться как заголовок этой ячейки.

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

Приложение расписания

В этом приложении мы продолжим наш последний проект, и мы создадим приложение, в котором мы распечатаем таблицу 2 (2… 10…. 20).

Итак, чтобы создать это приложение, просто измените файл контроллера представления проекта.

Измените функции, как показано ниже -

internal func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 
   return 10; 
} 
internal func tableView(_ tableView: UITableView, 
   cellForRowAt indexPath: IndexPath) -> UITableViewCell { 
   let cell = UITableViewCell(style: UITableViewCellStyle.default, reuseIdentifier: "Cell") 
}

Теперь запустите ваше приложение. Это должно выглядеть так, как показано ниже.

Теперь, когда мы завершили просмотр таблиц и создали приложение, нам предстоит быстро решить эту задачу.

Вызов

Создайте приложение, в котором мы распечатаем счетную таблицу любого числа, введенного пользователем.

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

tableView.reloadData()

Это вызов для вас, поскольку мы рассмотрели все темы, связанные с этим приложением, поэтому мы не будем предлагать решение для этого.

Приложение таймера для яиц

В этом приложении мы будем использовать концепцию Timer() и Class Constructor, который управляет временем. Мы предоставим вам концепцию и кодировку. Пользовательский интерфейс необходимо создать самостоятельно, поскольку мы уже много раз обсуждали каждый элемент пользовательского интерфейса в наших предыдущих главах. (Хотя мы дадим подсказки для всего, что выглядит довольно новым).

Ваш окончательный макет приложения должен выглядеть так -

Что происходит в этом приложении?

  • Метка заголовка имеет начальное значение 210.

  • При нажатии кнопки воспроизведения значение должно уменьшаться на единицу каждую секунду.

  • При нажатии паузы значение должно останавливаться только на этом.

  • При выборе -10 значение должно быть уменьшено на 10, и уменьшение должно продолжаться.

  • При нажатии +10 значение должно быть увеличено на 10, а уменьшение должно продолжаться.

  • При нажатии кнопки «Сброс» значение должно стать 210.

  • Значение никогда не должно опускаться ниже 0.

Концепция

  • Мы будем использовать переменную класса Timer () → var timer = Timer ().

  • Мы установим значение для этой только что созданной переменной таймера.

    • timer = Timer.scheduledTimer (timeInterval: 1, target: self, селектор: #selector (ViewController.processTimer), userInfo: nil, повторяет: true)

    • timeInterval -> - временной интервал, который мы хотим использовать,

    • target -> - это контроллер представления, который должен выполняться,

    • селектор -> - это имя функции, которая будет использовать этот таймер,

    • userInfo -> null и повторяется, да, мы хотим повторить, так что это будет правдой.

Недействительный таймер

Чтобы остановить таймер посредством программирования, мы добавим timer.invalidate() функция.

Elements we have used -

Navigation bar - На панели навигации мы добавили три элемента.

  • Элемент кнопки панели, один слева и один справа.
  • Название - «Наш таймер для яиц».

Toolbar - Панель инструментов появляется в нижней части экрана приложения и содержит кнопки для выполнения действий, относящихся к текущему представлению или содержимому в нем.

Панели инструментов полупрозрачны и могут иметь фоновый оттенок. Они часто прячутся, когда они вряд ли понадобятся людям.

Мы добавили панель инструментов в нижней части нашего пользовательского интерфейса, в которой есть 5 элементов.

  • Три кнопки на панели с названиями -10, Reset и +10.
  • Два гибких пространства: гибкое пространство между элементами кнопок панели -

Как добавить иконку к кнопке панели?

Выберите элемент кнопки панели. Щелкните элемент кнопки на панели, перейдите в инспектор атрибутов, нажмите «Выбрать элемент» и выберите элемент в появившемся раскрывающемся списке.

Точно так же выберите элементы для всех других кнопок и создайте пользовательский интерфейс, как указано выше. Добавьте метку в центр представления и подключите ее как выход, назовите ее как -timeLeftLabel.

Действие для таймера запуска

Ниже приводится программа для таймера запуска.

@IBAction func startTimerButton(_ sender: Any) { 
   if !timerActive { 
      timerActive = true 
      eggTimer = Timer.scheduledTimer(timeInterval: 1, target: self, selector: 
      #selector(ViewController.processTimer), userInfo: nil, repeats: true) 
   } 
}

Создайте следующую функцию -

func stopTimer() { 
   timerActive = false 
   eggTimer.invalidate() 
}

Действие для функции остановки

Ниже приводится программа для функции остановки.

@IBAction func pauseTimerButton(_ sender: Any) { 
   stopTimer() 
}

Действие для вычитания времени

Ниже приводится программа для вычитания времени.

@IBAction func subtractTime(_ sender: Any) { 
   if timeLeft > 10 { 
      timeLeft = timeLeft - 10 
      timeLeftLabel.text = String(timeLeft) 
   } 
}

Действие для сброса времени

Ниже приводится программа для сброса времени.

@IBAction func resetTimer(_ sender: Any) { 
   timeLeft = 210 
   timeLeftLabel.text = String(timeLeft) 
}

Действие для addTime

Ниже приводится программа для добавления времени.

@IBAction func addTime(_ sender: Any) { 
   timeLeft = timeLeft + 10 
   timeLeftLabel.text = String(timeLeft) 
}

Теперь viewController.swift должен выглядеть так:

import UIKit 
class ViewController: UIViewController { 
   @IBOutlet weak var timeLeftLabel: UILabel! 
   var eggTimer = Timer()  // Initialize the Timer class. 
   var timerActive = false // Prevents multiple timers from firing. 
   var timeLeft = 210  
   func stopTimer() { 
      timerActive = false 
      eggTimer.invalidate() 
   } 
     
   func processTimer() { 
      if timeLeft <= 0 { 
         stopTimer() 
         return 
      }     
      timeLeft = timeLeft - 1; 
      timeLeftLabel.text = String(timeLeft) 
   } 
    
   @IBAction func startTimerButton(_ sender: Any) { 
      if !timerActive {
         timerActive = true 
         eggTimer = Timer.scheduledTimer(timeInterval: 1, target: self, selector: 
         #selector(ViewController.processTimer), userInfo: nil, repeats: true) 
      } 
   } 
     
   @IBAction func pauseTimerButton(_ sender: Any) { 
      stopTimer() 
   } 
    
   @IBAction func subtractTime(_ sender: Any) { 
      if timeLeft > 10 { 
         timeLeft = timeLeft - 10 
         timeLeftLabel.text = String(timeLeft) 
      } 
   } 
     
   @IBAction func resetTimer(_ sender: Any) { 
      timeLeft = 210 
      timeLeftLabel.text = String(timeLeft) 
   } 
     
   @IBAction func addTime(_ sender: Any) { 
      timeLeft = timeLeft + 10 
      timeLeftLabel.text = String(timeLeft) 
   } 
     
   override func viewDidLoad() { 
      super.viewDidLoad() 
      // Do any additional setup after loading the view, typically from a nib. 
   }  
   override func didReceiveMemoryWarning() { 
      super.didReceiveMemoryWarning() 
      // Dispose of any resources that can be recreated
   } 
}

Это все, что мы будем делать в нашем приложении, попробуйте запустить приложение, оно должно работать нормально.

Хранение данных в локальном хранилище

Хранение данных в локальном хранилище означает использование хранилища локального устройства для хранения данных, связанных с приложением на устройстве. У нас есть два способа хранить данные в локальном хранилище, а именноNSUserDefault и CoreData.

Давайте разберемся с ними подробнее.

NSUserDefaults

NSUserDefaults предназначены для хранения небольших фрагментов данных, таких как предпочтения, настройки или отдельные значения. Чтобы использовать UserDefaults в нашем приложении, нам просто нужно создать ссылку на nsuserDefaults через наш код, как показано ниже.

let defaultValues = NSUserDefaults.standardUserDefaults()

Чтобы установить значения для данных в UserDefaults, мы можем использовать следующий код -

defaultValues.setObject("Simplified iOS", forKey: "nameKey")  
func setDouble(value: Double, forKey defaultName: String) 
func setBool(value: Bool, forKey defaultName: String) 
func setObject(value: AnyObject?, forKey defaultName: String) 
func setURL(url: NSURL?, forKey defaultName: String) 
func setInteger(value: Int, forKey defaultName: String) 
func setFloat(value: Float, forKey defaultName: String)

Чтобы получить значения из NSUserDefaults, мы можем использовать следующий код.

func boolForKey(defaultName: String) -> Bool 
func integerForKey(defaultName: String) -> Int 
func floatForKey(defaultName: String) -> Float 
func doubleForKey(defaultName: String) -> Double 
func objectForKey(defaultName: String) -> AnyObject? 
func URLForKey(defaultName: String) -> NSURL?

CoreData

CoreData - это постоянная платформа, которая поддерживает транзакции с большими данными. CoreData позволяет создавать реляционную модель сущность – атрибут для хранения пользовательских данных. CoreData - это платформа, которая может использовать двоичные форматы SQLite для хранения данных.

Чтобы использовать CoreData в нашем приложении, мы начнем с нового проекта и убедитесь, что вы отметили «Использовать основные данные» при создании проекта.

Login Using core Data - Создайте новый проект, выберите использовать CoreData, как показано на следующем снимке экрана.

Продолжайте, пока проект не откроется, теперь мы видим, что в проекте больше файлов, чем в наших предыдущих проектах.

Этот файл CoreData_demo.xcdatamodeld это наша база данных, в которой мы будем создавать нашу пользовательскую таблицу и хранить данные.

Concept - Суть CoreData в том, что даже если мы закроем приложение и откроем его через несколько месяцев, в нем все равно будут храниться данные, которые мы храним, что мы увидим в следующем приложении, которое мы создадим.

Теперь мы увидим, как добавить основные данные и получить основные данные.

Adding Core Data- Чтобы добавить CoreData, щелкните файл CoreData_demo.xcdatamodeld, и тогда мы увидим, что объекты пусты. Нажмите кнопку «Добавить сущность», она добавит сущность, теперь дважды щелкните имя сущности и переименуйте ее как угодно.

Теперь щелкните объект, и мы увидим, что поле атрибутов пусто. Щелкните значок плюса и переименуйте объект. В следующем поле выберите тип объекта.

Мы добавили в него объект и один атрибут. Теперь, если мы перейдем кAppDelegate.swift, мы видим, что были добавлены две новые функции, потому что мы выбрали CoreData. Две добавленные функции:

Note - Импортируйте CoreData в свой файл, прежде чем продолжить.

Saving data to Core Data - Чтобы сохранить данные в CoreData, нам нужно сделать объект класса AppDelegate.

let appDelegate = UIApplication.shared.delegate as! AppDelegate

И объект контекста

let context = appDelegate.persistentContainer.viewContext

Затем нам нужно создать объект сущности, который будет вызывать нашу сущность -

let newValue = NSEntityDescription.insertNewObject(forEntityName: "Users", into: context)

Теперь мы установим значение этого атрибута, который мы создали.

newValue.setValue(textField.text, forKey: "name")

Мы сохраним данные, используя

context.save();

Fetching from core data- При извлечении два вышеуказанных шага (создание appDelegate и context) будут одинаковыми. Затем мы создадим запрос на выборку.

let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Users")

Мы создадим объект для хранения результата.

let results = try context.fetch(request)

Затем мы рассмотрим результаты в соответствии с нашим требованием. Мы увидим больше CoreData в следующем приложении, которое мы создадим.

Challenge- Попробуйте создать приложение, в котором пользователь вводит имя, затем нажимает на логин и закрывает приложение. Когда в следующий раз пользователь откроет приложение, он все еще должен быть авторизован. Затем добавьте кнопку - выход, и если он нажмет на нее, приложение снова запросит имя пользователя.

Вход / выход с помощью CoreData

Создайте проект с одним представлением под названием «Вход», выберите использование CoreData. Щелкните CoreData_demo.xcdatamodeld и добавьте объект под названием «Пользователи». Внутри добавьте атрибут под названием «имя».

Перейдите на main.storyboard, добавьте текстовое поле и кнопку входа. Ниже добавьте метку, дважды щелкните по ней и удалите ее содержимое. Затем добавьте кнопку выхода из системы, перейдите в ее инспектор атрибутов и сделайте «альфа» равным 0. Теперь наше представление должно выглядеть следующим образом:

Теперь перейдите в файл контроллера представления, откройте редактор помощника и создайте связи между элементами пользовательского интерфейса и файлом контроллера.

Note- Мы также создадим выходы для обеих кнопок, потому что нам нужно изменить внешний вид этих кнопок. Например - когда пользователь вошел в систему, мы скроем кнопку входа в систему, если пользователь не вошел в систему, мы покажем вход и скроем кнопку выхода.

Поскольку мы уже обсуждали добавление и выборку данных из CoreData, мы разместим здесь код.

Try-Catch- Вы заметите, что мы много раз использовали блок try-catch в коде. Это потому, что, если мы не используем блоки try-catch и в нашей программе есть какое-то исключение или ошибка, выполнение остановится. Принимая во внимание, что если мы используем блоки try catch и если возникает какая-то ошибка, то блок catch обрабатывает ошибку. Узнайте больше об этом в нашем руководстве по Swift.

Код для входа / выхода из приложения

Давайте разберемся с различными компонентами и кодом, который используется для приложения входа / выхода.

Login Button Action - Следующий код объясняет, как добавить действие кнопки входа в систему.

var isLoggedIn = false 
@IBAction func logIn(_ sender: AnyObject) { 
   let appDelegate = UIApplication.shared.delegate as! AppDelegate
   let context = appDelegate.persistentContainer.viewContext 
   if isLoggedIn { 
      let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Users") 
      do { 
         let results = try context.fetch(request) 
         if results.count > 0 { 
            for result in results as! [NSManagedObject] { 
               result.setValue(textField.text, forKey: "name") 
               do { 
                  try context.save() 
               } 
               catch { 
                  print("Update username failed") 
               } 
            } 
            label.text = "Hi " + textField.text! + "!" 
         } 
      } 
      catch { 
         print("Update failed") 
      } 
   } else { 
      let newValue = NSEntityDescription.insertNewObject(forEntityName: "Users", into: context) 
      newValue.setValue(textField.text, forKey: "name") 
      do { 
         try context.save() 
         logInButton.setTitle("Update username", for: []) 
         label.alpha = 1 
         label.text = "Hi " + textField.text! + "!" 
         isLoggedIn = true 
         logOutButton.alpha = 1 
      }  
      catch { 
         print("Failed to save") 
      }     
   } 
}

Logout Button Action - Следующий код объясняет, как добавить действие кнопки выхода.

@IBAction func logOut(_ sender: AnyObject) { 
   let appDelegate = UIApplication.shared.delegate as! AppDelegate 
   let context = appDelegate.persistentContainer.viewContext 
   let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Users") 
   do { 
      let results = try context.fetch(request) 
      if results.count > 0 { 
         for result in results as! [NSManagedObject] { 
            context.delete(result) 
            do { 
               try context.save() 
            } catch { 
               print("Individual delete failed") 
            } 
         } 
         label.alpha = 0 
         logOutButton.alpha = 0 
         logInButton.setTitle("Login", for: []) 
         isLoggedIn = false 
         textField.alpha = 1 
      } 
   } catch { 
      print("Delete failed") 
   } 
}

ViewDidLoad() - Следующий код объясняет, как использовать функцию ViewDidLoad ().

override func viewDidLoad() { 
   super.viewDidLoad() 
   // Do any additional setup after loading the view, typically from a nib.
   let appDelegate = UIApplication.shared.delegate as! AppDelegate 
   let context = appDelegate.persistentContainer.viewContext 
   let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Users") 
   request.returnsObjectsAsFaults = false 
   do { 
      let results = try context.fetch(request) 
      for result in results as! [NSManagedObject] { 
         if let username = result.value(forKey: "name") as? String { 
            logInButton.setTitle("Update username", for: []) 
            logOutButton.alpha = 1 
            label.alpha = 1 
            label.text = "Hi there " + username + "!" 
         }     
      } 
             
   } catch { 
      print("Request failed") 
   } 
}

Помните, что вам нужно было создать розетку и действие для обеих кнопок.

Теперь сохраните и запустите приложение. Авторизуйтесь, закройте приложение и снова запустите. Это должно выглядеть следующим образом.

Это все, что мы будем делать с CoreData. Используя те же концепции, мы можем создать множество приложений CoreData.

Управление клавиатурой

В этом разделе мы научимся управлять поведением клавиатуры. Например - когда мы щелкаем за пределами текстового поля после ввода текста, клавиатура не закрывается. Здесь мы поймем, как управлять клавиатурой.

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

Это простая задача. Для этого просто вставьте следующий код в файл viewController перед закрытием фигурных скобок.

override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) { 
   self.view.endEditing(true)  
}

Таким образом, клавиатура исчезнет при нажатии вне поля ввода.

Клавиатура должна исчезнуть при нажатии клавиши возврата

Чтобы клавиатура исчезла, мы должны добавить новый тип для нашего контроллера представления. Мы также добавим текстовое поле и создадим его выход под названием textField. Наконец, мы добавимUITextFieldDelegate.

Мы также control + drag из нашего поля ввода в контроллер представления и выберите делегата из появившихся опций.

Затем мы добавим следующую функцию.

func textFieldShouldReturn(_ textField: UITextField) -> Bool { 
   textField.resignFirstResponder()  
   return true 
}

Окончательный файл View Controller должен выглядеть следующим образом -

import UIKit 
class ViewController: UIViewController, UITextFieldDelegate { 
   override func viewDidLoad() { 
      super.viewDidLoad() 
      // Do any additional setup after loading the view, typically from a nib. 
   }  
   override func didReceiveMemoryWarning() { 
      super.didReceiveMemoryWarning() 
      // Dispose of any resources that can be recreated. 
   } 
   override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) { 
      self.view.endEditing(true) 
   }
   func textFieldShouldReturn(_ textField: UITextField) -> Bool { 
      textField.resignFirstResponder() 
      return true 
   } 
}

Загрузка веб-контента - открытие Facebook / Google

В этом разделе мы узнаем, как создать приложение, которое будет открывать Facebook и Google при нажатии каждой кнопки соответственно. Мы также изучим концепцию веб-представлений и безопасности транспортного уровня приложения. После этого вы сможете создать собственный браузер.

Note - Нам необходимо подключение к Интернету в этом приложении.

Создание веб-приложения

Мы сделаем новое приложение с единым представлением, проект iOS. В строке поиска библиотеки объектов мы будем искать веб-представление, перетаскивать его и добавлять в наш контроллер представления в main.Storyboard.

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

Мы откроем наш main.storyboard и view controller, щелкнув помощник редактора. Мы создадим выход для нашего webView и действие для обеих кнопок. При загрузке приложение загрузит yahoo в webView. При нажатии на Google он должен загрузить Google, а при нажатии кнопки Facebook он должен загрузить страницу Facebook.

Окончательный вид должен выглядеть следующим образом -

На следующих снимках экрана показано, как должны выглядеть разные экраны нашего приложения. Если вы попытаетесь открыть веб-службу, отличную от https, она покажет ошибку, и нам придется добавить исключение безопасности транспортного уровня приложения в вашinfo.plist файл.