Я работаю над таблицей, и мне нужно создать собственный соединитель для веб-данных. Я написал его, и он отлично работает на Chrome. Но когда я использую его в Tableau я получаю ошибку foolowing:Parsing Json with Promise in Tableau
ReferenceError: Can't find variable: Promise file: http://localhost:9000/json-connector line: 246
Мой соединитель разделен на две части. Первая часть вызовет веб-службу, чтобы получить список получателей и заполнить два списка своими именами. Вторая часть вызовет другую веб-службу, чтобы получить все пути между двумя выбранными пунктами назначения.
Ошибка произошла, когда я хочу получить первый список. Я хочу настаивать на том, что он работает на хроме, но не в таблице.
Часть кода, где произошла ошибка:
var getJSON = function(url) {
return new Promise(function(resolve, reject) {
var xhr = new XMLHttpRequest();
xhr.open('get', url, true);
xhr.responseType = 'json';
xhr.onload = function() {
var status = xhr.status;
if (status == 200) {
resolve(xhr.response);
} else {
console.log("Something went wrong with the destination")
reject(status);
}
};
xhr.send();
});
};
Я думаю, что таблица не поддерживает обещание. Но я не знаю, как сделать работу. Большое спасибо за вашу помощь !
Это, как я использую эту функцию:
getJSON('http://localhost:9000/stations').then(function(data) {
//alert('Your Json result is: ' + data.result); //you can comment this, i used it to debug
//result.innerText = JSON.stringify(data); //display the result in an HTML element
console.log("starting parsing on : " + data.length);
var listArrival = document.getElementById('Arrival'); //get the list where you want to add options
var listDeparture = document.getElementById('Departure');
if(listArrival == null || listDeparture == null) console.error("Impossible to retrieve the list")
var op;
var addedStations = [];
for(var i = 0; i < data.length ; i++){
var obj = data[i];
var overflowControler = 0;
for(var key in obj){
console.log(key + '=' + obj[key]);
if(key == 'name' && addedStations.indexOf(obj[key]) == -1){
op = new Option(obj[key], obj['nlc'], true);
op2 = new Option(obj[key], obj['nlc'], true);
if(op == null) console.error("Impossible to create the new option")
listArrival.add(op);
listDeparture.add(op2);
addedStations.push(obj[key]);
}
overflowControler ++;
if(overflowControler > maxLengthOfEachRecordFromJson) break; // overflow control
}
if(i > maxStationsRecordNumberFromJson) break; //overflow control
}
}, function(status) { //error detection....
alert('Something went wrong.');
});
Можете ли вы включить внешнюю библиотеку Promise в свой проект tableau (если это правильное имя, я мало что знаю о таблице)? – Tomalak
Я могу включить некоторую библиотеку в свой js да! Пример: –
Затем включите один из них: https://cdnjs.com/#q=promise - I ' d пойти на 'bluebird', но если все, что вам нужно - это основные обещания ES6, тем легче будет выполнять« es6-prom' ». – Tomalak