如何在不重新渲染HTML的情况下切换vue.js路由器视图

时间:2020-01-16 17:48:19

标签: vue.js vue-router

我正在使用vue和官方路由器。我的应用程序有一些视图,一个视图有一个带有一些输入的表单。现在,我正在寻找一种在不丢失输入数据/不重新渲染视图的情况下切换到视图的解决方案。表单中的一个额外的保存按钮没有选项。

可能我的问题与v-if和v-show的工作方式接近不同: https://vuejs.org/v2/guide/conditional.html#v-if-vs-v-show

我基于vue路由器示例构建示例: https://jsfiddle.net/okuc64d2/6/

const Foo = { 
	data: function () {
            return {
                text: "abc"
            }
        },
  template: '<div>VIEW A: <input v-model="text" placeholder="edit me"></div>' 
}
const Bar = { 
	data: function () {
            return {
                text: "123"
            }
        },
  template: '<div>VIEW B: <input v-model="text" placeholder="edit me"></div>' 
}

const routes = [
  { path: '/foo', component: Foo },
  { path: '/bar', component: Bar }
]

const router = new VueRouter({
  routes
})

const app = new Vue({
  router
}).$mount('#app')

// Now the app has started!
.router-link-active {
  color: red;
}
<script src="https://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>

<div id="app">
  <h1>Hello App!</h1>
  <ul>
    <li>Go to  Foo</li>
    <li>Change input</li>
    <li>Go to Bar</li>
    <li>Go back to Foo</li>
    <li>Input is resetted</li>
  </ul>
  
  <p>
    <router-link to="/foo">Go to Foo</router-link>
    <router-link to="/bar">Go to Bar</router-link>
  </p>
  <router-view></router-view>
</div>

1 个答案:

答案 0 :(得分:0)

您可以将keyup上的输入保存到vuex存储,并将其用于您的组件。

相关问题