getmonth javascript с ведущим нулем

Javascript добавить лидирующие нули на сегодняшний день

Я создал этот скрипт для расчета даты за 10 дней в формате дд / мм / гггг:

Мне нужно, чтобы дата добавлялась с ведущими нулями в компоненте день и месяц путем добавления этих правил в скрипт. Я не могу заставить его работать.

Если бы кто-то мог показать мне, где вставить их в сценарий, я был бы очень благодарен.

24 ответа

РЕДАКТИРОВАТЬ:

Поэтому, несмотря ни на что, мы можем добавить «0» к дню или месяцу и просто запросить последние два, так как это всегда те два, которые мы хотим.

Попробуйте это для базовой функции, библиотеки не требуются

Как предлагает @Джон Хенкель, начать использовать toISOString () метод упрощает работу

Что я хотел бы сделать, это создать свой собственный помощник по дате, который выглядит следующим образом:

Следующее предназначено для извлечения конфигурации, подключения к Date.protoype и применения конфигурации.

Кажется, это работает довольно быстро: 0,016 мс

Вот очень простой пример того, как вы можете справиться с этой ситуацией.

Другой вариант, используя встроенную функцию для заполнения (но в результате получается довольно длинный код!):

И еще, манипулируя строками с помощью регулярных выражений:

Я обернул правильный ответ на этот вопрос в функцию, которая может добавлять несколько ведущих нулей, но по умолчанию добавляет 1 ноль.

Для работы только с числами, не более 2 цифр, это тоже подход:

Сделайте свою жизнь проще и используйте Moment.js пример кода:

Существует другой подход для решения этой проблемы, использующий slice в JavaScript.

datestring возвращаемая дата в ожидаемом формате: 2019-09-01

Другой подход заключается в использовании dateformat библиотеки: https://github.com/felixge/node-dateformat

Вы можете использовать троичный оператор для форматирования даты как «если».

Изменить: Забыл, что getMonth начинается с 0, поэтому добавил +1, чтобы учесть это. Конечно, вы также можете просто сказать d.getMonth () 5

Я нашел самый короткий способ сделать это:

Добавит начальные нули ко всем одиночным, однозначным

Источник

Дата и Время

Материал на этой странице устарел, поэтому скрыт из оглавления сайта.

Более новая информация по этой теме находится на странице https://learn.javascript.ru/date.

Для работы с датой и временем в JavaScript используются объекты Date.

Создание

Для создания нового объекта типа Date используется один из синтаксисов:

Создаёт объект Date с текущей датой и временем:

Если единственный аргумент – строка, используется вызов Date.parse (см. далее) для чтения даты из неё.

new Date(year, month, date, hours, minutes, seconds, ms)

Дату можно создать, используя компоненты в местной временной зоне. Для этого формата обязательны только первые два аргумента. Отсутствующие параметры, начиная с hours считаются равными нулю, а date – единице.

Год year должен быть из 4 цифр.

Отсчёт месяцев month начинается с нуля 0.

Дата задана с точностью до миллисекунд:

Получение компонентов даты

Для доступа к компонентам даты-времени объекта Date используются следующие методы:

getFullYear() Получить год (из 4 цифр) getMonth() Получить месяц, от 0 до 11. getDate() Получить число месяца, от 1 до 31. getHours(), getMinutes(), getSeconds(), getMilliseconds() Получить соответствующие компоненты.

Дополнительно можно получить день недели:

getDay() Получить номер дня в неделе. Неделя в JavaScript начинается с воскресенья, так что результат будет числом от 0(воскресенье) до 6(суббота).

Все методы, указанные выше, возвращают результат для местной временной зоны.

Если ваше локальное время сдвинуто относительно UTC, то следующий код покажет разные часы:

Кроме описанных выше, существуют два специальных метода без UTC-варианта:

Возвращает разницу между местным и UTC-временем, в минутах.

Установка компонентов даты

Следующие методы позволяют устанавливать компоненты даты и времени:

Автоисправление даты

Неправильные компоненты даты автоматически распределяются по остальным.

Например, нужно увеличить на 2 дня дату «28 февраля 2011». Может быть так, что это будет 2 марта, а может быть и 1 марта, если год високосный. Но нам обо всем этом думать не нужно. Просто прибавляем два дня. Остальное сделает Date :

Также это используют для получения даты, отдалённой от имеющейся на нужный промежуток времени. Например, получим дату на 70 секунд большую текущей:

Можно установить и нулевые, и даже отрицательные компоненты. Например:

Преобразование к числу, разность дат

Когда объект Date используется в числовом контексте, он преобразуется в количество миллисекунд:

Важный побочный эффект: даты можно вычитать, результат вычитания объектов Date – их временная разница, в миллисекундах.

Это используют для измерения времени:

Бенчмаркинг

Допустим, у нас есть несколько вариантов решения задачи, каждый описан функцией.

Как узнать, какой быстрее?

Для примера возьмём две функции, которые бегают по массиву:

Для правильного бенчмаркинга функция запускается много раз, чтобы сам тест занял существенное время. Это сведёт влияние помех к минимуму. Сложную функцию можно запускать 100 раз, простую – 1000 раз…

Померяем, какая из функций быстрее:

Теперь представим себе, что во время первого бенчмаркинга bench(walkIn) компьютер что-то делал параллельно важное (вдруг) и это занимало ресурсы, а во время второго – перестал. Реальная ситуация? Конечно реальна, особенно на современных ОС, где много процессов одновременно.

Гораздо более надёжные результаты можно получить, если весь пакет тестов прогнать много раз.

В современных браузерах (кроме IE9-) вызов performance.now() возвращает количество миллисекунд, прошедшее с начала загрузки страницы. Причём именно с самого начала, до того, как загрузился HTML-файл, если точнее – с момента выгрузки предыдущей страницы из памяти.

Так что это время включает в себя всё, включая начальное обращение к серверу.

Возвращаемое значение измеряется в миллисекундах, но дополнительно имеет точность 3 знака после запятой (до миллионных долей секунды!), поэтому можно использовать его и для более точного бенчмаркинга в том числе.

Для измерения с одновременным выводом результатов в консоли есть методы:

Параметр «метка» используется для идентификации таймера, чтобы можно было делать много замеров одновременно и даже вкладывать измерения друг в друга.

При запуске этого примера нужно открыть консоль, иначе вы ничего не увидите.

Современные интерпретаторы JavaScript делают массу оптимизаций, например:

Эти оптимизации могут влиять на результаты тестов, поэтому измерять скорость базовых операций JavaScript («проводить микробенчмаркинг») до того, как вы изучите внутренности JavaScript-интерпретаторов и поймёте, что они реально делают на таком коде, не рекомендуется.

Форматирование и вывод дат

Во всех браузерах, кроме IE10-, поддерживается новый стандарт Ecma 402, который добавляет специальные методы для форматирования дат.

Пример с почти всеми параметрами даты и русским, затем английским (США) форматированием:

Вы сможете подробно узнать о них в статье Intl: интернационализация в JavaScript, которая посвящена этому стандарту.

Методы вывода без локализации:

toISOString() Возвращает дату в формате ISO Детали формата будут далее. Поддерживается современными браузерами, не поддерживается IE8-.

Если хочется иметь большую гибкость и кросс-браузерность, то также можно воспользоваться специальной библиотекой, например Moment.JS или написать свою функцию форматирования.

Разбор строки, Date.parse

Все современные браузеры, включая IE9+, понимают даты в упрощённом формате ISO 8601 Extended.

Источник

Дата и время

Встречайте новый встроенный объект: Date. Он содержит дату и время, а также предоставляет методы управления ими.

Например, его можно использовать для хранения времени создания/изменения, для измерения времени или просто для вывода текущей даты.

Создание

Для создания нового объекта Date нужно вызвать конструктор new Date() с одним из следующих аргументов:

Без аргументов – создать объект Date с текущими датой и временем:

Создать объект Date с временем, равным количеству миллисекунд (тысячная доля секунды), прошедших с 1 января 1970 года UTC+0.

Целое число, представляющее собой количество миллисекунд, прошедших с начала 1970 года, называется таймстамп (англ. timestamp).

Это – легковесное численное представление даты. Из таймстампа всегда можно получить дату с помощью new Date(timestamp) и преобразовать существующий объект Date в таймстамп, используя метод date.getTime() (см. ниже).

Датам до 1 января 1970 будут соответствовать отрицательные таймстампы, например:

Создать объект Date с заданными компонентами в местном часовом поясе. Обязательны только первые два аргумента.

Максимальная точность – 1 мс (до 1/1000 секунды):

Получение компонентов даты

Существуют методы получения года, месяца и т.д. из объекта Date :

getFullYear() Получить год (4 цифры) getMonth() Получить месяц, от 0 до 11. getDate() Получить день месяца, от 1 до 31, что несколько противоречит названию метода. getHours(), getMinutes(), getSeconds(), getMilliseconds() Получить, соответственно, часы, минуты, секунды или миллисекунды.

Кроме того, можно получить определённый день недели:

getDay() Вернуть день недели от 0 (воскресенье) до 6 (суббота). Несмотря на то, что в ряде стран за первый день недели принят понедельник, в JavaScript начало недели приходится на воскресенье.

Все вышеперечисленные методы возвращают значения в соответствии с местным часовым поясом.

Если ваш местный часовой пояс смещён относительно UTC, то следующий код покажет разные часы:

Помимо вышеприведённых методов, существуют два особых метода без UTC-варианта:

Для заданной даты возвращает таймстамп – количество миллисекунд, прошедших с 1 января 1970 года UTC+0.

Возвращает разницу в минутах между UTC и местным часовым поясом:

Установка компонентов даты

Следующие методы позволяют установить компоненты даты и времени:

Автоисправление даты

Неправильные компоненты даты автоматически распределяются по остальным.

Предположим, нам требуется увеличить дату «28 февраля 2016» на два дня. В зависимости от того, високосный это год или нет, результатом будет «2 марта» или «1 марта». Нам об этом думать не нужно. Просто прибавляем два дня. Объект Date позаботится об остальном:

Эту возможность часто используют, чтобы получить дату по прошествии заданного отрезка времени. Например, получим дату «спустя 70 секунд с текущего момента»:

Также можно установить нулевые или даже отрицательные значения. Например:

Преобразование к числу, разность дат

Если объект Date преобразовать в число, то получим таймстамп по аналогии с date.getTime() :

Важный побочный эффект: даты можно вычитать, в результате получаем разность в миллисекундах.

Этот приём можно использовать для измерения времени:

Date.now()

Если нужно просто измерить время, объект Date нам не нужен.

Данный метод используется из соображений удобства или когда важно быстродействие, например, при разработке игр на JavaScript или других специализированных приложений.

Вероятно, предыдущий пример лучше переписать так:

Бенчмаркинг

Будьте внимательны, если хотите точно протестировать производительность функции, которая зависит от процессора.

Например, сравним две функции, вычисляющие разницу между двумя датами: какая сработает быстрее?

Подобные вычисления, замеряющие производительность, также называют «бенчмарками» (benchmark).

Обе функции делают буквально одно и то же, только одна использует явный метод date.getTime() для получения даты в миллисекундах, а другая полагается на преобразование даты в число. Результат их работы всегда один и тот же.

Но какая функция быстрее?

Для начала можно запустить их много раз подряд и засечь разницу. В нашем случае функции очень простые, так что потребуется хотя бы 100000 повторений.

Вот это да! Метод getTime() работает ощутимо быстрее! Всё потому, что не производится преобразование типов, и интерпретаторам такое намного легче оптимизировать.

Замечательно, это уже что-то. Но до хорошего бенчмарка нам ещё далеко.

Представьте, что при выполнении bench(diffSubtract) процессор параллельно делал что-то ещё, также потребляющее ресурсы. А к началу выполнения bench(diffGetTime) он это уже завершил.

Достаточно реалистичный сценарий в современных многопроцессорных операционных системах.

В итоге у первого бенчмарка окажется меньше ресурсов процессора, чем у второго. Это может исказить результаты.

Для получения наиболее достоверных результатов тестирования производительности весь набор бенчмарков нужно запускать по нескольку раз.

Современные интерпретаторы JavaScript начинают применять продвинутые оптимизации только к «горячему коду», выполняющемуся несколько раз (незачем оптимизировать то, что редко выполняется). Так что в примере выше первые запуски не оптимизированы должным образом. Нелишним будет добавить предварительный запуск для «разогрева»:

Современные интерпретаторы JavaScript выполняют множество оптимизаций. Они могут повлиять на результаты «искусственных тестов» по сравнению с «нормальным использованием», особенно если мы тестируем что-то очень маленькое, например, работу оператора или встроенной функции. Поэтому если хотите серьёзно понять производительность, пожалуйста, изучите, как работают интерпретаторы JavaScript. И тогда вам, вероятно, уже не понадобятся микробенчмарки.

Отличный набор статей о V8 можно найти на http://mrale.ph.

Разбор строки с датой

Метод Date.parse(str) считывает дату из строки.

Источник

Javascript добавить ведущие нули на сегодняшний день

Я создал этот скрипт для расчета даты на 10 дней вперед в формате ДД / ММ / гггг:

мне нужно, чтобы дата появилась с ведущими нулями в компоненте дня и месяца, добавив эти правила в скрипт. Я не могу заставить его работать.

Если бы кто-нибудь мог показать мне, где вставить их в сценарий, я был бы очень признателен.

16 ответов:

EDIT:

так что, несмотря ни на что, мы можем добавить «0» в день или месяц, и просто попросите последние два, так как это всегда те два, которые мы хотим.

так что если MyDate.getMonth() возвращает 9 будет:

но если MyDate.getMonth() возвращает 10 будет:

и ниже он используется в контексте.

вы можете определить функцию «str_pad» (как в PHP):

Если вы хотите локализовать вывод даты по языку и вам нужны ведущие нули, решение выглядит по-другому:

кроме того, вы можете использовать 2-digit на летний вариант, тоже.

пока вы знаете локаль и хотите отобразить дату в удобочитаемой форме, я считаю, что это самый чистый способ выполнить эту работу.

к сожалению, IE10 и более ранние версии не поддерживают toLocaleDateString параметры.

для вас люди из будущего (ECMAScript 2017 и за его пределами)

решение

объяснение

пример

вы можете использовать тернарный оператор для форматирования даты как оператор «if».

было бы похоже на Оператор if, где если getDate() возвращает значение меньше 10, то возвращает ‘0’ + дату, или же возвращает дату, если больше 10 (так как нам не нужно добавлять ведущий 0). То же самое в течение месяца.

изменить: Забыл, что getMonth начинается с 0, поэтому добавил +1 для его учета. Из конечно, вы также можете просто сказать d.getMonth()

я завернул правильный ответ на этот вопрос в функцию, которая может добавить несколько ведущих нулей, но по умолчанию добавляет 1 ноль.

для работы только с числами и не более 2 цифр, это также подход:

сделать вашу жизнь проще и использовать момент.js пример кода:

Я нашел более короткий способ сделать это:

добавит ведущие нули ко всем одиноким, одиночным цифрам

следующие цели извлечь конфигурацию, крюк в Date.protoype и применить конфигурации.

я использовал Array для хранения кусков времени и когда я push() this как Date объект, он возвращает мне длину итерации. Когда я закончу, я могу использовать join на return значение.

это, кажется, работает довольно быстро: 0.016 МС

что бы я сделал, это создать свой собственный помощник даты, который выглядит так:

другой вариант, используя встроенную функцию, чтобы сделать заполнение (но в результате довольно длинный код!):

и еще, манипулируя строками с регулярными выражениями:

но имейте в виду, что один покажет год на start и в конец.

добавить некоторые отступы, чтобы разрешить ведущий ноль-где это необходимо-и конкатенации с помощью разделителя выбора в качестве строки.

Источник

Javascript добавить ведущие нули на сегодняшний день

Я создал этот script, чтобы рассчитать дату за 10 дней вперед в формате dd/mm/yyyy:

Мне нужно указать дату с начальными нулями в компоненте day и month, добавив эти правила в script. Кажется, я не могу заставить его работать.

Если кто-то может показать мне, куда их вставить в script, я был бы очень благодарен.

18 ответов

EDIT:

Итак, неважно, мы можем добавить «0» в день или месяц, и просто попросить последние два, так как они всегда те, которые мы хотим.

Вот пример из Документов объектов даты в Mozilla Developer Network с использованием специальной функции «pad», без необходимости продления Javascript Number опытный образец. Удобной функцией, которую они дают в качестве примера, является

И ниже он используется в контексте.

Вы можете определить функцию «str_pad» (как в php):

Когда вы пропустите первый аргумент, он определит язык браузера. Кроме того, вы также можете использовать 2-digit опцию года.

Если вам не нужно поддерживать старые браузеры, такие как IE10, это самый чистый способ сделать эту работу. IE10 и более низкие версии не будут понимать аргумент параметров.

Для вас, людей из будущего (ECMAScript 2017 и далее)

Решение

Explaination

пример

Я нашел более короткий способ сделать это:

добавит ведущие нули ко всем одиноким, одиночным цифрам

Вы можете использовать трехмерный оператор для форматирования даты как оператора «if».

будет похож на оператор if, где, если getDate() возвращает значение меньше 10, затем верните «0» + «Дата» или верните дату, если она больше 10 (поскольку нам не нужно добавьте начало 0). То же самое касается месяца.

Изменить: Забыл, что getMonth начинается с 0, поэтому добавил +1 для его учета. Конечно, вы могли бы просто сказать d.getMonth() Hellojeffy 13 март 2014, в 22:34

Сделайте вашу жизнь проще и используйте Moment.js некоторый пример кода:

Я завернул правильный ответ этого вопроса в функцию, которая может добавить несколько ведущих ноль, но по умолчанию добавляет 1 ноль.

для работы с номерами и не более 2-х цифр, это также подход:

Другой вариант, используя встроенную функцию для заполнения (но в результате получается довольно длинный код!):

И еще, манипулируя строками с регулярными выражениями:

Но имейте в виду, что в начале и в конце дня будет показан год.

Как говорит @Джон Хенкель, начало использования метода toISOString() облегчает задачу

Источник

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *