notifyDataSetChanged()无法工作或触发?

时间:2015-09-30 09:30:17

标签: android listview notifydatasetchanged

我正在尝试做什么:

按下添加按钮时,将EditText中的值插入数据库。

使用数据库中的数据填充列表视图。

问题:

当我点击添加按钮时,它会将值插入数据库,但不会将其填充到listview中。 重新打开我的应用程序时,listview刷新并显示数据库中的数据。

这是我的代码:

public class MainActivity extends AppCompatActivity {

EditText editText;
Button add;
ListView listView;
final DBFunctions db=new DBFunctions(MainActivity.this);
ArrayAdapter<String> adapter;
String[] values;

@Override
protected void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    //xml inflation
    editText= (EditText) findViewById(R.id.editText);
    add= (Button) findViewById(R.id.button);
    listView= (ListView) findViewById(R.id.listView);
    values=db.getAlldata();
    adapter=new ArrayAdapter<String>(MainActivity.this,android.R.layout.simple_list_item_1,values);
    listView.setAdapter(adapter);
    add.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v)
        {
            String name = editText.getText().toString();
            if (!name.equals(""))
            {
                editText.setText("");
                long check = db.insertData(name);
                if (check < 0)
                {
                    Toast.makeText(MainActivity.this, "Error in insert query", Toast.LENGTH_SHORT).show();
                } else
                {
                    adapter.notifyDataSetChanged();
                    Toast.makeText(MainActivity.this, name + " inserted", Toast.LENGTH_SHORT).show();
                }
            }
            else
            {
                editText.setError("this field is empty");
            }

        }

    });
}

我在正确的位置使用了 adapter.notifyDataSetChanged

任何人都可以给我解决方案。 这将对我有所帮助。

提前致谢。

2 个答案:

答案 0 :(得分:1)

我认为您还应该将新元素插入values。 调用notifyDataSetChanged()时,实际数据集根本没有变化。 将元素添加到值中,然后调用notifyDataSetChanged()。 您的adpater不能在数据库上工作,只能在Array / LinkedList / ArrayList / Vector上调用值。

其他一切对我来说都很好。

答案 1 :(得分:0)

您的适配器使用从数组获取的数据填充listView。您正在数据库中插入新数据,但这不会更改values数组,因此适配器找不到任何要更改的内容。

尝试更改values数组。因为使用ArrayList而不是Arrays是一个更好的选择。

public class MainActivity extends AppCompatActivity {

EditText editText; 
Button add; 
ListView listView; 
final DBFunctions db=new DBFunctions(MainActivity.this);
ArrayAdapter<String> adapter; 
ArrayList<String> values;

@Override protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    //xml inflation
    editText= (EditText) findViewById(R.id.editText);
    add= (Button) findViewById(R.id.button);
    listView= (ListView) findViewById(R.id.listView);
    values = new ArrayList<String>(Arrays.asList(db.getAlldata()));
    adapter=new ArrayAdapter<String>(MainActivity.this,android.R.layout.simple_list_item_1,values);
    listView.setAdapter(adapter);
    add.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v)
        {
            String name = editText.getText().toString();
            if (!name.equals(""))
            {
                editText.setText("");
                long check = db.insertData(name);
                if (check < 0)
                {
                    Toast.makeText(MainActivity.this, "Error in insert query", Toast.LENGTH_SHORT).show();
                } else
                {
                    values.add(name);
                    adapter.notifyDataSetChanged();
                    Toast.makeText(MainActivity.this, name + " inserted", Toast.LENGTH_SHORT).show();
                }
            }
            else
            {
                editText.setError("this field is empty");
            }

        }

    });


}