}
}
第四步: 监听 LOADING 状态
Vuex 中 state 是动态更新的,也就是不管在任何地方对某一个 state的值做了修改,那么依赖该数据的 DOM 也将会发生改变。修改 App.vue 文件,监听 LOADING 的值的变化。
<template>
<div id="app">
<router-view></router-view>
<loading v-if='LOADING'/> //自己封装的loading 组件
</div>
</template><script>
import {mapState} from 'vuex'
export default {
computed:{
...mapState([
'LOADING'
])
},
name: 'App'
}
</script>
总结:
loading的过渡效果最根本的就是通过 state 来控制 loading 组件的显示和隐藏。在请求接口前使该状态为 为 true,接口完成后改为 false。
简单的 loading 组件。
一个简单的 loading 组件,应该会有一个遮罩层,一个过度动画,或者一个loading 说明。
<template>
<section>
<div class='mock'>
<div class='main'>
loading...
</div>
</div>
</section>
</template>
<style>
section{
width:100vh;
height:100vh;
position:relative;
}
.mock{
tion{
width:100vh;
height:100vh;
position:absolute;
z-index:100;
background-color:#abb2bf;
}
.main{
margin:200px auto;
text-align:center:
}
</style>










