Как использовать URL-адреса HTML5 с SpringBoot и VueJS

У меня есть следующая настройка моего проекта Vue ...

import UploadComponent from './Upload.vue'
import MainPageComponent from './MainPage.vue'
...
const router = new VueRouter({
    routes: [
        { path: '/', component: MainPageComponent },
        { path: '/upload', component: UploadComponent }
    ]
});
...
let App = { router };
new Vue(App).$mount('#km-viewport');

Тогда в моем html у меня есть ...

<div id = "km-viewport">
    <jg-app> </jg-app>
</div>

а внутри jg-app у меня есть следующий шаблон ...

<md-app-content>
    <router-view></router-view>
</md-app-content>

Затем, чтобы заставить эту работу работать с Spring Boot, я добавляю следующее ...

@Controller
public class MainEndpoint {
  @GetMapping("")
  public String rootRedirect(){return "redirect:/ui";}
  @RequestMapping("/ui")
  public String root(){
      return "splash";
  }
  @RequestMapping("/ui/upload")
  public String upload() { return "forward:/ui"; }
}

Проблема в том, дошел ли я до <address>/ui или <address>/ui/upload, они оба показывают один и тот же компонент MainPageComponent. Я не могу понять, как заставить загрузку показать компонент загрузки.

Как использовать URL-адреса HTML5 с VueJS и Spring Boot?

Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Версия Java на основе версии загрузки
Версия Java на основе версии загрузки
Если вы зайдете на официальный сайт Spring Boot , там представлен start.spring.io , который упрощает создание проектов Spring Boot, как показано ниже.
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
1
0
1 161
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

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

Возможно, разница в том, как Vue обрабатывает URL-адреса.

Попробуйте активировать режим истории для vue-router:

const router = new VueRouter({
    mode: 'history',                       // <=================== added this line
    routes: [
        { path: '/', component: MainPageComponent },
        { path: '/upload', component: UploadComponent }
    ]
});

Я собирался ответить на то же самое. Я думал, что по умолчанию будет html5, как ng2, но потом я перечитал документацию.

JGleason 15.03.2018 16:22

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

acdcjunior 15.03.2018 16:25

Кстати, JSYK, я думаю, у тебя достаточно репутации, чтобы делать апвоуты, поздравляю :)

acdcjunior 15.03.2018 16:26

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