it-swarm.com.de

Wie zeige ich das heutige Datum in Node.js Jade an?

Ich bin neu bei Node.js und Jade und habe versucht, #{Date.now()} zu verwenden, und es gibt mir Zahlen. Wie zeige ich das Datum im mm/dd/yy-Format an?

37
Vartan Arabyan

Sie können moment.js verwenden

Fügen Sie zunächst den lokalen Locals Ihrer Expressanwendung einen Moment hinzu

express = require('express');
...
app = express();
app.locals.moment = require('moment');

Dann können Sie Moment in einer Jade-Vorlage wie folgt verwenden:

p #{moment(Date.now()).format('MM/DD/YYYY')}

Moment nimmt Date.now() standardmäßig an, so dass Sie auch schreiben können:

p #{moment().format('MM/DD/YYYY')}

Quellen:

73
Yves M.

Oder Sie können die Bibliothek moment.js verwenden, um Datumsangaben zu bearbeiten und sie entsprechend Ihren Anforderungen zu formatieren

8
zemirco

Das ist alt, aber ich mache folgendes:

return (new Date()).toLocaleDateString()

Gibt ein Datum im Format 'mm/tt/jjjj' zurück. Es sind keine zusätzlichen Bibliotheken erforderlich.

6
Gadi

Ich habe eigentlich angefangen, date-util zu verwenden, das aus zwei Teilen sowohl clientseitig als auch serverseitig besteht.

URL https://github.com/JerrySievert/node-date-utils

Verwenden innerhalb eines Browsers

<script type="text/javascript" src="date-utils.min.js"></script>

Verwendung mit Node.js

$ npm install date-utils

require('date-utils');

Hinweis: Dies hat in REPL vor Node.js 0.6 nicht funktioniert, da Node.js den Kontext in REPL behandelt.

Statische Methoden

Date.today(); // today, 00:00:00
Date.yesterday(); // yesterday, 00:00:00    
Date.tomorrow(); // tomorrow, 00:00:00

Date.validateDay(day, year, month); // true/false whether a date is valid
Date.validateYear(year); // true/false whether a year is valid
Date.validateMonth(month); // true/false whether a month is valid
Date.validateHour(hour); // true/false whether an hour is valid
Date.validateMinute(minute); // true/false whether a minute is valid
Date.validateSecond(second); // true/false whether a second is valid
Date.validateMillisecond(millisecond); // true/false whether a millisecond is valid

Date.compare(date1, date2); // -1 if date1 is smaller than date2, 0 if equal, 1 if date2 is smaller than date1
Date.equals(date1, date2); // true/false if date1 is equal to date2

Date.getDayNumberFromName(name); // su/Sun/sunday - 0, mo/mon/monday - 1, etc
Date.getMonthNumberFromName(name); // jan/january - 0, feb/february - 1, etc
Date.isLeapYear(year); // true/false whether the year is a leap year
Date.getDaysInMonth(monthNumber); // number of days in the month

Instanzmethoden

d.clone(); // returns a new copy of date object set to the same time
d.getMonthAbbr(); // abreviated month name, Jan, Feb, etc
d.getMonthName(); // fill month name, January, February, etc
d.getUTCOffset(); // returns the UTC offset
d.getOrdinalNumber(); // day number of the year, 1-366 (leap year)
d.clearTime(); // sets time to 00:00:00
d.setTimeToNow(); // sets time to current time
d.toFormat(format); // returns date formatted with:
  // YYYY - Four digit year
  // MMMM - Full month name. ie January
  // MMM  - Short month name. ie Jan
  // MM   - Zero padded month ie 01
  // M    - Month ie 1
  // DDDD - Full day or week name ie Tuesday 
  // DDD  - Abbreviated day of the week ie Tue
  // DD   - Zero padded day ie 08
  // D    - Day ie 8
  // HH24 - Hours in 24 notation ie 18
  // HH   - Padded Hours ie 06
  // H    - Hours ie 6
  // MI   - Padded Minutes
  // SS   - Padded Seconds
  // PP   - AM or PM
  // P    - am or pm
d.toYMD(separator); // returns YYYY-MM-DD by default, separator changes delimiter

d.between(date1, date2); // true/false if the date/time is between date1 and date2
d.compareTo(date); // -1 if date is smaller than this, 0 if equal, 1 if date is larger than this
d.equals(date); // true/false, true if dates are equal
d.isBefore(date); // true/false, true if this is before date passed
d.isAfter(date); // true/false, true if this is after date passed
d.getDaysBetween(date); // returns number of full days between this and passed
d.getHoursBetween(date); // returns number of hours days between this and passed
d.getMinutesBetween(date); // returns number of full minutes between this and passed
d.getSecondsBetween(date); // returns number of full seconds between this and passed

d.add({ milliseconds: 30,
        minutes: 1,
        hours: 4,
        seconds: 30,
        days: 2,
        weeks: 1,
        months: 3,
        years: 2}); // adds time to existing time

d.addMilliseconds(number); // add milliseconds to existing time
d.addSeconds(number); // add seconds to existing time
d.addMinutes(number); // add minutes to existing time
d.addHours(number); // add hours to existing time
d.addDays(number); // add days to existing time
d.addWeeks(number); // add weeks to existing time
d.addMonths(number); // add months to existing time
d.addYears(number); // add years to existing time
4
Vartan Arabyan

Sie müssen die Methoden des Date-Objekts verwenden, um das zu erreichen, wonach Sie suchen. Siehe https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/Date

Der folgende Code sollte beispielsweise das tun, was Sie brauchen:

var dateNow = new Date();
var dd = dateNow.getDate();
var monthSingleDigit = dateNow.getMonth() + 1,
    mm = monthSingleDigit < 10 ? '0' + monthSingleDigit : monthSingleDigit;
var yy = dateNow.getFullYear().toString().substr(2);

var formattedDate = mm + '/' + dd + '/' + yy;

Wenn Sie beispielsweise Jade mit Express und Node verwenden, könnten Sie Folgendes tun:

res.render('jadeTemplateName', { 
    dateNow: function() {
        var dateNow = new Date();
        var dd = dateNow.getDate();
        var monthSingleDigit = dateNow.getMonth() + 1,
            mm = monthSingleDigit < 10 ? '0' + monthSingleDigit : monthSingleDigit;
        var yy = dateNow.getFullYear().toString().substr(2);

        return (mm + '/' + dd + '/' + yy);
    } 
})

und sagen Sie in Ihrer Jade-Vorlage, ob Sie das Datum zu einer Zeitspanne hinzufügen möchten:

span Today's date is #{dateNow()}
1
rbginge

Ich habe eine Lösung gefunden 1.Erstelle eine Funktion in pug mit - syntax 2.pass die Variable an die Funktion, wenn pug.js Variablen an die Pug-Vorlage bindet

    -function prettyDate(dateString){
                        -var date = new Date(dateString);
                        -var d = date.getDate();
                        -var monthNames = [ "Jan", "Feb", "Mar", "Apr", "May", "Jun","Jul", "Aug", "Sep", "Oct", "Nov", "Dec" ];
                        -var m = monthNames[date.getMonth()];
                        -var y = date.getFullYear();
                        -return d+' '+m+' '+y;
                    -}
3.span.post-date #{prettyDate(val.date)};
0
user6016061

fügen Sie die Klasse .post-date einem Tag hinzu, der das Datum enthält

document.addEventListener('DOMContentLoaded', function() {
    var list = document.getElementsByClassName('post-date');
                // get the number of selected elements

                // iterate over elements and output their HTML content
                for (var i=0; i<list.length; i++){
                    //console.log(list[i].innerHTML);
                    var string=list[i].innerHTML;
                    var length = 15;
                    var trimmedString = string.substring(0, length);
                    list[i].innerHTML=trimmedString ;
                }

})
0
user6016061