การพัฒนา iOS ด้วย Swift2 - iOS ขั้นสูง
ในบทนี้เราจะกล่าวถึงคุณลักษณะขั้นสูงบางอย่างเช่นการสร้างมุมมองหลาย ๆ มุมมองบนแอปพลิเคชันของเราการเพิ่มแถบนำทางการเพิ่มมุมมองตารางการจัดเก็บข้อมูลในแอปพลิเคชันการสร้างเว็บแอปพลิเคชันเป็นต้น
โปรดอ่านทุกส่วนอย่างละเอียดเนื่องจากบทนี้มีเนื้อหาส่วนใหญ่ที่เราต้องการในขณะพัฒนาแอปพลิเคชัน
คอนโทรลเลอร์หลายมุมมอง
ในแอปพลิเคชันก่อนหน้านี้เราให้ตัวควบคุมมุมมอง / มุมมองเดียวเท่านั้น อย่างไรก็ตามเราสามารถมีหลายมุมมองในแอปพลิเคชันของเราและเราสามารถดำเนินการกับมุมมองใดก็ได้โดยอิสระ
ดังนั้นเราจะเริ่มต้นด้วยการสร้างโครงการใหม่ ชื่อของโครงการนี้มีหลายมุมมอง เช่นเดียวกับโครงการอื่น ๆ โครงการนี้ยังมี View Controller และ Swift File สำหรับคอนโทรลเลอร์นั้น (สิ่งนี้คุณสามารถดูได้โดยเลือกมุมมองและดูคุณสมบัติในตัวตรวจสอบข้อมูลประจำตัว)
ภาพหน้าจอต่อไปนี้แสดงให้เห็นว่ามุมมองปัจจุบันของเราเป็นอย่างไร -
ทางด้านขวามือ (ตัวตรวจสอบข้อมูลประจำตัว) เราจะเห็นคลาสที่เกี่ยวข้องกับตัวควบคุมมุมมองของเรา ลูกศรนี้ทางด้านซ้ายคือจุดเข้า นี่คือมุมมองแรกของแอปพลิเคชันของเราที่จะแสดงหลังจากแอปพลิเคชันเริ่มทำงาน
การเพิ่มตัวควบคุมหลายมุมมองที่สอง
หากต้องการเพิ่มตัวควบคุมมุมมองอื่น ๆ ในแอปพลิเคชันของเราเราจะค้นหาตัวควบคุมมุมมองในไลบรารีวัตถุของเรา เมื่อเราพบแล้วเราจะลากตัวควบคุมมุมมองไปที่ main.stroryboard ของเรานอกมุมมองอื่น ๆ
นี่คือลักษณะของแอปพลิเคชันของคุณ ตอนนี้เราได้เพิ่มตัวควบคุมมุมมองแล้ว แต่ตอนนี้เราจะต้องสร้างคลาสตัวควบคุมมุมมองสำหรับมุมมองที่เพิ่มเข้ามาใหม่ของเราด้วย
Right click on your project → new File → cocoa Touch Class → ตั้งชื่ออะไรก็ได้ที่คุณต้องการเราจะตั้งชื่อว่า“ SecondViewController”
นี่คือวิธีที่คุณสร้างไฟล์คลาสสำหรับตัวควบคุมมุมมองของคุณ ตอนนี้กลับไปที่“ main.storyboard” ของคุณคลิกที่ตัวควบคุมมุมมองที่สองของคุณและดูตัวตรวจสอบข้อมูลประจำตัว
ช่องชั้นเรียนต้องว่างเปล่าในตอนนี้ดังนั้นให้คลิกที่ช่องนั้นและเริ่มพิมพ์ชื่อชั้นเรียนของคุณที่คุณเพิ่มในขั้นตอนสุดท้าย หากปรากฏขึ้นให้คลิก Enter
ตอนนี้เราได้สร้างคอนโทรลเลอร์หลายมุมมองและเพิ่มไฟล์คลาสคอนโทรลเลอร์สำหรับ View นั้น อย่างไรก็ตามหากคุณเรียกใช้แอปพลิเคชันแอปพลิเคชันจะไม่แสดงมุมมองที่สองของคุณ ทำไม?
เนื่องจากเราไม่ได้เพิ่มฟังก์ชันซึ่งจะนำเราไปสู่มุมมองนั้น กล่าวโดยย่อเรายังไม่ได้เพิ่มการนำทางไปยังแอปพลิเคชันของเรา ไม่ต้องกังวล; เราจะกล่าวถึงในส่วนต่อไปนี้
การเพิ่มการนำทางไปยังแอปพลิเคชัน
กระบวนการเปลี่ยนจากมุมมองหนึ่งไปสู่อีกมุมมองหนึ่งเรียกว่า Segueingกล่าวคือทำโดยการสร้างต่อเนื่องระหว่างสองมุมมอง ในการดำเนินการนี้ให้เพิ่มปุ่มในตัวควบคุมมุมมองแรกและควบคุมการลากจากปุ่มไปยังมุมมองที่สองของคุณ เมื่อคุณปล่อยปุ่มคุณจะเห็นตัวเลือกบางอย่างดังที่แสดงในภาพหน้าจอด้านล่าง
เลือกตัวเลือกแสดงจาก Action Segue ตอนนี้เรียกใช้แอปพลิเคชันของคุณคุณจะเห็นว่าเมื่อคลิกปุ่มมุมมองที่สองของคุณจะปรากฏขึ้น (หากต้องการดูให้ชัดเจนยิ่งขึ้นเพิ่มบางสิ่งในมุมมองที่สองของคุณเพื่อให้คุณสามารถระบุได้)
อย่างไรก็ตามตอนนี้คุณไม่สามารถกลับไปที่มุมมองแรกของคุณได้ สำหรับสิ่งนั้นเรามีNavigation controllers.
การเพิ่มตัวควบคุมการนำทาง
เลือกตัวควบคุมมุมมองแรกของคุณแล้วคลิกในแถบด้านบน Editor → Embed in → Navigation controller.
ตอนนี้แอปพลิเคชันของเราควรมีลักษณะเหมือนภาพหน้าจอต่อไปนี้
เราจะเห็นว่ามีแถวสีเทาอ่อนอยู่ด้านบนของมุมมอง ตอนนี้เมื่อเราเรียกใช้แอปพลิเคชันเราจะเห็นว่ามีแถบนำทางอยู่ด้านบนของมุมมอง เมื่อเราคลิกที่ปุ่มเราจะไปที่มุมมองที่สองซึ่งเราจะเห็นปุ่มย้อนกลับในแถบนำทางนั้น คลิกที่นี่และเราจะกลับมาที่มุมมองเริ่มต้น
การเพิ่มชื่อเรื่องและปุ่มย้อนกลับไปที่แถบนำทาง
หากต้องการเพิ่มชื่อในแถบนำทางของคุณให้คลิกที่แถบนำทางและดูตัวตรวจสอบคุณสมบัติ เราจะเห็น -
Title - นี่จะเป็นชื่อของแถบการนำทางซึ่งปรากฏอยู่ตรงกลาง
Prompt - สิ่งนี้ปรากฏที่ด้านบนของแถบหัวเรื่องตรงกลาง
Back Button - คุณสามารถแก้ไขข้อความที่ปรากฏในปุ่มย้อนกลับได้ที่นี่
ขณะนี้ปุ่มที่กำลังส่งผ่านมุมมองนั้นอยู่ในมุมมองของเราซึ่งอาจไม่เหมาะหากเราต้องการให้สิ่งอื่นปรากฏบนหน้าจอ ดังนั้นเราจะเพิ่มรายการ Bar Button ในแถบนำทางซึ่งจะนำเราไปสู่มุมมองที่สองของเรา อย่างไรก็ตามสำหรับสิ่งนี้เราควรลบปุ่มสุดท้ายที่เราเพิ่มก่อน
การเพิ่มรายการปุ่มแถบ
ค้นหารายการปุ่มแถบในไลบรารีออบเจ็กต์แล้วลากไปวางทางด้านขวามือของแถบนำทาง ตั้งชื่อเป็น -“ ถัดไป>” ควบคุมการลากจากไปยังมุมมองที่สองเลือกแสดงเหมือนที่เราทำกับปุ่มสุดท้ายที่เราเพิ่ม
ตอนนี้เรียกใช้แอปพลิเคชันมันจะดูสะอาดและดีขึ้น นี่คือทั้งหมดที่เราจะทำกับการนำทางในตอนนี้ ในบทต่อ ๆ ไปเราจะปรับเปลี่ยนแถบนำทางโดยใช้ Swift Code เมื่อจำเป็น
มุมมองตาราง
ตารางแสดงข้อมูลเป็นรายการคอลัมน์เดียวที่มีหลายแถวซึ่งสามารถแบ่งออกเป็นส่วนต่างๆได้อีก ควรใช้ตารางเพื่อนำเสนอข้อมูลอย่างสะอาดและมีประสิทธิภาพ
ในส่วนนี้เราจะเข้าใจวิธีการเพิ่มมุมมองตารางการเพิ่มเซลล์ต้นแบบการเพิ่มแหล่งข้อมูลและผู้รับมอบสิทธิ์สำหรับมุมมองตารางการเปลี่ยนคุณสมบัติของตารางและการตั้งค่าข้อมูลแบบไดนามิกสำหรับเซลล์มุมมองตาราง
การเพิ่มมุมมองตาราง
ในการเพิ่มมุมมองตารางก่อนอื่นเราจะสร้างโครงการใหม่และตั้งชื่อเป็น -“ tableView” จากนั้นไปที่ไลบรารีวัตถุและค้นหา Table View เราจะเห็นมุมมองตารางตัวควบคุมมุมมองตารางและตัวเลือกอื่น ๆ อีกมากมาย อย่างไรก็ตามเราควรเลือกมุมมองตารางลากและเพิ่มไปยังตัวควบคุมมุมมองเริ่มต้น
การเพิ่มเซลล์ต้นแบบ
ยืดมุมมองตารางเพื่อให้ครอบคลุมมุมมองทั้งหมดในขณะที่มุมมองตารางของคุณถูกเน้น ตรวจสอบตัวตรวจสอบแอตทริบิวต์มีฟิลด์ที่เรียกว่าเซลล์ต้นแบบซึ่งปัจจุบันเป็น 0 เราควรเปลี่ยนค่าเป็น 1 ตอนนี้มุมมองของคุณควรมีลักษณะดังนี้ -
การเปลี่ยนตัวระบุเซลล์
ตอนนี้ในมุมมองของคุณให้คลิกที่เซลล์ต้นแบบของคุณ (ซึ่งค่อนข้างยุ่งยากเล็กน้อย) ดังนั้นในโครงร่างเอกสารของคุณให้คลิกที่ View controller → View → Table View → Table View Cell และตอนนี้ในตัวตรวจสอบแอตทริบิวต์มีคอลัมน์ที่เรียกว่า Identifier ให้คลิกที่และตั้งชื่อเป็น "Cell" ดูภาพหน้าจอต่อไปนี้เพื่อทำความเข้าใจขั้นตอนข้างต้น
การเพิ่มผู้รับมอบสิทธิ์และแหล่งข้อมูล
ในการทำให้มุมมองตารางเป็นแบบไดนามิกเราจำเป็นต้องให้พวกเขาโหลดข้อมูลแบบไดนามิก ดังนั้นเราจึงจำเป็นต้องมีผู้รับมอบสิทธิ์และแหล่งข้อมูลสำหรับสิ่งนั้น ในการสร้างตัวแทนและแหล่งข้อมูลของตารางของคุณให้ควบคุมการลากจากมุมมองตารางไปยังตัวควบคุมมุมมองของคุณหรือปุ่มสีเหลืองที่ด้านบนของตัวควบคุมมุมมองดังที่แสดงในภาพหน้าจอด้านล่าง
เมื่อเราปล่อยเคอร์เซอร์เราจะเห็นสองตัวเลือกที่นั่น 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ซึ่งจัดการเวลา เราจะให้แนวคิดและการเข้ารหัสแก่คุณ คุณต้องสร้าง UI ด้วยตัวเองตามที่เราได้พูดคุยไปแล้วทุกองค์ประกอบ UI หลายครั้งในบทก่อนหน้าของเรา (แม้ว่าเราจะให้คำแนะนำสำหรับทุกสิ่งที่ดูค่อนข้างใหม่)
เค้าโครงแอปสุดท้ายของคุณควรมีลักษณะดังนี้ -
เกิดอะไรขึ้นในแอปพลิเคชันนี้
ป้ายชื่อมีค่าเริ่มต้น 210
เมื่อคลิกปุ่มเล่นค่าควรลดลงทีละวินาทีทุกวินาที
เมื่อคลิกหยุดชั่วคราวค่าควรหยุดเพียงแค่นั้น
เมื่อคลิกที่ -10 ค่าควรจะลดลง 10 และการลดควรดำเนินต่อไป
เมื่อคลิกที่ +10 ค่าควรเพิ่มขึ้น 10 และการลดควรดำเนินต่อไป
เมื่อคลิกรีเซ็ตค่าควรเป็น 210
ค่าไม่ควรต่ำกว่า 0
แนวคิด
เราจะใช้ตัวแปรของ class Timer () → var timer = Timer ()
เราจะกำหนดค่าให้กับตัวแปรตัวจับเวลาที่เราเพิ่งสร้างขึ้น
timer = Timer.scheduledTimer (timeInterval: 1, target: self, selector: #selector (ViewController.processTimer), userInfo: nil, repeat: true)
timeInterval -> คือช่วงเวลาที่เราต้องการใช้
เป้าหมาย -> เป็นตัวควบคุมมุมมองที่ควรได้รับผล
ตัวเลือก -> คือชื่อฟังก์ชันที่จะใช้ตัวจับเวลานี้
userInfo -> null และทำซ้ำใช่เราต้องการทำซ้ำดังนั้นมันจะเป็นจริง
ตัวจับเวลาไม่ถูกต้อง
ในการหยุดตัวจับเวลาผ่านการเขียนโปรแกรมเราจะเพิ่ม timer.invalidate() ฟังก์ชัน
Elements we have used -
Navigation bar - ในแถบนำทางเราได้เพิ่มสามรายการ
- รายการปุ่มแถบหนึ่งรายการทางซ้ายและอีกรายการทางขวา
- ชื่อเรื่องว่า -“ เครื่องจับเวลาไข่ของเรา”
Toolbar - แถบเครื่องมือจะปรากฏที่ด้านล่างของหน้าจอแอพและมีปุ่มสำหรับดำเนินการที่เกี่ยวข้องกับมุมมองปัจจุบันหรือเนื้อหาที่อยู่ภายใน
แถบเครื่องมือโปร่งแสงและอาจมีสีพื้นหลัง พวกเขามักจะซ่อนตัวเมื่อไม่มีคนต้องการ
เราได้เพิ่มแถบเครื่องมือที่ด้านล่างของ UI ซึ่งมี 5 รายการ
- รายการปุ่ม Three Bar ชื่อ -10 รีเซ็ตและ +10
- สองพื้นที่ที่ยืดหยุ่น: ช่องว่างที่ยืดหยุ่นระหว่างรายการปุ่มแถบ -
จะเพิ่มไอคอนลงในรายการปุ่มแถบได้อย่างไร?
เลือกรายการปุ่มแถบของคุณ คลิกที่รายการปุ่มแถบของคุณไปที่ตัวตรวจสอบคุณสมบัติคลิกที่เลือกรายการและเลือกรายการจากรายการแบบหล่นลงที่ปรากฏขึ้น
ในทำนองเดียวกันเลือกรายการสำหรับปุ่มอื่น ๆ ทั้งหมดและสร้าง UI ตามที่ระบุไว้ด้านบน เพิ่มป้ายกำกับตรงกลางมุมมองและเชื่อมต่อเป็นเต้าเสียบตั้งชื่อว่า -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 Class
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 และบริบท) จะเหมือนกัน จากนั้นเราจะสร้างคำขอดึงข้อมูล
let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Users")
เราจะสร้างวัตถุเพื่อเก็บผลลัพธ์
let results = try context.fetch(request)
จากนั้นเราจะดำเนินการตามผลลัพธ์ตามความต้องการของเรา เราจะเห็น CoreData มากขึ้นด้วยแอปพลิเคชันถัดไปที่เราสร้างขึ้น
Challenge- พยายามสร้างแอปพลิเคชันโดยผู้ใช้ป้อนชื่อจากนั้นคลิกที่ล็อกอินและปิดแอปพลิเคชัน เมื่อผู้ใช้เปิดแอปพลิเคชันในครั้งต่อไปเขาควรจะยังคงเข้าสู่ระบบอยู่จากนั้นเพิ่มปุ่ม - ออกจากระบบและหากเขาคลิกที่แอปพลิเคชันจะถามชื่อผู้ใช้อีกครั้ง
เข้าสู่ระบบ / ออกจากระบบโดยใช้ CoreData
สร้างโครงการมุมมองเดียวที่เรียกว่า 'เข้าสู่ระบบ' เลือกใช้ CoreData คลิกที่ CoreData_demo.xcdatamodeld และเพิ่มเอนทิตีที่เรียกว่า 'Users' ภายในนั้นให้เพิ่มแอตทริบิวต์ที่เรียกว่า "name"
ไปที่ main.storyboard เพิ่มช่องข้อความและปุ่มล็อกอิน ด้านล่างเพิ่มป้ายกำกับดับเบิลคลิกที่ป้ายแล้วลบเนื้อหา จากนั้นเพิ่มปุ่มออกจากระบบไปที่ตัวตรวจสอบแอตทริบิวต์และทำให้ 'alpha' เท่ากับ 0 ตอนนี้มุมมองของเราควรมีลักษณะดังนี้ -
ตอนนี้ไปที่ไฟล์ตัวควบคุมมุมมองของคุณเปิดตัวแก้ไขผู้ช่วยและสร้างการเชื่อมต่อระหว่างองค์ประกอบ UI และไฟล์คอนโทรลเลอร์ของคุณ
Note- เราจะสร้างช่องสำหรับปุ่มทั้งสองด้วยเนื่องจากเราจำเป็นต้องปรับเปลี่ยนรูปลักษณ์ของปุ่มเหล่านั้น ตัวอย่างเช่น - เมื่อผู้ใช้เข้าสู่ระบบเราจะซ่อนปุ่มเข้าสู่ระบบหากผู้ใช้ไม่ได้เข้าสู่ระบบเราจะแสดงการเข้าสู่ระบบและซ่อนปุ่มออกจากระบบ
ดังที่เราได้กล่าวไปแล้วเกี่ยวกับการเพิ่มและดึงข้อมูลจาก CoreData เราจะใส่รหัสที่นี่
Try-Catch- คุณจะสังเกตเห็นว่าเราใช้ try-catch block หลายครั้งในโค้ด เป็นเพราะถ้าเราไม่ใช้บล็อคลองจับและมีข้อยกเว้นหรือข้อผิดพลาดในโปรแกรมของเราการดำเนินการจะหยุดลง ในขณะที่หากเราใช้บล็อก 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)
}
การทำเช่นนี้จะทำให้แป้นพิมพ์หายไปเมื่อคลิกนอกช่องป้อนข้อมูล
แป้นพิมพ์ควรหายไปเมื่อแตะปุ่มย้อนกลับ
เพื่อให้แป้นพิมพ์หายไปเราควรเพิ่ม Type ใหม่สำหรับ View Controller ของเรา นอกจากนี้เรายังจะเพิ่มช่องข้อความและสร้างร้านที่เรียกว่า 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 เมื่อแต่ละปุ่มถูกกดตามลำดับ นอกจากนี้เรายังจะได้เรียนรู้แนวคิดของ Web Views และ App transport Layer Security หลังจากนี้คุณจะสามารถสร้างเบราว์เซอร์ของคุณเองได้
Note - เราต้องการการเชื่อมต่ออินเทอร์เน็ตในแอปพลิเคชันนี้
การทำ Web Application
เราจะสร้างแอปพลิเคชันมุมมองเดียวใหม่โครงการ iOS ในแถบค้นหาของไลบรารีออบเจ็กต์เราจะค้นหามุมมองเว็บลากและเพิ่มไปยังตัวควบคุมมุมมองของเราในหน้าหลักสตอรี่บอร์ด
หลังจากเพิ่มมุมมองเว็บแล้วเราจะขยายไปจนสุดมุม UI ของแอปพลิเคชันควรมีลักษณะดังนี้ -
เราจะเปิด main.storyboard และดูคอนโทรลเลอร์โดยคลิกที่ตัวแก้ไขผู้ช่วย เราจะสร้างทางออกสำหรับ webView และการดำเนินการสำหรับทั้งสองปุ่ม เมื่อโหลดแอปพลิเคชันจะโหลด yahoo ใน webView ในการคลิก google ควรโหลด Google และเมื่อคลิกปุ่ม Facebook ก็ควรโหลดหน้า Facebook
มุมมองสุดท้ายควรมีลักษณะดังนี้ -
ภาพหน้าจอต่อไปนี้แสดงให้เห็นว่าหน้าจอต่างๆของแอปพลิเคชันของเราควรมีลักษณะอย่างไร หากคุณพยายามเปิดบริการเว็บที่ไม่ใช่ https บริการจะแสดงข้อผิดพลาดและเราจะต้องเพิ่มข้อยกเว้นของ App Transport Layer Security ในของคุณinfo.plist ไฟล์.