Javascript считывает мою строку даты как число, когда я передаю свои данные с помощью ModelAndView (Spring)

Я использую Spring Boot framework и Thymeleaf для создания своей программы.

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

@RequestMapping(value = "/search")
public ModelAndView search() {
    ModelAndView view = new ModelAndView("exchangerate");
    List<String> timeList = new ArrayList<>();
    timeList.add("2017/07/21");
    timeList.add("2017/07/24");
    timeList.add("2017/07/25");
    timeList.add("2017/07/26");
    view.addObject("timeList",timeList);
    return view;        
}

А также

<script>
    var yAxis = [[${timeList}]];
    var yAxis2 = ['2017-07-21', '2017-07-24', '2017-07-25', '2017-07-26'];
    console.info(yAxis);
    console.info(yAxis2);
</script>

В консоли я вижу

[13.721088435374151, 12.005952380952381, 11.525714285714287, 11.082417582417584]

["2017-07-21", "2017-07-24", "2017-07-25", "2017-07-26"]

Так что я предполагаю, что yAxix читается как число.

Что мне делать, если я хочу использовать yAxis в формате строки или даты?

Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
1
0
46
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Понять, почему это происходит, довольно просто.

Когда вы отправляете его в JavaScript для обработки, JSON.parse фактически интерпретирует ваши даты как (2017/07)/21, который оценивается с плавающей десятичной дробью, которую вы видите. Это означает, что ваши даты не преобразуются в строки для JSON перед отправкой дальше.

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

Ответ принят как подходящий

Я считаю, что используя:

<script th:inline = "javascript">

исправлю это. Он должен выводить его как список строк в кавычках.

Другие вопросы по теме