- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何从用户界面警报文本字段中保存多个数据,我已经可以使用这行代码将一个数据保存到数据库中。正如您所注意到的,只有一个文本字段,我添加了 2 个文本字段来保存地址、日期等其他数据,但当我保存数据时,仅保存了名称。代码部分是 Add New Chore 。保存它的函数位于 func saveItemInLocalDB(groceryItem : Item) 上,您可以在下面找到它。
let alert = UIAlertController(title: "Add New Chore", message: "", preferredStyle:
UIAlertControllerStyle.alert)
alert.addTextField(configurationHandler: textFieldHandler)
导入UIKit 导入核心数据
class GroceryViewController: UIViewController, UICollectionViewDelegate, UICollectionViewDataSource, UISearchBarDelegate, NSFetchedResultsControllerDelegate, GroceryItemCollectionViewCellDelegate {
@IBOutlet var collectionView: UICollectionView!
@IBOutlet weak var seeTask: UIButton!
@IBOutlet weak var see: UIButton!
@IBOutlet var searchBar: UISearchBar!
let unselectedCellColor : UIColor = UIColor(red: 60/255, green: 78/255, blue: 127/255, alpha: 1.0)
let selectedCellColor : UIColor = UIColor(red: 93/255, green: 173/255, blue: 195/255, alpha: 1.0)
var searchBarActive : Bool?
var textToSearch : String?
var loggedInUserHouseNumber : String?
var loggedInUsername : String?
open var context: NSManagedObjectContext!
var fetchedResultsController: NSFetchedResultsController<GroceryItem>!
let datePicker = UIDatePicker()
let reuseIdentifier = "Cell"
@IBAction func checkListButtonIsPressed(_ sender: Any) {
let storyBoard : UIStoryboard = UIStoryboard(name: "Main", bundle:nil)
let cartVC = storyBoard.instantiateViewController(withIdentifier: "GroceryCheckListViewController") as! GroceryCheckListViewController
self.navigationController?.pushViewController(cartVC, animated: true)
}
override func viewDidLoad() {
super.viewDidLoad()
loggedInUserHouseNumber = (UserDefaults.standard.value(forKey: "loggedInUserHouseNumber") as! String)
loggedInUsername = (UserDefaults.standard.value(forKey: "loggedInUsername") as! String)
// likeLabel.transform = CGAffineTransform(rotationAngle: CGFloat(M_PI_2 * 3))
var a = loggedInUsername
if ((a?.lowercased().range(of: "mother")) != nil) {
seeTask.setTitle("Completed Tasks", for: .normal)
print("true")
} else {
print("false")
seeTask.setTitle("View Details",for: .normal)
// self.collectionView.isd = true
}
searchBarActive = false
textToSearch = nil
self.navigationItem.title = "Chore List"
self.navigationController?.navigationBar.isHidden = false
self.searchBar.delegate = self
self.setUpCollectionView()
// Do any additional setup after loading the view.
}
func createDatePicker() {
}
func setUpCollectionView() {
configureFetchedResultsController()
do {
try fetchedResultsController.performFetch()
} catch {
print("An error occurred")
}
self.collectionView.reloadData()
}
func configureFetchedResultsController() {
self.fetchedResultsController = nil
let itemsFetchRequest = NSFetchRequest<GroceryItem>(entityName: "GroceryItem")
let primarySortDescriptor = NSSortDescriptor(key: "name", ascending: true)
// let secondarySortDescriptor = NSSortDescriptor(key: "commonName", ascending: true)
if (textToSearch != nil) {
itemsFetchRequest.predicate = NSPredicate(format: "name contains[c] %@ AND houseNo == %@",textToSearch!, loggedInUserHouseNumber!)
} else {
itemsFetchRequest.predicate = NSPredicate(format: "houseNo == %@",loggedInUserHouseNumber!)
}
itemsFetchRequest.sortDescriptors = [primarySortDescriptor]
self.context = getContext()
self.fetchedResultsController = NSFetchedResultsController<GroceryItem>(
fetchRequest: itemsFetchRequest,
managedObjectContext: getContext(),
sectionNameKeyPath: nil,
cacheName: nil)
self.fetchedResultsController.delegate = self
}
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
if self.searchBarActive! {
if let sections = fetchedResultsController.sections {
let currentSection = sections[section]
return currentSection.numberOfObjects
}
return 0
} else {
if let sections = fetchedResultsController.sections {
let currentSection = sections[section]
return (currentSection.numberOfObjects + 1)
}
return 0
}
}
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
if self.searchBarActive! {
// get a reference to our storyboard cell
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: reuseIdentifier, for: indexPath as IndexPath) as! GroceryItemCollectionViewCell
cell.buttonDelegate = self
let item = fetchedResultsController.object(at: indexPath)
cell.label.text = item.name
cell.deleteButton.tag = indexPath.row
if item.isSelected {
cell.backgroundColor = selectedCellColor
} else {
cell.backgroundColor = unselectedCellColor
}
return cell
} else {
if indexPath.row == 0 {
// get a reference to our storyboard cell
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "AddNewCell", for: indexPath as IndexPath) as! AddNewCollectionViewCell
cell.backgroundColor = unselectedCellColor // make cell more visible in our example project
return cell
} else {
let index = IndexPath(row: (indexPath.row - 1), section: 0)
let item = fetchedResultsController.object(at: index)
// get a reference to our storyboard cell
let cell = collectionView.dequeueReusableCell(withReuseIdentifier: reuseIdentifier, for: indexPath as IndexPath) as! GroceryItemCollectionViewCell
cell.buttonDelegate = self
cell.deleteButton.tag = indexPath.row - 1
cell.label.text = item.name
if item.isSelected {
cell.backgroundColor = selectedCellColor
} else {
cell.backgroundColor = unselectedCellColor
}
return cell
}
}
}
func buttonTapped(cell: GroceryItemCollectionViewCell) {
let index = IndexPath(row: (cell.deleteButton.tag), section: 0)
self.context.delete(fetchedResultsController.object(at: index))
self.setUpCollectionView()
}
func textFieldHandler(textField: UITextField!)
{
let label = UILabel(frame: CGRect(x: 0, y: 0, width: 50, height: 50))
label.text = "Text"
textField.placeholder = "Enter Chore Name"
if (textField) != nil {
print("true")
}
}
func textFieldHandler1(textField: UITextField!)
{
let label = UILabel(frame: CGRect(x: 0, y: 0, width: 50, height: 50))
label.text = "Text"
textField.placeholder = "Enter Date"
if (textField) != nil {
print("true")
}
}
func getContext () -> NSManagedObjectContext {
let appDelegate = UIApplication.shared.delegate as! AppDelegate
return appDelegate.persistentContainer.viewContext
}
func saveItemInLocalDB(groceryItem : Item) {
let context = getContext()
//retrieve the entity that we just created
let entity = NSEntityDescription.entity(forEntityName: "GroceryItem", in: context)
let item = NSManagedObject(entity: entity!, insertInto: context)
//set the entity values
item.setValue(groceryItem.name, forKey: "name")
item.setValue(false, forKey: "isSelected")
item.setValue(loggedInUserHouseNumber, forKey: "houseNo")
//save the object
do {
try context.save()
print("ang item:", groceryItem.name)
print("saved!")
} catch let error as NSError {
print("Could not save \(error), \(error.userInfo)")
} catch {
}
}
func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
// handle tap events
print("You selected cell #\(indexPath.item)!")
let cell = collectionView.cellForItem(at: indexPath)
if self.searchBarActive! {
let index = IndexPath(row: indexPath.row, section: 0)
let item = fetchedResultsController.object(at: index)
if item.isSelected {
item.isSelected = false
cell?.backgroundColor = unselectedCellColor
} else {
item.isSelected = true
cell?.backgroundColor = selectedCellColor
}
do {
try context.save()
print("saved!")
} catch let error as NSError {
print("Could not save \(error), \(error.userInfo)")
} catch {
}
} else {
if indexPath.row == 0 {
let alert = UIAlertController(title: "Add New Chore", message: "", preferredStyle:
UIAlertControllerStyle.alert)
alert.addTextField(configurationHandler: textFieldHandler)
alert.addTextField(configurationHandler: textFieldHandler1)
// alert.addTextField(configurationHandler: { (textField) in
// textField.placeholder = "Enter Chore Name"
// })
let a = loggedInUsername
if ((a?.lowercased().range(of: "mother")) != nil) {
print("true")
alert.addAction(UIAlertAction(title: "OK", style: UIAlertActionStyle.default, handler:{ (UIAlertAction)in
let newItem : String = (alert.textFields?.first?.text)!
if !newItem.isEmpty {
let item = Item(name: newItem)
// let item2 = Item(name: newItem2)
self.saveItemInLocalDB(groceryItem: item!)
self.setUpCollectionView()
}
}))
self.present(alert, animated: true, completion:nil)
} else {
let alertVC : UIAlertController = UIAlertController(title: "No Access", message: "please try again", preferredStyle: .alert)
alertVC.addAction(UIAlertAction(title: "Close", style: .default, handler: nil))
self.present(alertVC, animated: true, completion: nil)
print("false")
}
} else {
let index = IndexPath(row: (indexPath.row - 1), section: 0)
let item = fetchedResultsController.object(at: index)
if item.isSelected {
item.isSelected = false
cell?.backgroundColor = unselectedCellColor
} else {
item.isSelected = true
cell?.backgroundColor = selectedCellColor
}
do {
try context.save()
print("saved!")
} catch let error as NSError {
print("Could not save \(error), \(error.userInfo)")
} catch {
}
}
}
}
// This method updates filteredData based on the text in the Search Box
func searchBar(_ searchBar: UISearchBar, textDidChange searchText: String) {
if (searchBar.text?.isEmpty)!{
searchBarActive = false
textToSearch = nil
} else {
searchBarActive = true
textToSearch = searchText
}
self.setUpCollectionView()
}
func searchBarCancelButtonClicked(_ searchBar: UISearchBar) {
self.searchBarActive = false
textToSearch = nil
self.searchBar.text = ""
self.view.endEditing(true)
self.setUpCollectionView()
// self.collectionView.reloadData()
}
func searchBarSearchButtonClicked(_ searchBar: UISearchBar) {
self.searchBarActive = true
textToSearch = searchBar.text
self.view.endEditing(true)
self.setUpCollectionView()
// self.collectionView.reloadData()
}
func searchBarTextDidEndEditing(_ searchBar: UISearchBar) {
self.searchBar.setShowsCancelButton(false, animated: true)
self.searchBarActive = false
textToSearch = nil
self.setUpCollectionView()
// self.collectionView.reloadData()
}
func searchBarTextDidBeginEditing(_ searchBar: UISearchBar) {
self.searchBar.setShowsCancelButton(true, animated: true)
}
func controller(_ controller: NSFetchedResultsController<NSFetchRequestResult>, didChange anObject: Any, at indexPath: IndexPath?, for type: NSFetchedResultsChangeType, newIndexPath: IndexPath?) {
switch (type) {
case .insert:
break;
case .update:
break;
case .move:
break;
case .delete:
break;
}
}
}
最佳答案
根据我的理解,您正在尝试添加多个具有相同字段的数据。
所以我想你可以使用我的保存数据的方法
func saveDataInCoreData(nameOfGroccery:String){
let context = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
let groceryData = GroceryItem(context: context) // Link GroceryItem & Context
groceryData.name = nameOfGroccery
groceryData.isSelected = false
groceryData.houseNo = loggedInUserHouseNumber
(UIApplication.shared.delegate as! AppDelegate).saveContext()
}
这将一次保存您的所有数据。
在评论中引用您的问题
您可以尝试以下逻辑
步骤:1在顶部创建一个变量
var strName:String = String()
第 2 步修改您的代码,如下所示
strName = (alert.textFields?.first?.text)!
if strName != ""{
self.saveDataInCoreData(nameOfGroccery: strName)
}
在警报中添加文本字段的代码:
//1. Create the alert controller.
let alert = UIAlertController(title: "Add New Chore", message: "", preferredStyle: .alert)
//2. Add the text field. You can configure it however you need.
alert.addTextField { (textField) in
textField.text = "Some default text"
}
// 3. Grab the value from the text field, and print it when the user clicks OK.
alert.addAction(UIAlertAction(title: "OK", style: .default, handler: { [weak alert] (_) in
let textField = alert?.textFields![0] // Force unwrapping because we know it exists.
if textField?.text != ""{
print("Text field: \(textField?.text!)")
self.saveDataInCoreData(nameOfGroccery: textField?.text)
}
}))
// 4. Present the alert.
self.present(alert, animated: true, completion: nil)
关于ios - 如何使用警报文本字段在 swift ios 中保存多个数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49548485/
在有些场景下,我们需要对我们的varchar类型的字段做修改,而修改的结果为两个字段的拼接或者一个字段+字符串的拼接。 如下所示,我们希望将xx_role表中的name修改为name+id。
SELECT incMonth as Month, SUM( IF(item_type IN('typ1', 'typ2') AND incMonth = Month, 1, 0 ) )AS
我最近读到 volatile 字段是线程安全的,因为 When we use volatile keyword with a variable, all the threads read its va
我在一些模型中添加了一个 UUID 字段,然后使用 South 进行了迁移。我创建的任何新对象都正确填充了 UUID 字段。但是,我所有旧数据的 UUID 字段为空。 有没有办法为现有数据填充 UUI
刚刚将我的网站从 mysql_ 更新为 mysqli,并破坏了之前正常运行的查询。 我试图从旋转中提取 id,因为它每次都会增加 1,但我不断获取玩家 id,有人可以告诉我我做错了什么吗?我尝试了将
我在 Mac OS X 上使用带有 Sequel Pro 的 MySQL。我想将一个表中的一个字段(即名为“GAME_DY”的列)复制到另一个名为“DAY_ID”的表的空字段中。两个表都是同一数据库的
问题: 是否有可能有一个字段被 JPA 保留但被序列化跳过? 可以实现相反的效果(JPA 跳过字段而序列化则不会),如果使用此功能,那么相反的操作肯定会很有用。 类似这样的事情: @Entity cl
假设我有一个名为“dp”的表 Year | Month | Payment| Payer_ID | Payment_Recipient | 2008/2009 | July
我将尝试通过我的 Raspberry Pi 接入点保证一些 QoS。 开始之前,我先动手:我阅读了有关 tcp、udp 和 ip header 的内容。在IP header description我看
如果你能弄清楚如何重命名这个问题,我愿意接受建议。 在 Dart 语言中,可以编写一个带有 final 字段的类。这些是只能设置的字段构造函数前 body 跑。这可以在声明中(通常用于类中的静态常量)
你怎么样? 我有两个带有两个字段的日期选择器 我希望当用户选择 (From) 时,第二个字段 (TO) 将是 next day 。比如 booking.com 例如:当用户选择From 01-01-2
我想我已经看到了这个问题的一些答案,这些答案可能与我需要的相差不远,但我对 mysql 的了解还不够确定,所以我会根据我的具体情况提出问题。 我有一个包含多个表的数据库,为此,如果“image”表上的
我在 mySQL 数据库中有 2 个表: customers ============ customer_id (1, 2 ) customer_name (john, mark) orders ==
我正在开发一个员工目标 Web 应用程序。 领导/经理在与团队成员讨论后为他们设定目标。这是一年/半年/季度,具体取决于组织遵循的评估周期。 现在的问题是添加基于时间段的字段或存档上一季度/年度数据的
我正在寻找允许内容编辑器从媒体库中选择多个文件的东西,这些文件将在渲染中列出。他们还需要能够上传文件和搜索。它必须在页面编辑器(版本 8 中称为体验编辑器)中工作。 到目前为止我所考虑的: 一堆文件字
现在,我有以下由 original.df %.% group_by(Category) %.% tally() %.% arrange(desc(n)) 创建的 data.frame。 DF 5),
我想知道是否有一些步骤/解决方案可以处理错误消息并将它们放入 Pentaho 工具中的某个字符串或字段中?例如,如果连接到数据库时发生某些错误,则将该消息从登录到字符串/字段。 最佳答案 我们在作业的
如何制作像短信应用程序一样的“收件人”字段?例如,右侧有一个“+”按钮,当添加某人时,名称将突出显示并可单击,如圆角矩形等。有没有内置的框架? 最佳答案 不,但请参阅 Three20 的 TTMess
是否可以获取记录的元素或字段的列表 通过类型信息类似于类的已发布属性的列表吗? 谢谢 ! 最佳答案 取决于您的delphi版本,如果您使用的是delphi 2010或更高版本,则可以使用“新rtti”
我正在构建一个 SQLite 数据库来保存我的房地产经纪人的列表。我已经能够使用外键来识别每个代理的列表,但我想在每个代理的记录中创建一个列表;从代理商和列表之间的一对一关系转变为一对多关系。 看这里
我是一名优秀的程序员,十分优秀!