我创建了一个tableViewcontroller,并在story board中为它分配了自定义类:PFQueryTableViewController。然后我还给了它parseClassName "userMessage",出于某种原因,当我尝试运行应用程序时,总是得到相同的错误消息:NSInternalInconsistencyException', reason: 'You need to specify a parseClassName for the PFQueryTableViewController.
我不明白为什么会出现这个错误,因为我显式地给了类一个parseClassName。
以下是PFQueryTabletableViewController的关联代码:
import UIKitimport CoreLocationimport Parse
class TableViewController: PFQueryTableViewController, CLLocationManagerDelegate {

let userMessages = ["blah blahh blahhh", "Beep Beep Boop", "Beep Beep Bobbity boop"]

let locationManager = CLLocationManager()
var currLocation: CLLocationCoordinate2D?

override init!(style: UITableViewStyle, className: String!) {
    super.init(style: style, className: className)
}

required init(coder aDecoder: NSCoder) {
    super.init(coder: aDecoder)

    self.parseClassName = "userMessage"
    self.textKey = "text"
    self.pullToRefreshEnabled = true
    self.objectsPerPage = 40

}





private func alert(message: String){
    let alert = UIAlertController(title: "Uh-OH", message: message, preferredStyle: UIAlertControllerStyle.Alert)
    let action = UIAlertAction(title: "Ok", style: UIAlertActionStyle.Default, handler: nil)
    let cancel = UIAlertAction(title: "Cancel", style: UIAlertActionStyle.Cancel, handler: nil)
    let settings = UIAlertAction(title: "Settings", style: UIAlertActionStyle.Default) {(action) -> Void in
        UIApplication.sharedApplication().openURL(NSURL(string: UIApplicationOpenSettingsURLString)!)
        return

    }

    alert.addAction(settings)
    alert.addAction(action)
    self.presentViewController(alert, animated: true, completion: nil)
}

override func viewDidLoad() {
    super.viewDidLoad()
    self.tableView.estimatedRowHeight = 120
    self.tableView.rowHeight = 120
    locationManager.desiredAccuracy = 100
    locationManager.delegate = self
    locationManager.requestWhenInUseAuthorization()
    locationManager.startUpdatingLocation()
}

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
}

func locationManager(manager: CLLocationManager!, didChangeAuthorizationStatus status: CLAuthorizationStatus) {
    alert("Cannot fetch your location!!")
}

override func queryForTable() -> PFQuery! {
    let query = PFQuery(className: "Messages")
    if let queryLoc = currLocation {
        query.whereKey("location", nearGeoPoint: PFGeoPoint(latitude: queryLoc.latitude, longitude: queryLoc.longitude), withinMiles: 1)
        query.limit = 40
        query.orderByDescending("createdAt")
    }else {
        query.whereKey("location", nearGeoPoint: PFGeoPoint(latitude: 37.41182, longitude: -121.941125), withinMiles: 1)
        query.limit = 40
        query.orderByDescending("createdAt")
    }

    return query
}

func locationManager(manager: CLLocationManager!, didUpdateLocations locations: [AnyObject]!) {
    locationManager.stopUpdatingLocation()
    if(locations.count > 0) {
        let location = locations[0] as CLLocation
        println(location.coordinate)
        currLocation = location.coordinate
    } else {
        alert("Cannot fetch your loation")
    }
}

override func objectAtIndexPath(indexPath: NSIndexPath!) -> PFObject! {
    var obj : PFObject? = nil
    if(indexPath.row < self.objects.count) {
        obj = self.objects[indexPath.row] as? PFObject
    }
    return obj
}

override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
    return 1
}

override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return userMessages.count
}

override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath!, object: PFObject!) -> PFTableViewCell {
    let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as TableViewCell
    cell.messageText.text = object.valueForKey("text") as? String
    cell.messageText.numberOfLines = 0
    let views = object.valueForKey("count") as Int
    cell.numberOfViewsLabel.text = "\(views)"
    cell.numberOfViewsLabel.text = "\((indexPath.row + 1) * 5)"
    return cell
}

func addToViews(sender: AnyObject) {
    let hitPoint = sender.convertPoint(CGPointZero, toView: self.tableView)
    let hitIndex = self.tableView.indexPathForRowAtPoint(hitPoint)
    let object = objectAtIndexPath(hitIndex)
    object.incrementKey("count")
    object.saveInBackgroundWithBlock { (Bool, NSError) -> Void in
        //blahhh
    }
    self.tableView.reloadData()

}

}
`

最佳答案

parseClassName是一个只读变量,仅在子类化PFObject时使用。
https://parse.com/docs/ios/api/Classes/PFObject.html#//api/name/parseClassName
对象的类名。
@属性(强,只读)NSString*parseClassName
声明于
PFObject.h文件
目标-C

@implementation MYGame

 @dynamic title;

 + (NSString *)parseClassName {
     return @"Game";
 }

 @end

斯威夫特
class MYGame: PFObject  {
    class func parseClassName() -> String! {
        return "Game"
    }
}

关于xcode - 您需要为PFQueryTableViewController指定parseClassName,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/28255376/

10-14 21:07