如何将EditText中的文本插入数据库?

时间:2017-12-02 22:36:12

标签: java android android-sqlite

我试图从 editText 获取文本并将其输入到我的数据库中。一旦我尝试提交文本,我遇到的问题是NullPointerException。任何帮助将不胜感激。

ERROR:

 java.lang.NullPointerException: Attempt to invoke virtual method 'android.text.Editable android.widget.EditText.getText()' on a null object reference

这来自我的 MainActivity

public boolean onOptionsItemSelected(MenuItem item) {
    switch (item.getItemId()){

        case R.id.action_add_task:

            final EditText text = (EditText)findViewById(R.id.editText);

            AlertDialog dialog = new AlertDialog.Builder(this)
                    .setTitle("Add New Task")
                    .setMessage("what do you want to do next")
                    .setView(R.layout.custom_view)
                    .setPositiveButton("Add", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {

                            String task;
                            task = text.getText().toString();

                            dbHelper.insertNewTask(task);
                            if(getFragmentRefreshListener()!=null) {
                                getFragmentRefreshListener().onRefresh();
                            }
                            loadTaskList();
                        }
                    })
                    .setNegativeButton("Cancel",null)
                    .create();
            dialog.show();

            return true;
    }
    return super.onOptionsItemSelected(item);
}

我的 custom_view.xml

  <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="Enter a task"
        android:id="@+id/editText" />

my activity_main.xml:

<android.support.design.widget.TabLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/tablayout"
        android:background="@color/colorPrimaryDark"
        android:minHeight="?attr/actionBarSize"
        >

    </android.support.design.widget.TabLayout>

     <android.support.v4.view.ViewPager
            android:id="@+id/pager"
            android:layout_width="match_parent"
            android:layout_height="fill_parent"
            android:backgroundTint="@android:color/darker_gray"
            android:visibility="visible">

            <ListView
                android:id="@+id/lstTask"
                android:layout_width="match_parent"
                android:layout_height="match_parent"

                android:layout_alignParentStart="true"
                android:layout_alignParentTop="true"
                android:text="@string/tasks"
                android:textSize="30sp" />
        </android.support.v4.view.ViewPager>

2 个答案:

答案 0 :(得分:1)

好吧,因为我看不到MainActivity布局的xml,所以它最有可能导致NPE。

 final EditText text = (EditText)findViewById(R.id.editText);

您在活动视图层次结构中搜索编辑文本时(假设对话框创建中显示的内容)您应该在对话框视图层次结构中搜索它。

      .setView(R.layout.custom_view)

您将该视图设置为对话框的视图,这可能是导致异常的原因。尝试在onClick方法中修改对编辑文本的引用,如下所示:

 AlertDialog dialog = new AlertDialog.Builder(this)
                .setTitle("Add New Task")
                .setMessage("what do you want to do next")
                .setView(R.layout.custom_view)
                .setPositiveButton("Add", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {

                        final EditText text = ((AlertDialog)dialog).findViewById(R.id.editText);
                        String task;
                        task = text.getText().toString();

                        dbHelper.insertNewTask(task);
                        if(getFragmentRefreshListener()!=null) {
                            getFragmentRefreshListener().onRefresh();
                        }
                        loadTaskList();
                    }
                })
                .setNegativeButton("Cancel",null)
                .create();
        dialog.show();

答案 1 :(得分:0)

以下是解决我问题的原因:

我更改了这一行:

final EditText text = ((AlertDialog)dialog).findViewById(R.id.editText);

对此:

final EditText text = (EditText) ((AlertDialog)dialog).findViewById(R.id.editText);