【问题标题】:Vuejs router transition doesn't happenVuejs 路由器转换不会发生
【发布时间】:2020-10-31 10:20:39
【问题描述】:

我刚开始学习vue并尝试做一个路由器转换。但是,当我在页面之间切换时,上面的代码没有任何转换。知道为什么吗? 额外的行,因为stackoverflow不允许我提交问题。

<template>
  <div id="app">
    <div id="nav">
      <router-link to="/">Home</router-link> |
      <router-link to="/about">About</router-link><br><br>
    </div>
    <transition name="fade" mode="out-in">
      <router-view></router-view>
    </transition>
  </div>
</template>
<script>

</script>
<style>
body {
  background-color: #00ffcc;
  margin: 0;
  padding: 0;
}
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  overflow: hidden;
  width: 100vw;
}

#nav {
  padding: 30px;
}

#nav a {
  font-weight: bold;
  color: #2c3e50;
}

#nav a.router-link-exact-active {
  color: #42b983;
}

.fade-enter, .fade-leave-to {
  opacity: 0;
  transform: translateX(2em);
}

.fade-enter-active, .fade-leave-active {
  transition: all .3 ease;
}
</style>

【问题讨论】:

    标签: javascript css vue.js


    【解决方案1】:

    问题似乎出在您的 CSS 代码上,应该是 transition: all 0.3s ease。 这是一个工作示例

    const Home = { template: '<div>Home</div>' }
    const Foo = { template: '<div>Foo</div>' }
    
    const router = new VueRouter({
      mode: 'hash',
      routes: [
        { path: '/', component: Home },
        { path: '/foo', component: Foo }
      ]
    })
    
    new Vue({
        router,
      el: '#app',
      data: {
        msg: 'Hello World'
      }
    })
    body {
      background-color: #00ffcc;
      margin: 0;
      padding: 0;
    }
    #app {
      font-family: Avenir, Helvetica, Arial, sans-serif;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      text-align: center;
      color: #2c3e50;
      overflow: hidden;
      width: 100vw;
    }
    
    #nav {
      padding: 30px;
    }
    
    #nav a {
      font-weight: bold;
      color: #2c3e50;
    }
    
    #nav a.router-link-exact-active {
      color: #42b983;
    }
    
    .router-link-active {
      color: red;
    }
    
    .fade-enter, .fade-leave-to {
      opacity: 0;
      transform: translateX(2em);
    }
    
    .fade-enter-active, .fade-leave-active {
      transition: all 0.3s ease;
    }
    <script src="https://npmcdn.com/vue/dist/vue.js"></script>
    <script src="https://npmcdn.com/vue-router/dist/vue-router.js"></script>
    
    <div id="app">
      <router-link to="/">/home</router-link>
      <router-link to="/foo">/foo</router-link>
      <transition name="fade" mode="out-in">
          <router-view></router-view>
      </transition>
    </div>

    这里,是上面代码的jsfiddle

    【讨论】:

      猜你喜欢
      • 2017-07-13
      • 2020-12-04
      • 2019-01-14
      • 2019-11-13
      • 2018-02-10
      • 1970-01-01
      • 1970-01-01
      • 2023-03-25
      相关资源
      最近更新 更多