Date.getDay () javascript retorna dia errado

146

Oi eu sou novo em javascript Eu tenho esse código javascript

alert(DATE.value);
var d = new Date(DATE.value);
var year = d.getFullYear();
var month = d.getMonth();
var day = d.getDay();
alert(month);
alert(day);
if(2012 < year < 1971 | 1 > month+1 > 12 | 0 >day > 31){
    alert(errorDate);
    DATE.focus();
    return false;
}

Veja, por exemplo: DATE.value = "11/11/1991"

quando eu chamo alert(day);isso me mostra 3;
quando eu chamo alert(d);é retorna informações corretas.

Aleksei Bulgak
fonte
Segunda-feira ...
gdoron está apoiando Monica

Respostas:

330

use em .getDatevez de .getDay.

O valor retornado por getDay é um número inteiro correspondente ao dia da semana: 0 para domingo, 1 para segunda-feira, 2 para terça-feira e assim por diante.

Luca Rainone
fonte
154
Realmente idiota que o designer dessa função não a chamasse getDayOf Week. Não, isso teria sido óbvio demais.
precisa saber é o seguinte
41
@AndroidDev Concordo! Além disso .getDate, espera-se que seja devolvida a data completa, não apenas o dia.
47
Veja mais: a função getMonth retorna um número inteiro de 0 a 11, com 0 para janeiro e 11 para dezembro. Eles devem estar fumando coisas pesadas por lá
taralex
13
Aqui está ainda mais: getYear () na verdade o ano menos 1900!
Guilhem Fry
Design totalmente incongruente ~Date.getYear() okay, Date.getMonth() okay, Date.getDate() what?
Eddie B
8

getDay()lhe dará o dia da semana. Você está procurando getDate().

Ash Burlaczenko
fonte
5

Eu tive um problema parecido. date.getMonth()retorna um índice que varia de 0 to 11. Janeiro é 0. Se você criar um novo date()objeto e quiser obter informações sobre uma data de fantasia que não seja a data atual, você deverá diminuir apenas o mês 1.

Assim :

function getDayName () {
var year = 2016;
var month = 4;
var day = 11;

var date = new Date(year, month-1, day);
var weekday = new Array("sunday", "monday", "tuesday", "wednesday",
                    "thursday", "friday", "saturday");

return weekday[date.getDay()];
}
Sven Ya
fonte
Sven impressionante ... essa é a solução para o meu, menos um na mariposa ... obrigado.
Juanram0n
1
function formatDate(date, callback)
{
var weekday = new Array("Sunday", "Monday", "Tuesday", "Wednesday",     "Thursday", "Friday", "Saturday");
var day = weekday[date.getDay()];
console.log('day',day);
var d = date.getDate();
var hours = date.getHours();
ampmSwitch = (hours > 12) ? "PM" : "AM";
if (hours > 12) {
    hours -= 12;

}
else if (hours === 0) {
    hours = 12;
}
var m = date.getMinutes();
var months = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"];
var month = months[date.getMonth()];
var year = date.getFullYear();
newdate = day + ', ' + month + ' ' + d + ',' + year + ' at ' + hours + ":" + m + " " + ampmSwitch
callback(newdate)
}

e ligue com este código

date="Fri Aug 26 2016 18:06:01 GMT+0530 (India Standard Time)"
formatDate(date,function(result){
   console.log('Date=',result);
 });
Alex
fonte
1

A partir de agora, você provavelmente deseja usar as seguintes funções abaixo para objetos Data:

    function dayOf(date)
    {
        return date.getDate();
    }

    function monthOf(date)
    {
        return date.getMonth() + 1;
    }

    function yearOf(date)
    {
        return date.getYear() + 1900;
    }

    function weekDayOf(date)
    {
        return date.getDay() + 1;
    }
    
    var date = new Date("5/15/2020");
    console.log("Day: " + dayOf(date));
    console.log("Month: " + monthOf(date));
    console.log("Year: " + yearOf(date));

user13710070
fonte