- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个带有 6 个字段的扩展 ParseObject 类。除 ParseFile getter 方法外,所有字段都返回正确的数据。以老式方式获取 ParseFiles 是可行的,但由于某种原因,当我使用扩展类时,调用 GetDataCallback 时数据为空。它有一个 URL 和图像名称,但数据字段为空。
我的扩展类(class):
package [mypackage];
import com.parse.ParseClassName;
import com.parse.ParseFile;
import com.parse.ParseObject;
import java.io.Serializable;
@ParseClassName("Listing")
public class Listing extends ParseObject implements Serializable {
private boolean active;
private String description, title, username;
private int price;
private ParseFile file;
public Listing() {
super();
}
public void setDetail(boolean active, String description, String title,
String username, int price, ParseFile file) {
this.active = active;
this.description = description;
this.price = price;
this.title = title;
this.username = username;
this.file = file;
}
/* getter methods */
public boolean getIsActive() {
return getBoolean("active");
}
public String getDescription() {
return getString("description");
}
public int getPrice() {
return getInt("price");
}
public String getListingTitle() { /* getTitle() reserved by android */
return getString("title");
}
public String getUsername() {
return getString("username");
}
public ParseFile getFile() {
return getParseFile("image");
}
}
调用 getter 方法的位置:
public void getListings() {
ParseQuery<Listing> query = ParseQuery.getQuery(Listing.class);
/* only retrieve active listings */
query.whereEqualTo("active", true);
query.findInBackground(new FindCallback<Listing>() {
@Override
//public void done(List<ParseObject> listingList, ParseException e) {
public void done(List<Listing> listingList, ParseException e) {
if (e == null) {
Log.d("listing", "Retrieved " + listingList.size() + " listings");
/* clear adapter before populating */
adapter.clear();
/* iterate through listings and create listing objects */
for (Listing listingObject : listingList) {
boolean active;
String description, title, username;
int price;
active = listingObject.getIsActive();
username = listingObject.getUsername();
description = listingObject.getDescription();
title = listingObject.getListingTitle();
price = listingObject.getPrice();
file = listingObject.getFile();
/* create a listing object to be added to a ListView */
Listing listing = new Listing();
listing.setDetail(active, description, title, username, price, file);
listings.add(listing);
} /* end for loop */
}
else {
Log.d("listing", "Error: " + e.getMessage());
}
}
});
}
在适配器中:
public View getView(int position, View convertView, ViewGroup parent){
if(convertView == null){
LayoutInflater mLayoutInflater = LayoutInflater.from(context);
convertView = mLayoutInflater.inflate(R.layout.listing_row_item, null);
}
Listing listing = listings.get(position);
TextView titleView = (TextView) convertView.findViewById(R.id.listing_title);
TextView priceView = (TextView) convertView.findViewById(R.id.listing_price);
final ParseImageView imageView = (ParseImageView) convertView.findViewById(R.id.ivPicture);
titleView.setText(listing.getListingTitle());
priceView.setText("$" + String.valueOf(listing.getPrice()));
listing.getFile().getDataInBackground(new GetDataCallback() { //getFile() returns null
public void done(byte[] data, ParseException e) {
编辑:我相信我的根本误解是如何设置扩展 ParseObject 的值。正如下面的答案所示,这里的 put
Parse 方法实际上将值放入对象中。我的印象是 put
仅用于实际的数据库操作,因此我的 setter 方法没有正确设置 ParseObject。
最佳答案
呃...我们是如此接近。我发现了问题,您没有将值设置为 ParseObject 中的字段,这就是适配器中所有内容均为空的原因。将以下内容添加到您的 Listing 类中并更改 setDetail 方法,如下所示:
public void setDetail(boolean active, String description, String title,
String username, int price, ParseFile file) {
setIsActive(active);
setIsActive(description);
setPrice(price);
setListingTitle(title);
setUsername(username);
setFile(file);
}
public void setIsActive(boolean a) {
put("active", a);
}
public void setDescription(String s) {
put("description", s);
}
public void setPrice(int p) {
put("price", p);
}
public void setListingTitle(String t) {
put("title", t);
}
public void setUsername(String u) {
put("username", u);
}
public void setFile(ParseFile f) {
put("image", f);
}
旧答案
我可能是错的,但我很确定您应该保存 ParseFile 的 URL 而不是 ParseFile 本身,并使用该 URL 来获取文件。所以在done(..)方法中你应该做类似的事情:
file.getUrl();
并将其设置为字符串。继续前进,如果
关于java - getParseFile(string key) 使用扩展的 ParseObject 类从 Parse.com 返回 null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27753769/
最近开始学习oracle和sql。 在学习的过程中,我遇到了几个问题,我的 friend 在接受采访时被问到这些问题。 SELECT * FROM Employees WHERE NULL IS N
这个问题在这里已经有了答案: Can we subtract NULL pointers? (4 个回答) 关闭 2 个月前。 是否定义了NULL - NULL? (char *)NULL - (ch
是否有推荐的方法(根据 .net Framework 指南)检查 null,例如: if (value == null) {//code1} else {//code2} 或 if (value !=
我正在尝试将值插入数据库,但出现这样的错误任何人都可以告诉我为什么该值为空,如下所示: An exception occurred while executing 'INSERT INTO perso
这个问题在这里已经有了答案: String concatenation with a null seems to nullify the entire string - is that desire
您好,我正在 Android 联系人搜索模块中工作。我正在查询下方运行。 cur = context.getContentResolver().query(ContactsContract.Data.
下面的 SQL 表定义说明了从我的 MYSQL 数据库创建表的语句之一,该数据库是由我公司的前开发人员开发的。 DROP TABLE IF EXISTS `classifieds`.`category
我主要有应用程序开发背景。在编程语言中 variable == null或 variable != null有效。 当涉及到 SQL 时,以下查询不会给出任何语法错误,但也不会返回正确的结果。 sel
我在尝试检查某些元素是否为 NULL 时遇到段错误或不。任何人都可以帮忙吗? void addEdge(int i, int j) { if (i >= 0 && j > 0)
在 SQL 服务器中考虑到以下事实:Col1 和 Col2 包含数值和 NULL 值 SELECT COALESCE(Col1,Col2) 返回一个错误:“COALESCE 的至少一个参数必须是一个不
在 SQL 服务器中考虑到以下事实:Col1 和 Col2 包含数值和 NULL 值 SELECT COALESCE(Col1,Col2) 返回一个错误:“COALESCE 的至少一个参数必须是一个不
下面查询的关系代数表达式是什么?我找不到“Is Null”的表达式。 SELECT reader.name FROM reader LEFT JOIN book_borrow ON reader.ca
我正在尝试使用三元运算符来检查值是否为 null 并返回一个表达式或另一个。将此合并到 LINQ 表达式时,我遇到的是 LINQ 表达式的 Transact-SQL 转换试图执行“column = n
我在给定的代码中看到了以下行: select(0, (fd_set *) NULL, (fd_set *) NULL, (fd_set *) NULL, &timeout); http://linux
var re = /null/g; re.test('null null'); //> true re.test('null null'); //> true re.test('null null')
这个问题在这里已经有了答案: 关闭 13 年前。 我今天避开了一场关于数据库中空值的激烈辩论。 我的观点是 null 是未指定值的极好指示符。团队中有意见的其他每个人都认为零和空字符串是可行的方法。
由于此错误,我无法在模拟器中运行我的应用: Error:null value in entry: streamOutputFolder=null 或 gradle - Error:null value
我正在尝试在 Android 应用程序中创建电影数据库,但它返回错误。知道这意味着什么吗? public Cursor returnData() { return db.query(TABLE
我一直在检查浏览器中的日期函数以及运行时间 new Date (null, null, null); 在开发工具控制台中,它给出了有效的日期 Chrome v 61 回归 Sun Dec 31 189
为什么 NA==NULL 会导致 logical (0) 而不是 FALSE? 为什么 NULL==NULL 会导致 logical(0) 而不是 TRUE? 最佳答案 NULL 是一个“零长度”对象
我是一名优秀的程序员,十分优秀!