Why do I have problems to fetch users name in javascript?












1














I am working on a Javascript, HTML and CSS proyect. What I want is to get the name of a user using its Id. I use fetch to do that but I am getting some problems.



function getUserName(userId) {
let userTemp = window.API_HOST + '/users/' + userId;
return fetch(userTemp, {
headers: { authorization: localStorage.access_token },
})
.then(response => response.json())
.then(response => {
console.log('El nombre es: ' + response.name);
return response.name;
});
}


The problem here is that response.name is a promise object and not the actual name. I tried to use stringify but it did not work. Any suggestions?



EDIT:
I need to call that function in a place like this:



function showOffer(newOffer) {
if (newOffer.user_id === JSON.parse(localStorage.current_user)._id) {
const wrapper = document.createElement('div');
wrapper.className = 'wrap';
const prodHolder = document.getElementById('demo').appendChild(wrapper);

const offerBidderId = document.createElement('p');
const offerBidderIdText = document.createTextNode(
'Bidder id: ' + getUserName(newOffer.bidder_id),
);
console.log('New offer bidder id ' + newOffer.bidder_id);
offerBidderId.appendChild(offerBidderIdText);
wrapper.appendChild(offerBidderId);
....
}


Maybe here is the problem?










share|improve this question
























  • can you give an example of what userId might contain as a value?
    – Ahmad
    Nov 21 '18 at 8:08










  • If the response.name is type of promise as you said then you would have to use .then method to access its value
    – Joven28
    Nov 21 '18 at 8:09












  • @Ahmad the userId is just a long integer
    – Mauricio Estevez
    Nov 21 '18 at 8:11










  • If it's a promise, you certainly should do something like : userId.then(function(someParameter) { console.log(someParameter); });
    – csblo
    Nov 21 '18 at 8:14










  • Maybe this will help: stackoverflow.com/questions/14220321/…
    – Oram
    Nov 21 '18 at 8:21
















1














I am working on a Javascript, HTML and CSS proyect. What I want is to get the name of a user using its Id. I use fetch to do that but I am getting some problems.



function getUserName(userId) {
let userTemp = window.API_HOST + '/users/' + userId;
return fetch(userTemp, {
headers: { authorization: localStorage.access_token },
})
.then(response => response.json())
.then(response => {
console.log('El nombre es: ' + response.name);
return response.name;
});
}


The problem here is that response.name is a promise object and not the actual name. I tried to use stringify but it did not work. Any suggestions?



EDIT:
I need to call that function in a place like this:



function showOffer(newOffer) {
if (newOffer.user_id === JSON.parse(localStorage.current_user)._id) {
const wrapper = document.createElement('div');
wrapper.className = 'wrap';
const prodHolder = document.getElementById('demo').appendChild(wrapper);

const offerBidderId = document.createElement('p');
const offerBidderIdText = document.createTextNode(
'Bidder id: ' + getUserName(newOffer.bidder_id),
);
console.log('New offer bidder id ' + newOffer.bidder_id);
offerBidderId.appendChild(offerBidderIdText);
wrapper.appendChild(offerBidderId);
....
}


Maybe here is the problem?










share|improve this question
























  • can you give an example of what userId might contain as a value?
    – Ahmad
    Nov 21 '18 at 8:08










  • If the response.name is type of promise as you said then you would have to use .then method to access its value
    – Joven28
    Nov 21 '18 at 8:09












  • @Ahmad the userId is just a long integer
    – Mauricio Estevez
    Nov 21 '18 at 8:11










  • If it's a promise, you certainly should do something like : userId.then(function(someParameter) { console.log(someParameter); });
    – csblo
    Nov 21 '18 at 8:14










  • Maybe this will help: stackoverflow.com/questions/14220321/…
    – Oram
    Nov 21 '18 at 8:21














1












1








1







I am working on a Javascript, HTML and CSS proyect. What I want is to get the name of a user using its Id. I use fetch to do that but I am getting some problems.



function getUserName(userId) {
let userTemp = window.API_HOST + '/users/' + userId;
return fetch(userTemp, {
headers: { authorization: localStorage.access_token },
})
.then(response => response.json())
.then(response => {
console.log('El nombre es: ' + response.name);
return response.name;
});
}


The problem here is that response.name is a promise object and not the actual name. I tried to use stringify but it did not work. Any suggestions?



EDIT:
I need to call that function in a place like this:



function showOffer(newOffer) {
if (newOffer.user_id === JSON.parse(localStorage.current_user)._id) {
const wrapper = document.createElement('div');
wrapper.className = 'wrap';
const prodHolder = document.getElementById('demo').appendChild(wrapper);

const offerBidderId = document.createElement('p');
const offerBidderIdText = document.createTextNode(
'Bidder id: ' + getUserName(newOffer.bidder_id),
);
console.log('New offer bidder id ' + newOffer.bidder_id);
offerBidderId.appendChild(offerBidderIdText);
wrapper.appendChild(offerBidderId);
....
}


Maybe here is the problem?










share|improve this question















I am working on a Javascript, HTML and CSS proyect. What I want is to get the name of a user using its Id. I use fetch to do that but I am getting some problems.



function getUserName(userId) {
let userTemp = window.API_HOST + '/users/' + userId;
return fetch(userTemp, {
headers: { authorization: localStorage.access_token },
})
.then(response => response.json())
.then(response => {
console.log('El nombre es: ' + response.name);
return response.name;
});
}


The problem here is that response.name is a promise object and not the actual name. I tried to use stringify but it did not work. Any suggestions?



EDIT:
I need to call that function in a place like this:



function showOffer(newOffer) {
if (newOffer.user_id === JSON.parse(localStorage.current_user)._id) {
const wrapper = document.createElement('div');
wrapper.className = 'wrap';
const prodHolder = document.getElementById('demo').appendChild(wrapper);

const offerBidderId = document.createElement('p');
const offerBidderIdText = document.createTextNode(
'Bidder id: ' + getUserName(newOffer.bidder_id),
);
console.log('New offer bidder id ' + newOffer.bidder_id);
offerBidderId.appendChild(offerBidderIdText);
wrapper.appendChild(offerBidderId);
....
}


Maybe here is the problem?







javascript






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 21 '18 at 8:27







Mauricio Estevez

















asked Nov 21 '18 at 8:07









Mauricio EstevezMauricio Estevez

7319




7319












  • can you give an example of what userId might contain as a value?
    – Ahmad
    Nov 21 '18 at 8:08










  • If the response.name is type of promise as you said then you would have to use .then method to access its value
    – Joven28
    Nov 21 '18 at 8:09












  • @Ahmad the userId is just a long integer
    – Mauricio Estevez
    Nov 21 '18 at 8:11










  • If it's a promise, you certainly should do something like : userId.then(function(someParameter) { console.log(someParameter); });
    – csblo
    Nov 21 '18 at 8:14










  • Maybe this will help: stackoverflow.com/questions/14220321/…
    – Oram
    Nov 21 '18 at 8:21


















  • can you give an example of what userId might contain as a value?
    – Ahmad
    Nov 21 '18 at 8:08










  • If the response.name is type of promise as you said then you would have to use .then method to access its value
    – Joven28
    Nov 21 '18 at 8:09












  • @Ahmad the userId is just a long integer
    – Mauricio Estevez
    Nov 21 '18 at 8:11










  • If it's a promise, you certainly should do something like : userId.then(function(someParameter) { console.log(someParameter); });
    – csblo
    Nov 21 '18 at 8:14










  • Maybe this will help: stackoverflow.com/questions/14220321/…
    – Oram
    Nov 21 '18 at 8:21
















can you give an example of what userId might contain as a value?
– Ahmad
Nov 21 '18 at 8:08




can you give an example of what userId might contain as a value?
– Ahmad
Nov 21 '18 at 8:08












If the response.name is type of promise as you said then you would have to use .then method to access its value
– Joven28
Nov 21 '18 at 8:09






If the response.name is type of promise as you said then you would have to use .then method to access its value
– Joven28
Nov 21 '18 at 8:09














@Ahmad the userId is just a long integer
– Mauricio Estevez
Nov 21 '18 at 8:11




@Ahmad the userId is just a long integer
– Mauricio Estevez
Nov 21 '18 at 8:11












If it's a promise, you certainly should do something like : userId.then(function(someParameter) { console.log(someParameter); });
– csblo
Nov 21 '18 at 8:14




If it's a promise, you certainly should do something like : userId.then(function(someParameter) { console.log(someParameter); });
– csblo
Nov 21 '18 at 8:14












Maybe this will help: stackoverflow.com/questions/14220321/…
– Oram
Nov 21 '18 at 8:21




Maybe this will help: stackoverflow.com/questions/14220321/…
– Oram
Nov 21 '18 at 8:21












1 Answer
1






active

oldest

votes


















1














fetch returns always a Promise. So you have to handle it with then or async/await.



You can access it like this:



getUserName(1).then(name => {
console.log('El nombre es: ' + name);
});


or inside an async function:



async function access() {
const name = await getUserName(1);

console.log('El nombre es: ' + name);
}


Nice article about async functions: https://developers.google.com/web/fundamentals/primers/async-functions






share|improve this answer





















  • This was the answer that helped me the most
    – Mauricio Estevez
    Nov 21 '18 at 8:32











Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53407638%2fwhy-do-i-have-problems-to-fetch-users-name-in-javascript%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









1














fetch returns always a Promise. So you have to handle it with then or async/await.



You can access it like this:



getUserName(1).then(name => {
console.log('El nombre es: ' + name);
});


or inside an async function:



async function access() {
const name = await getUserName(1);

console.log('El nombre es: ' + name);
}


Nice article about async functions: https://developers.google.com/web/fundamentals/primers/async-functions






share|improve this answer





















  • This was the answer that helped me the most
    – Mauricio Estevez
    Nov 21 '18 at 8:32
















1














fetch returns always a Promise. So you have to handle it with then or async/await.



You can access it like this:



getUserName(1).then(name => {
console.log('El nombre es: ' + name);
});


or inside an async function:



async function access() {
const name = await getUserName(1);

console.log('El nombre es: ' + name);
}


Nice article about async functions: https://developers.google.com/web/fundamentals/primers/async-functions






share|improve this answer





















  • This was the answer that helped me the most
    – Mauricio Estevez
    Nov 21 '18 at 8:32














1












1








1






fetch returns always a Promise. So you have to handle it with then or async/await.



You can access it like this:



getUserName(1).then(name => {
console.log('El nombre es: ' + name);
});


or inside an async function:



async function access() {
const name = await getUserName(1);

console.log('El nombre es: ' + name);
}


Nice article about async functions: https://developers.google.com/web/fundamentals/primers/async-functions






share|improve this answer












fetch returns always a Promise. So you have to handle it with then or async/await.



You can access it like this:



getUserName(1).then(name => {
console.log('El nombre es: ' + name);
});


or inside an async function:



async function access() {
const name = await getUserName(1);

console.log('El nombre es: ' + name);
}


Nice article about async functions: https://developers.google.com/web/fundamentals/primers/async-functions







share|improve this answer












share|improve this answer



share|improve this answer










answered Nov 21 '18 at 8:23









PhilPhil

1,9411919




1,9411919












  • This was the answer that helped me the most
    – Mauricio Estevez
    Nov 21 '18 at 8:32


















  • This was the answer that helped me the most
    – Mauricio Estevez
    Nov 21 '18 at 8:32
















This was the answer that helped me the most
– Mauricio Estevez
Nov 21 '18 at 8:32




This was the answer that helped me the most
– Mauricio Estevez
Nov 21 '18 at 8:32


















draft saved

draft discarded




















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.





Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


Please pay close attention to the following guidance:


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53407638%2fwhy-do-i-have-problems-to-fetch-users-name-in-javascript%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Costa Masnaga

Fotorealismo

Sidney Franklin