Ich habe eine benutzerdefinierte TableViewRow mit einem Titel und den Schalter wie unten:Appcelerator - Programmatische Toggle des Schalters in der kundenspezifischen TableViewRow
rowFilter.xml
<TableViewRow id="rowFilter">
<View id="vwItemHeader">
<Label id="lblItemHeader"></Label>
</View>
<View id="vwFilterStatus">
<Switch id="swtFilterStatus" onChange="swtFilterStatusChange"></Switch>
</View>
</TableViewRow>
rowFilter.js
var args = arguments[0] || {};
var swtFilterStatusChange_callback;
initialize();
function initialize() {
// Initialize filter row UI
$.lblItemHeader.text = args.title;
$.swtFilterStatus.value = args.value;
// Callback
swtFilterStatusChange_callback = args.callback;
};
In eine Sicht, die ich Browse aufrufen, programmiere ich diese benutzerdefinierten Zeilen programmgesteuert wie folgt:
var args = { title: item.title, value: item.value, callback: swtFilterStatusChanged, };
var newRow = Alloy.createController('rowFilter', args).getView('rowFilter');
Dies funktioniert wie vorgesehen. Jetzt möchte ich jedoch ein Häkchen setzen/entfernen. Wie programmiere ich programmgesteuert einen Schalter in meinen benutzerdefinierten Zeilen?
Ich habe versucht, die folgende Funktion in rowFilter.js zu schaffen (und ein ähnliches für Toggle-off):
exports.toggleOn = function() {
if ($.swtFilterStatus.value == false) {
$.swtFilterStatus.value = true;
swtFilterStatusChange();
}
};
Und ich habe auch versucht, dieses:
$.toggleOn = function() {
}
:: EDIT :: So handle ich mit dem Check/De-Check-Schalter.
function allSwitch_Change(value) {
$.tblFilters.data[0].rows.forEach(function(row) {
if (value) {
row.toggleOn();
}
else {
row.toggleOf();
}
}
}
Ändern Sie dann die Browse.js Zeile über das tut Alloy.createController mit den folgenden:
var newRow = require('rowFilter');
newRow.initialize(args);
Aber ich bekomme nur eine Ausnahme auf der Linie mit dem erfordern Erklärung, „konnte nicht gefunden werden Modul: rowFilter für Architektur: x86_64 ".
Was mache ich falsch und wie implementiere ich einen Haken?
Jetzt bekomme ich Ausnahme mit dieser Nachricht angezeigt: "undefiniert ist keine Funktion (Auswertung 'row.trigger (\ "toggleOff \")')". Sehen Sie meine Bearbeitung, die zeigt, wie ich das in einer anderen Funktion nenne. –
Nicht sicher, ob es wichtig ist, aber ich versuche, die Zeilenschalter in einer separaten Funktion zu wechseln, von der ich die Controller erstelle. –
Mein schlechtes. Ich habe nicht gesehen, dass Sie 'getView' auf dem Controller aufgerufen haben. Trigger ist eine Funktion des Controllers selbst. Sie müssen also die Referenz des Controllers für den späteren Zugriff speichern. Antwort aktualisiert – Shawn