在动态组件上使用 keep-alive
我们可以使用 is attribute 来切换不同的组件
1 | <my-componet v-bind:is="currentTabComponent"></my-component> |
在切换组件的时候, 我们有时候需要保持这些组件的状态, 避免反复冲渲染导致性能的问题.
为了解决这个问题, Vue 为我们提供了 <keep-alive> 元素将其动态组件包裹起来
1 | <!-- 失活的组件将会被缓存 --> |
<keep-alive>元素要求被切换的组件都有自己的名字.
异步组件
我们可以将应用分隔成一些小代码块, 在组件需要被用到的时候才从服务器加载一个模块.
Vue 允许以一个工厂函数的方式定义一个组件, 这个工厂函数会异步解析组件定义
Vue 只有在这个组件需要被渲染的时候才会触发该工厂函数, 并把结果缓存起来供未来重渲染
1 | // 异步组件-在1秒后渲染 |
将异步组件和webpack的code-splitting功能一起配合使用
1 | Vue.component('my-component', function(resolve, reject) { |
也可以在工厂函数中返回一个 Promise
1 | Vue.component( |
局部注册时, 也可以直接提供一个返回Promise的函数
1 | new Vue({ |
处理加载状态
异步组件工厂函数也可以返回一个如下格式的对象
1 | const AsyncComponent = () => ({ |