Titanium,Android,ListView与searchView在actionBar中,怎么样?

时间:2014-01-16 17:11:27

标签: android listview android-actionbar titanium searchview

我无法想象如何使用嵌入在带有ListView的操作栏中的Ti.UI.Android.createSearchView。 我的代码是:

var win = Ti.UI.createWindow({
    backgroundColor: 'blue',
    fullscreen: false,
    title: 'Productos'
});

var search;
var searchAsChild = false;

if (Ti.Platform.name == 'android' && Ti.Platform.Android.API_LEVEL >= 11) {
    // Use action bar search view
    search = Ti.UI.Android.createSearchView({
        hintText: "Table Search"
    });

    win.activity.onCreateOptionsMenu = function(e) {
        var menu = e.menu;
        var menuItem = menu.add({
            title: 'Table Search',
            actionView : search,
            icon: (Ti.Android.R.drawable.ic_menu_search ? Ti.Android.R.drawable.ic_menu_search : "my_search.png"),
            showAsAction: Ti.Android.SHOW_AS_ACTION_IF_ROOM | Ti.Android.SHOW_AS_ACTION_COLLAPSE_ACTION_VIEW
        });
    };
}
else {
    // Use search bar
    search = Ti.UI.createSearchBar({
        hintText: "Table Search"
    });
    searchAsChild = true;
}

search.addEventListener('cancel', function(){
    search.blur();
});

var listView = Ti.UI.createListView({searchView: search, caseInsensitiveSearch: true});

var listSection = Ti.UI.createListSection();
var fruits = ['Papaya', 'Peach', 'Pear', 'Persimmon', 'Pineapple', 'Pluot', 'Pomegranate'];
var data = [];
for (var i = 0; i < fruits.length; i++) {
    data.push({
        properties: {title: fruits[i], searchableText: fruits[i]}
    });
}
listSection.setItems(data);

listView.sections = [listSection];

win.add(listView);

win.open();

并在日志中显示:

[ERROR] MenuProxy: (main) [6091237,6100945] View already has a parent. Can't add it as an action view

在设备上,在操作栏上显示一个搜索图标,但是如果我点击它,则没有任何反应。并在listView标题上显示另一个搜索图标,当我单击它时,会出现一个文本框进行搜索。




如果我使用TableView实现相同的列表,它可以正常工作!

谢谢!!

1 个答案:

答案 0 :(得分:1)

您已将搜索作为searchView添加到ListView。只需在创建ListView时删除searchView属性即可。要搜索ListView,您必须使用listview.searchText。它需要一个字符串。您可以向searchView添加更改侦听器以设置此searchText。我没有对此进行测试,但如果您希望我能提供代码段。