文章目录

  • 一、本地存储
    • 1.概念
    • 2.接口
    • 3.实际操作
  • 二、自定义事件绑定
    • 1.自定义事件使用过程
    • 2.绑定自定义事件的语法
    • 3.其他注意事项
  • 三、全局事件总线
    • 1.全局事件总线概念
    • 2.全局事件总线的使用方式
    • 3.原理剖析
  • 四、$nextTick小技巧

一、本地存储

1.概念

可以将数据临时存储到本地浏览器,一般大小最大为5M,存储的时候形式是字符串,早期可以做网站搜索记录的存储,随着云原生的不断发展,搜索记录,浏览记录不断转向了云端存储方式。

分类:

  • 永久存储 使用localStorage
  • 临时存储 使用sessionStorage

2.接口

(上面两种存储方式接口名称一样):

  • window.localStorage.setItem() 存数据,传入的应是一个JSON串
  • window.localStorage.getItem() 获取数据。接受到后应进行解析,为防止没有数据应加一个|| “”
  • window.localStorage.removeItem() 删除数据。传入的是一个键
  • window.localStorage.clear()

读取与写入的时候可以使用JSON进行解析,写入的时候如果不解析,会导致存储异常
读取的时候不解析,读到的将是一个字符串。JSON解析null结果还是null

  • JSON.stringify()
  • JSON.parse()

存储的时候使用的是键值对的形式,对一个键进行多次存储以最后一次为准

3.实际操作

<script>//存数据function addStorage(){localStorage.setItem("users",JSON.stringify([{"name":"张三","age":"18"},{"name":"张三1","age":"188"}]))}//取数据function alertStorage(){let i=JSON.parse(localStorage.getItem("users"))console.log(i)}//删除数据function delStorage(){localStorage.removeItem("users")}//清空数据function delAllStorage(){localStorage.clear()}
</script>

如图所示(存储的一条用户数据):

二、自定义事件绑定

这种方法信息流向为 子组件===>父组件

1.自定义事件使用过程

  • 进行事件的绑定
  • 使用$emit触发事件(可以对$emit传多个参数,能接受几个看绑定的回调函数)

2.绑定自定义事件的语法

  • 方法① 直接使用v-on:事件名=“回调函数”或者@+事件名+“回调函数”(事件名与回调函数名可以一样)
  • 方法② 通过this.$refs.xxx.$on('atguigu',回调)绑定自定义事件时,回调要么配置在methods中,要么用箭头函数,否则this指向会出问题!(ref在父组件的标签上)
  • 一般事件绑定与解除使用时机如下:
    • mounted函数中进行事件绑定
    • beforeDestroy函数中进行事件的解除
mounted(){this.$bus.$on("alertDone",this.alertDone)
},
beforeDestroy(){this.$bus.$off("alertDone")
}

3.其他注意事项

  • 在组件中没办法直接使用系统给定的事件,例如@click他会当做一个自定义事件处理,想要作为系统自带的事件需要使用@click.native,其余系统自带属性亦是如此。
  • 如果想让事件只触发一次,就需要使用once或$once进行修饰
  • 触发自定义事件,需要使用$emit(“事件名”,事件需要的参数)
  • 解绑事件使用$off(“事件名”)
  • 事件回调函数可以使用省略传参方式进行传参

结合一个实例看看如何使用:
以下实例实现了将子组件的数据传送到父组件,传送之后并重新渲染模板,只给出了核心代码注释。
App.vue 父组件

<template>
<div class="demo"><!-- 第一种测试方式 ref--><h3>这里是父组件,子组件传过来的数据为:{{schname}}</h3><School ref="school"></School><!-- 第二种测试方式 @ or v-on --><h3>这里是父组件,子组件传过来的数据为:{{stuname}}</h3><Student @getstuname="getstuname"></Student><h3>以下组件只会触发一次事件,因为使用了once属性</h3><Student @getstuname.once="getstuname"></Student>
</div>
</template><script>
import Student from "./components/Student.vue"
import School from "./components/School.vue"
export default {name:"App",components:{Student,School},data(){return{stuname:"",schname:""}},methods:{//回调函数getstuname(name){this.stuname=nameconsole.log(name)},getschname(name){this.schname=nameconsole.log(name)}},mounted(){// 第二种进行事件的绑定的方法(将事件名与回调函数绑定起来)this.$refs.school.$on("getschname",this.getschname)}
}
</script><style>.demo{background-color:grey;}
</style>

School.vue子组件

<template><div class="demo"><h2>学校名称:{{name}}</h2><h2>学校地址:{{address}}</h2><button @click="sendschoolname">点我给把学校名给App</button></div>
</template><script>
export default {// eslint-disable-next-line vue/multi-word-component-namesname:"School",data(){return {name:"南阳理工学院",address:"长江路80号"}},methods:{sendschoolname(){//触发事件,并传递参数this.$emit("getschname",this.name)}}
}
</script><style scoped>
.demo{background-color: #ddd;}
</style>

Student.vue子组件

<template><div class="demo"><h2>姓名:{{name}}</h2><h2>年龄:{{age}}</h2><button @click="sendstuname">点我发送学生姓名给App</button></div>
</template><script>
export default {// eslint-disable-next-line vue/multi-word-component-namesname:"Student",data(){return {name:"张三",age:18}},methods:{sendstuname(){//触发事件,并传递参数this.$emit("getstuname",this.name)}}
}
</script><style scoped>
.demo{background-color: #ddd;
}
</style>

三、全局事件总线

可用于父子、兄弟之间等等任意组件间相互通信

1.全局事件总线概念

  • 全局事件总线可以用于同一层的组件进行通信
  • 全局事件总线利用的是vue运行底层原理(在自己身上找不到数据是向上级找,直到原型)
  • 在使用全局事件总线的时候需要先定义(安装),安装的时机是在vm对象创建但数据代理等没有创建之前。
  • 使用事件总线的时候需要先明白哪里接受数据,哪里发送数据
  • 接受数据的地方绑定事件,发送数据的地方触发事件,绑定事件一般写在就是mounted函数内
  • 在销毁对象的时候最好将之前绑定的事件解绑掉,解绑的时候还是用$off()

通俗点来说,全局事件总线就像一个公交车或者说邮差,游走在兄弟组件、父子组件、不相关组件之间,虽然组件之间相互不知道有什么,但可以将信息传递到很远的地方,原因就是在Vue原型对象上挂载了一个全局变量,大家都知道有这么一个东西的存在。

2.全局事件总线的使用方式

  1. 安装全局事件总线
new Vue({......beforeCreate() {Vue.prototype.$bus = this //安装全局事件总线,$bus就是当前应用的vm},......
})
  1. 使用全局事件总线
  • 接受数据(绑定事件):A组件想接收数据,则在A组件中给$bus绑定自定义事件,事件的回调留在A组件自身
methods(){demo(data){......}
}
......
mounted() {
//第一个参数是事件名,第二个参数是回调函数this.$bus.$on('xxxx',this.demo)
}
  • 发送数据(触发事件)
this.$bus.$emit('xxxx',数据)

3.原理剖析

解释一下为啥要将Vue.prototype.$bus = this放在beforeCreate内

全局事件总线利用的就是一个大家都知道的对象进行通信
全局事件总线的调用过程就是绑定事件、触发事件如果没在自己身上就向上级找、上级找不到就在原型上找
将一个大家都知道的对象挂在原型上在该对象上搭建事件,这个对象无疑最好的是使用vue对象(vm)。
在给Vue.prototype上挂载vm时,如果new vm 写在前面会报出模板中找不到Vue.prototype.$bus等信息
如果Vue.prototype.$bus写前面。vm对象还没有创建完毕,所以将他写在beforeCreate函数中恰到好处

四、$nextTick小技巧

  1. 语法:this.$nextTick(回调函数)
  2. 作用:在下一次 DOM 更新结束后执行其指定的回调。
  3. 什么时候用:当改变数据后,要基于更新后的新DOM进行某些操作时,要在nextTick所指定的回调函数中执行。
  4. 常用于页面加载完毕后输入框聚焦等操作。

eg:这是一个触发编辑功能的函数,在触发之后等待模板渲染完毕,直接将鼠标聚焦在指定的输入框

editThisTodo(id){this.$bus.$emit("editSomeTodo",id)this.$nextTick(function(){this.$refs.inputTitle.focus()})
},

这四种操作的基础语法已经介绍完了,接下来会根据这四种操作的语法实现一个记事本小案例。

【Vue 快速入门系列】Vue数据实现本地存储、自定义事件绑定、全局事件总线、$nextTick的使用相关推荐

  1. 【Vue 快速入门系列】3分钟掌握Vue中插槽的使用与理解

    文章目录 前言 一.常规实现方式 二.匿名插槽 三.具名插槽 四.作用域插槽 前言 插槽作用:让父组件可以向子组件指定位置插入html结构,也是一种组件间通信的方式,适用于 父组件 ===> 子 ...

  2. 【Python零基础快速入门系列 | 03】AI数据容器底层核心之Python列表

    • 这是机器未来的第7篇文章 原文首发地址:https://blog.csdn.net/RobotFutures/article/details/124957520 <Python零基础快速入门 ...

  3. 【Python数据科学快速入门系列 | 04】Numpy四则运算、矩阵运算和广播机制的爱恨情仇

    这是机器未来的第43篇文章 原文首发地址:https://blog.csdn.net/RobotFutures/article/details/126493989 文章目录 1. 概述 2. 四则运算 ...

  4. b站黑马的Vue快速入门案例代码——【axios+Vue2】悦听player(音乐播放器)

    目录 本文中修改的原代码中的BUG: 修改方法: 本文案例代码仍有的BUG:(欢迎大家献计献策) 目标效果: 悦音player案例--效果展示视频: 更换的新接口/参数: 1.歌曲搜索接口:https ...

  5. Vue快速入门(含下载地址)

    Vue快速入门 文档 想学习vue,最好的文档就是官网 这里列出几个: Vue.js 介绍 - Vue.js 中文文档 (bootcss.com) Vue.js 教程 | 菜鸟教程 (runoob.c ...

  6. Vue快速入门(下)

    文章目录 Vue快速入门(下)(应急用) 八.使用Axios实现异步通信(重点) 8.1 什么是Axios 8.2 第一个Axios应用程序 九.表单输入绑定 十.组件基础 十一.Vue-cli搭建d ...

  7. Vue快速入门一:官网、下载、定义变量

    Vue官网:Vue.js - 渐进式 JavaScript 框架 | Vue.js Vue2中文文档:Vue.js介绍 - Vue.jsVue.js Vue3中文文档:快速上手 | Vue.js Vu ...

  8. 01Vue.js快速入门(一)Vue概念及Helloworld

    1.1. Vue简介 Vue是一个前端的双向绑定类的框架,发音[读音 /vjuː/, 类似于 view].新的Vue版本参考了React的部分设计,当然也有自己独特的地方,比如Vue的单文件组件开发方 ...

  9. 【Vue 快速入门】从零开始搭建 VUE + Element UI后台管理系统框架

    [Vue 快速入门]从零开始搭建 VUE + Element UI后台管理系统框架 前言 后台管理系统前端框架,现在很流行的形式都是,上方和左侧都是导航菜单,中间是具体的内容.比如阿里云.七牛云.头条 ...

最新文章

  1. iOS设计模式 - 生成器
  2. linux中GIT组件,GitLab在Linux下安装
  3. 人工智能:模型与算法 之 启发式搜索
  4. kalman滤波的解释
  5. vb编程的好帮手--资源文件
  6. Flutter组件学习(二)—— Image
  7. HANA report transaction data retrieve in QHD/504
  8. 开源项目管理软件禅道使用帮助下载
  9. c++歌手大赛系统_计人即讯|第十届程序设计大赛
  10. java8 streams_当Java 8 Streams API不够用时
  11. 一文读懂工业设备的两种通讯方式:现场总线和工业以太网
  12. CentOS 6 和 CentOS 7 防火墙的关闭
  13. 【ElasticSearch】深入理解 relocating rebalance 对Elasticsearch集群的影响
  14. 如何让背景图片固定在中间,滚动内容图片不动?
  15. xtrabackup备份mysql_xtrabackup备份mysql
  16. Docker部署ssm项目
  17. 好程序员分享大数据入门教程:Hadoop和spark的性能比较
  18. 数据结构——散列表--线性探测法
  19. php实现五维雷达图,【数据可视化·图表篇】雷达图
  20. gz是什么意思饭圈_网络语BE是什么意思 饭圈用GE含义出处是哪里还有哪些类似表达...

热门文章

  1. 【Python大作业】耦合网络信息传播
  2. 简单又漂亮的思维导图怎么画?脑图创作分享
  3. 天翼云服务器的一些问题及解决方式
  4. 数论——卢卡斯(Lucas)定理(板子)
  5. 文本分类之降维技术之特征抽取之SVD矩阵的分解的原理的介绍
  6. arcpy——利用Arcpy进行字段操作
  7. 水库信息化监测系统有哪些?水库信息化监测解决方案
  8. C语言——初识关键字、static、#define定义、指针
  9. 行业前沿|无人机视觉自主导航发展及视觉智能开发支撑平台介绍
  10. 微信小程序制作顶部导航栏