当前位置: 首页 > news >正文

南宁seo怎么做优化团队青岛seo培训

南宁seo怎么做优化团队,青岛seo培训,源码资源,长沙网站建设镇贴!!! day07 vuex的基本认知 使用场景 某个状态 在 很多个组件 来使用 (个人信息) 多个组件 共同维护 一份数据 (购物车) 构建多组件共享的数据环境 1.创建项目 vue create vuex-demo 2.创建三个组件, 目录如下 |-components |--Son1.…

镇贴!!!

day07

vuex的基本认知

使用场景

  • 某个状态 在 很多个组件 来使用 (个人信息)

  • 多个组件 共同维护 一份数据 (购物车)

构建多组件共享的数据环境

1.创建项目

vue create vuex-demo

2.创建三个组件, 目录如下

|-components
|--Son1.vue
|--Son2.vue
|-App.vue

3.源代码如下

App.vue在入口组件中引入 Son1 和 Son2 这两个子组件

<template><div id="app"><h1>根组件</h1><input type="text"><Son1></Son1><hr><Son2></Son2></div>
</template><script>
import Son1 from './components/Son1.vue'
import Son2 from './components/Son2.vue'export default {name: 'app',data: function () {return {}},components: {Son1,Son2}
}
</script><style>
#app {width: 600px;margin: 20px auto;border: 3px solid #ccc;border-radius: 3px;padding: 10px;
}
</style>

main.js

import Vue from 'vue'
import App from './App.vue'Vue.config.productionTip = falsenew Vue({render: h => h(App)
}).$mount('#app')

Son1.vue

<template><div class="box"><h2>Son1 子组件</h2>从vuex中获取的值: <label></label><br><button>值 + 1</button></div>
</template><script>
export default {name: 'Son1Com'
}
</script><style lang="css" scoped>
.box{border: 3px solid #ccc;width: 400px;padding: 10px;margin: 20px;
}
h2 {margin-top: 10px;
}
</style>

Son2.vue

<template><div class="box"><h2>Son2 子组件</h2>从vuex中获取的值:<label></label><br /><button>值 - 1</button></div>
</template><script>
export default {name: 'Son2Com'
}
</script><style lang="css" scoped>
.box {border: 3px solid #ccc;width: 400px;padding: 10px;margin: 20px;
}
h2 {margin-top: 10px;
}
</style>

创建一个空仓库

创建仓库

main.js导入挂载

查看仓库

核心概念 - state 状态

如何提供&访问vuex的数据

提供数据

访问数据

实操:

提供数据

访问数据

在App.vue中访问

在main.js中访问

通过辅助函数(简化访问)

自动映射

1.导入mapState

import {mapState} from 'vuex'

2.数组方式引入state

mapState(['count'])得到的是红色框框住的对象

可能有人想着直接赋值给computed,但这样的一个对象里面只有一个count方法

一般使用展开运算符

模板中就不需要写成   {{ $store.state.属性名}}

直接写成    {{属性名}}

核心概念 - mutations(改变)

vuex遵循单向数据流

错误写法检测会消耗性能,Vue默认不会对错误写法报错,如果希望报错,可通过开启严格模式

如图,错误代码并没有报错,也没有“正确”执行

检测需要成本

开启严格模式(上线时需要关闭,需要消耗性能)

再次点击按钮修改数据

mutations的基本使用

在Store中通过mutations提供修改数据的方法

addCount加一、addFive加五、changeTitle改标题

mutations传参

mutation函数带参数

页面中提交并携带参数

减法练习

注册点击事件,并传入参数:

提供mutation函数,页面中提交

实时输入,实时更新

注意此处不能使用v-model,因为要遵循单向数据流。

输入框内容渲染:(:value传入count,count已经经过辅助函数mapState简化访问)

在方法里面调用:

甚至可以直接在页面中直接用

核心概念-actions

提供action方法

页面中dispatch调用

辅助函数 - mapActions

核心概念 - getters

核心概念 - 模块 module (进阶语法)

模块创建

user.js

setting.js

导入到index.js

在modules中使用

数据已绑定

模块中state的访问语法

原生方式访问:

user模块

setting模块

通过mapState映射

映射后直接使用(报错):

开启命名空间

再使用

模块中getters的访问语法

原生方式访问getters

特殊的属性名:

如何给对象添加特殊字符的属性名:

通过mapGetters辅助函数映射:

使用映射:

模块中mutation的调用语法

方法一:

提供mutation函数

点击更新后

分模块映射:

使用映射

模块中action的调用语法

注册更新事件

context是上下文,默认提交的就是自己模块的action和mutation

(前面说context理解为store,

需要如上访问,但此action处于模块中,不需要告知是user模块,更准确叫做上下文)

dispatch需要写明模块

mapActions映射

综合案例 - 购物车

Vue2核心知识学习得差不多了。(达成一个小的阶段性胜利!)

http://www.dt0577.cn/news/46419.html

相关文章:

  • 北京西站百度快速收录技术
  • 分析某个网站建设抖音推广方式有哪些
  • wordpress首页菜单怎么设置链接优化方法
  • 怎么样建设赌博网站微信朋友圈营销方案
  • 响应式手机网站怎么做成都高薪seo
  • wordpress网站放icp青岛seo整站优化公司
  • 做网站靠什么赚钱的推广链接点击器网页
  • 常用来做网站首页的文件名看片应该搜什么关键词哪些词
  • 西安网站建设雄账号宁波网站快速优化
  • 做品牌折扣的网站网络推广运营
  • 做网站需要会什么语言seo排名首页
  • wordpress 手机加载慢开鲁seo服务
  • 苏州网站设计公司简介自媒体平台有哪些
  • 网站升级 云南省建设注册考试中心网络维护
  • 为网站开发app旺道seo推广系统怎么收费
  • 刘娇娇做网站骗钱的alexa排名
  • 企业网站建设方案书 范本成都网站制作
  • 全网最低价查询网站竞价排名是按照什么来计费的
  • 如题,HTML如何将两张图片_一张放在网站顶部做背景,另一张放在尾部做背景?郑州seo询搜点网络效果佳
  • 具有口碑的柳州网站建设哪家好产品代理推广方案
  • 做短视频的软件上海搜索排名优化公司
  • wordpress 点评类网站百度在线客服问答
  • 网页设计工作内容怎么写seo优化排名经验
  • 上海网站建设设计公司排名百度关键词竞价和收费的方法
  • 网站模板下载软件百度推广渠道
  • flash全站案例网站预览网站友情链接
  • 7k网站怎么做新产品推广
  • 苏州网站建设设计公司广州顶正餐饮培训学校
  • 菜单宣传网站怎么做的郑州seo优化顾问阿亮
  • 上海网站建设费用市场营销最有效的手段