java - 如果 Android 中的值为空或 null,则显示默认文本

标签 java android xml sqlite android-fragments

我有一个应用程序,其中包含我 (MyProfileAboutFragment) 和我 friend (AboutFragment) 的个人资料 Activity 。

我从服务器获取我的 friend 列表,当我点击它时,我通过 Intent 将用户名、照片、关于、电话等发送到我的 AboutFragment如果缺少字段,则会显示默认文本。这可以正常工作。

现在我想这样做:当我打开 MyProfileAboutFragment 时,它应该从我的 sqlite 数据库中获取我的个人数据,并在缺少字段时返回默认文本。 我得到的不是默认文本,而是“null”

我在 MyProfileAboutFragment 中做了所有事情,就像在 AboutFragment 中一样,只不过我的数据不是从服务器返回,而是从 sqlite 获取。

AboutFragment.java:

public class AboutFragment extends Fragment {

private TextView userName, contactsStatus, contactUserStars, contactUserAbout;
private String contactId, contactName;
private ImageView contactStatusImage;

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.profile_fragment_about, container,
            false);

    userName = (TextView) view.findViewById(R.id.contactUserName);
    contactsStatus = (TextView) view.findViewById(R.id.contactsStatus);
    contactUserStars = (TextView) view.findViewById(R.id.userStars);
    contactUserAbout = (TextView) view.findViewById(R.id.contactUserAbout);
    contactStatusImage = (ImageView) view.findViewById(R.id.contactStatusImage);

    ContactProfileActivity activity = (ContactProfileActivity) getActivity();
    Intent fromAvailableActivityIntent = activity.getIntent();

    String userId = fromAvailableActivityIntent.getStringExtra("userId");
    String contactUserName = fromAvailableActivityIntent.getStringExtra("userName");
    String contactAbout = fromAvailableActivityIntent.getStringExtra("about");

    userName.setText(contactUserName);
    if (contactAbout != null && !contactAbout.isEmpty()) {
        contactUserAbout.setText(contactAbout);
    }

    return view;
    }
}

MyProfileAboutFragment.java:

public class MyProfileAboutFragment extends Fragment {

private TextView userName, eMail, myPhone, stars, aboutMe;
private SQLiteHandler db;

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.profile_fragment_about_me, container,
            false);

    db = new SQLiteHandler(getActivity());
    // Fetching user details from sqlite
    HashMap<String, String> user = db.getUserDetails();

    String id = user.get("uid");
    String name = user.get("name");
    String email = user.get("email");
    String phone = user.get("phone");
    String about = user.get("about");

    userName = (TextView) view.findViewById(R.id.userName);
    eMail = (TextView) view.findViewById(R.id.userEmail);
    myPhone = (TextView) view.findViewById(R.id.userPhone);
    stars = (TextView) view.findViewById(R.id.userStars);
    aboutMe = (TextView) view.findViewById(R.id.userAboutMe);

    userName.setText(name);
    eMail.setText(email);
    myPhone.setText(phone);

    // I did the same exact thing in AboutFragment and it worked
    if (about != null && !about.isEmpty()) {
        aboutMe.setText(about);
    }

    return view;
    }
}

profile_fragment_about.xml:

<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?attr/selectableItemBackground"
android:padding="@dimen/activity_horizontal_margin">

<TextView
    android:id="@+id/contactUserAboutTitle"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:maxLines="1"
    android:text="@string/about"
    android:textAppearance="@style/TextAppearance.AppCompat.Medium"
    android:textColor="@color/mycolorred"
    android:textStyle="bold" />

<TextView
    android:id="@+id/contactUserAbout"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@id/contactUserAboutTitle"
    android:layout_marginTop="8dp"
    android:text="@string/long_text"
    android:textAppearance="@style/TextAppearance.AppCompat.Small"
    android:textColor="#727272" />
</RelativeLayout>

profile_fragment_about_me.xml:

<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?attr/selectableItemBackground"
android:padding="@dimen/activity_horizontal_margin">

<TextView
    android:id="@+id/userAbout"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:maxLines="1"
    android:text="@string/about"
    android:textAppearance="@style/TextAppearance.AppCompat.Medium"
    android:textColor="@color/mycolorred"
    android:textStyle="bold" />

<TextView
    android:id="@+id/userAboutMe"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@id/userAbout"
    android:layout_marginTop="8dp"
    android:text="@string/long_text"
    android:textAppearance="@style/TextAppearance.AppCompat.Small"
    android:textColor="#727272" />
</RelativeLayout>

SQLITE:

/**
* Storing user details in database
*/
public void addUser(String name, String email, String uid, String created_at,    String about, String image, String phone) {
SQLiteDatabase db = this.getWritableDatabase();

ContentValues values = new ContentValues();
values.put(KEY_NAME, name); // Name
values.put(KEY_EMAIL, email); // Email
values.put(KEY_UID, uid); // Email
values.put(KEY_CREATED_AT, created_at); // Created At
values.put(KEY_ABOUT, about);
values.put(IMAGE, image);
values.put(PHONE, phone);

// Inserting Row
long id = db.insert(TABLE_USER, null, values);
db.close(); // Closing database connection

Log.d(TAG, "New user inserted into sqlite: " + id);
}
/**
 * Getting user data from database
 */
public HashMap<String, String> getUserDetails() {
HashMap<String, String> user = new HashMap<>();
String selectQuery = "SELECT  * FROM " + TABLE_USER;

SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);
// Move to first row
cursor.moveToFirst();
if (cursor.getCount() > 0) {
    user.put("name", cursor.getString(1));
    user.put("email", cursor.getString(2));
    user.put("phone", cursor.getString(3));
    user.put("uid", cursor.getString(4));
    user.put("about", cursor.getString(5));
    user.put("image", cursor.getString(6));
    user.put("created_at", cursor.getString(7));
}
cursor.close();
db.close();
// return user
Log.d(TAG, "Fetching user from Sqlite: " + user.toString());

return user;
}

编辑:

在我的个人资料 Activity 中,我在 Bharat singh 的回答后添加了此内容,以在没有电话号码时显示:

    if (about != null && !about.isEmpty() && !about.equals("null")) {
        myPhone.setText(phone);
    }

XML:

        <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="?attr/selectableItemBackground"
        android:padding="@dimen/activity_horizontal_margin">
        <!--android:clickable="true"-->

        <ImageView
            android:id="@+id/userPhoneImage"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerVertical="true"
            android:layout_marginEnd="@dimen/activity_horizontal_margin"
            android:contentDescription="@string/phone"
            app:srcCompat="@drawable/ic_icon_phone" />

        <TextView
            android:id="@+id/userPhone"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginStart="@dimen/activity_horizontal_margin"
            android:layout_toEndOf="@id/userPhoneImage"
            android:text="@string/phone_default"
            android:textAppearance="@style/TextAppearance.AppCompat.Medium" />

    </RelativeLayout>

编辑2:

巴拉特·辛格也回答了这个问题:

    if (!about.isEmpty() && !about.equals("null")) {
        myPhone.setText(phone);
    }

最佳答案

替换这个

 if (about != null && !about.isEmpty()) {
    aboutMe.setText(about);
}

有了这个

 if (about != null && !about.isEmpty() && !about.equals("null")) {
        aboutMe.setText(about);
    }

作为数据库返回“null”作为字符串

关于java - 如果 Android 中的值为空或 null,则显示默认文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43868593/

相关文章:

android - 使用 Retrofit 和 MockWebServer 模拟无网络

php - 如何在对 XPLAN API 的 CURL 请求中构造 edai.Search 方法的第三个参数?

包含嵌套元素的 SQL 表中的 XML

java - 将 Int 值添加到二维数组

java - 如何在 java 中为 android 应用程序检索和访问多维数组

java - 标题列旁边的空白

android - RxJava 如何从具有间隔的列表中发出对象

android - 无法通过 ViewPropertyAnimator 更改 View 大小?

c# - 从 XML 中获取标签值

java - 如何将 gzipped rdf 文件加载到 rdf4j 存储库?