• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

brak reakcji funkcji switch w js

Hosting forpsi easy 1 pln
0 głosów
114 wizyt
pytanie zadane 19 listopada w JavaScript przez Piotrek2713 Gaduła (4,230 p.)

Tak wygląda cały kod js

const date = document.querySelector('.date');
const time = document.querySelector('.time');

function dateAndTime()
{
    let dateToShow = new Date();

    let day = dateToShow.getDate();
    let month = dateToShow.getMonth();
    let year = dateToShow.getFullYear();

    let hour = dateToShow.getHours();
    let minutes = dateToShow.getMinutes();
    let seconds = dateToShow.getSeconds();

    switch (month)
    {
        case 0: 'Stycznia';
        break;
        case 1: 'Lutego';
        break;
        case 2: 'Marca';
        break;
        case 3: 'Kwietnia';
        break;
        case 4: 'Maja';
        break;
        case 5: 'Czerwca';
        break;
        case 6: 'Lipca';
        break;
        case 7: 'Sierpnia';
        break;
        case 8: 'Września';
        break;
        case 9: 'Października';
        break;
        case 10: 'Listopada';
        break;
        case 11: 'Grudnia';
        break;
        default: 'Nie wczytano miesiąca';
    }
    date.innerHTML = day + " " + month + " " + year;
}
dateAndTime();

Data wyświetla się na stronie, ale zamiast 19 Listopada 2023 mam 19 10 2023

Jak to naprawić?

4 odpowiedzi

0 głosów
odpowiedź 19 listopada przez VBService Ekspert (246,070 p.)
wybrane 23 listopada przez Piotrek2713
 
Najlepsza

Możesz zamiast switch-a użyć tablicy.

//const date = document.querySelector('.date');
//const time = document.querySelector('.time');

function dateAndTime()
{
  const months = [ 'Stycznia', 'Lutego', 'Marca', 'Kwietnia', 'Maja', 'Czerwca',
                   'Lipca', 'Sierpnia', 'Września', 'Października', 'Listopada', 'Grudnia' ];
  const dateToShow = new Date();

  const day = dateToShow.getDate();
  const month = dateToShow.getMonth();
  const year = dateToShow.getFullYear();

  const hour = dateToShow.getHours();
  const minutes = dateToShow.getMinutes();
  const seconds = dateToShow.getSeconds(); 

  //date.textContent = day + ' ' + months[month] + ' ' + year;
  console.log(day + ' ' + months[month] + ' ' + year);
}

dateAndTime();

 

+1 głos
odpowiedź 19 listopada przez Comandeer Guru (596,500 p.)

Bo nigdzie nie przypisujesz wyniku ze switcha i ostatecznie wyświetlasz oryginalną zmienną month. W każdym case musiałbyś np. nadpisać zmienną month nową wartością:

case 10:
    month = 'Listopada';
break;

BTW datę po polsku można ogarnąć też przy pomocy Intl.DateTimeFormat.

+1 głos
odpowiedź 23 listopada przez DamianoSmok Początkujący (280 p.)
Dziwny sposób na poradzenie sobie z datą. Ale zwróć uwagę, że po tym case: piszesz normalny kod JS, więc musiałbyś wartość przypisać do zmiennej. Przejrzyj sobie na spokojnie jak działa switch.
0 głosów
odpowiedź 24 listopada przez RadoslawER Użytkownik (540 p.)
Mam widoczny problem w kodzie JavaScript.

Warto dodać zero przed jednocyfrowymi dniami, miesiącami i godzinami, aby zachować jednolitość wyświetlania. Na przykład, jeśli minutes lub secondu są mniejsze niż 10, dodaj zero przed nimi.

Przemyśl też, czy przypadkiem nie chcesz dodać do miesiąca 1, ponieważ w JavaScript indeksy miesięcy zaczynają się od zera. Czyli, jeśli masz Marca, to tak naprawdę jest to miesiąc o indeksie 2.

Spróbuj wprowadzić te poprawki, a powinno działać poprawnie. Jakbyś miał jakiekolwiek pytania lub potrzebował więcej pomocy, pytaj śmiało.

Podobne pytania

0 głosów
2 odpowiedzi 390 wizyt
pytanie zadane 7 listopada 2017 w C i C++ przez Mateusz Cybulski Nowicjusz (120 p.)
0 głosów
1 odpowiedź 149 wizyt
pytanie zadane 25 marca 2021 w C i C++ przez fsfxvcxv Obywatel (1,160 p.)
0 głosów
0 odpowiedzi 208 wizyt
pytanie zadane 16 października 2016 w C i C++ przez Jakub Olszak Użytkownik (540 p.)

92,133 zapytań

140,789 odpowiedzi

317,829 komentarzy

61,457 pasjonatów

Advent of Code 2023

Top 15 użytkowników

  1. 1886p. - Łukasz Eckert
  2. 1856p. - Dawid128
  3. 1844p. - CC PL
  4. 1844p. - Marcin Putra
  5. 1818p. - rafalszastok
  6. 1775p. - Mikbac
  7. 1760p. - rucin93
  8. 1741p. - sefirek
  9. 1682p. - Adrian Wieprzkowicz
  10. 1652p. - Eryk Andrzejewski
  11. 1644p. - jaroslawroszyk
  12. 1565p. - Rafał Trójniak
  13. 1467p. - dia-Chann
  14. 1445p. - nidomika
  15. 1424p. - ssynowiec
Szczegóły i pełne wyniki

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Uwaga - w dniach od 02.12 do 08.12 trwają Mikołajki (książki drukowane mają rabat -35%, ebooki do -45%). Zaś dodatkowy, specjalny kod zniżkowy: HELMIKOLAJ-10 dla naszych Widzów zapewni Wam oszczędność -10zł dla zamówień powyżej 70zł! Warto korzystać!

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...