作者:本多天舞 | 来源:互联网 | 2023-08-17 15:46
vue中有 data()、computed、methods、beforeRouteLeave、created等具体的:data():定义一些文件中需要用到的变量,data中带ret
vue 中有 data() 、computed、methods、beforeRouteLeave、created等
具体的:
data():定义一些文件中需要用到的变量,data中带return,是使数据只在当前组件中可用,不会影响其他组件,不使用return,会让数据在全局可见,会造成污染
computed():用来监控自己定义的变量,该变量不在data里面声明,直接在computed里面定义,然后就可以在页面上进行双向数据绑定展示出结果或者用作其他处理,
它其实就是定义一些需要通过各种计算处理等得到的数据,data是定义一些初始化的变量
methods:里面是放上下文中用到的函数的,比如,点击事件中调用一个函数,这个函数就写在methods里面
beforeRouteLeave:离开路由之前执行的函数。
created:在模板渲染成html前调用,即通常初始化某些属性值,然后再渲染成视图。在实例创建完成后被立即调用
关于store:
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。
每一个 Vuex 应用的核心就是 store(仓库)。“store”基本上就是一个容器,它包含着你的应用中大部分的状态 (state)。Vuex 和单纯的全局对象有以下两点不同:
-
Vuex 的状态存储是响应式的。当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变化,那么相应的组件也会相应地得到高效更新。
-
你不能直接改变 store 中的状态。改变 store 中的状态的唯一途径就是显式地提交 (commit) mutation。这样使得我们可以方便地跟踪每一个状态的变化,从而让我们能够实现一些工具帮助我们更好地了解我们的应用。
个人理解:
store主要包括了state、getters、mutations、actions、modules
具体的: actions 和mutations都是去改变state中的数据,只是,actions中可以通过调用后端接口异步操作去该变state中的数据,也可以再actions中调用mutations,进行该变state中的值
state, //类似于定义一些初始化的变量
getters, //可以对这些变量(state)进行,派生出一些状态,例如对列表进行过滤并计数(一些筛选)
mutations, //可以对state进行一些更改(用来触发同步操作的方法。)
actions //可以对state进行一些更改,和mutations相似,(可以进行一些异步操作,可以提交mutations)
modules uex 允许我们将 store 分割成模块(module)。每个模块拥有自己的 state、mutation、action、getter、甚至是嵌套子模块——从上至下进行同样方式的分割:这个地方主要是引用其他子store
mutations和actions 都可以在created中调用,如 this.$store.commit(‘showFooter‘); commit=>mutations,用来触发同步操作的方法。
this.$store.dispatch(‘getThirdUnitStudent‘) dispatch =>actions,用来触发异步操作的方法。
state, 可以在computed中用, 如 schoolName(){
return this.$store.state.info.schoolName
},
{{stu.indexCode}}
{{stu.user_name}}
vue 学习小记