我想显示一些细节,比如客户地址的名称,当我必须重新排序视图列表时,用户可以将第3行拖放到第5位,将第6行拖放到第10位,就像这样我需要,在钛工作室的Android。
任何人都会帮助我。我处于钛基础水平。答案 0 :(得分:3)
拖放支持仅适用于iOS(至少通过Titanium SDK)。此外,我不相信我在Android应用程序中看到拖放行重新排序。但我已经看到上下箭头让你重新订购。下面是使用TableView的示例代码。如果使用ListView,代码可以更清晰(您可以使用replaceItemsAt交换项而不更新整个列表)。
var win = Ti.UI.createWindow({
backgroundColor: '#fff',
fullscreen: true
});
var data = [];
for(var i = 1; i <= 10; i++) {
var row = Ti.UI.createTableViewRow();
row.add(Ti.UI.createLabel({
text: 'Row ' + i, textAlign: 'left',
width: Ti.UI.FILL, color: '#000'
}));
row.add(Ti.UI.createButton({
title: 'Up', action: 'moveUp',
width: 50, right: 70
}));
row.add(Ti.UI.createButton({
title: 'Down', action: 'moveDown',
width: 50, right: 10
}));
data.push(row);
}
var table = Ti.UI.createTableView({
data: data
});
table.addEventListener('click', function(evt) {
var action = evt.source.action,
index = evt.index,
isFirstRow = index === 0,
isLastRow = index + 1 === data.length;
if(action === 'moveUp' && !isFirstRow) {
swapRows(index, index - 1);
}
else if(action === 'moveDown' && !isLastRow) {
swapRows(index, index + 1);
}
});
win.add(table);
win.open();
function swapRows(indexOne, indexTwo) {
var temp = data[indexOne];
data[indexOne] = data[indexTwo];
data[indexTwo] = temp;
table.data = data;
}