位置: IT常识 - 正文

【Vue 快速入门系列】Vue数据实现本地存储、自定义事件绑定、全局事件总线、$nextTick的使用(vue快速入门与实战开发)

编辑:rootadmin
【Vue 快速入门系列】Vue数据实现本地存储、自定义事件绑定、全局事件总线、$nextTick的使用 文章目录一、本地存储1.概念2.接口3.实际操作二、自定义事件绑定1.自定义事件使用过程2.绑定自定义事件的语法3.其他注意事项三、全局事件总线1.全局事件总线概念2.全局事件总线的使用方式3.原理剖析四、$nextTick小技巧一、本地存储1.概念

推荐整理分享【Vue 快速入门系列】Vue数据实现本地存储、自定义事件绑定、全局事件总线、$nextTick的使用(vue快速入门与实战开发),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue入门教程简书,vue从入门到精通教程,vue详细教程,vue快速入门与实战开发,vue入门视频教程,vue怎么入门,vue入门教程,vue怎么入门,内容如对您有帮助,希望把文章链接给更多的朋友!

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

分类:

永久存储 使用localStorage临时存储 使用sessionStorage2.接口

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

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>

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

二、自定义事件绑定【Vue 快速入门系列】Vue数据实现本地存储、自定义事件绑定、全局事件总线、$nextTick的使用(vue快速入门与实战开发)

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

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=name console.log(name) }, getschname(name){ this.schname=name console.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-names name:"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-names name:"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.全局事件总线的使用方式安装全局事件总线new Vue({......beforeCreate() {Vue.prototype.$bus = this //安装全局事件总线,$bus就是当前应用的vm}, ......}) 使用全局事件总线接受数据(绑定事件):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小技巧语法:this.$nextTick(回调函数)作用:在下一次 DOM 更新结束后执行其指定的回调。什么时候用:当改变数据后,要基于更新后的新DOM进行某些操作时,要在nextTick所指定的回调函数中执行。常用于页面加载完毕后输入框聚焦等操作。

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

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

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

本文链接地址:https://www.jiuchutong.com/zhishi/300686.html 转载请保留说明!

上一篇:tokenizer.encode、tokenizer.tokenize、tokenizer.encode_plus的用法差异

下一篇:【Windows Server 2019】Web服务 IIS 配置与管理—— IIS 的安装与基本配置 Ⅲ(windowsserver2019产品密钥)

  • meas压力传感器官网(meas压力传感器)(meas压力传感器m5156)

    meas压力传感器官网(meas压力传感器)(meas压力传感器m5156)

  • 三天朋友圈针对个人吗(三天的朋友圈是针对一个人还是所有人呢)

    三天朋友圈针对个人吗(三天的朋友圈是针对一个人还是所有人呢)

  • 荣耀v30pro支持wifi6的吗(荣耀V30Pro支持快充吗)

    荣耀v30pro支持wifi6的吗(荣耀V30Pro支持快充吗)

  • 苹果7怎么给软件加密码(苹果7怎么给软件设置密码锁)

    苹果7怎么给软件加密码(苹果7怎么给软件设置密码锁)

  • 红米note7pro发热严重(红米note7发热严重)

    红米note7pro发热严重(红米note7发热严重)

  • 微信怎么看用了几年了(微信怎么看用了多少头像)

    微信怎么看用了几年了(微信怎么看用了多少头像)

  • 手机怎么找回QQ删除的好友(手机怎么找回QQ群)

    手机怎么找回QQ删除的好友(手机怎么找回QQ群)

  • 怎么辨别对方语音是否静音了(怎么辨别对方语音)

    怎么辨别对方语音是否静音了(怎么辨别对方语音)

  • 苹果自带字体是什么字体(苹果自带字体是什么软件)

    苹果自带字体是什么字体(苹果自带字体是什么软件)

  • 机顶盒专用网络怎么电脑(机顶盒配置网络)

    机顶盒专用网络怎么电脑(机顶盒配置网络)

  • 手机电池显示蓝色是什么原因(手机显示电池异常是什么原因)

    手机电池显示蓝色是什么原因(手机显示电池异常是什么原因)

  • 苹果x边框花了怎么修复(苹果x边框花了怎么回事)

    苹果x边框花了怎么修复(苹果x边框花了怎么回事)

  • 苹果怎么关闭快门声音(苹果怎么关闭快手通知消息)

    苹果怎么关闭快门声音(苹果怎么关闭快手通知消息)

  • 苹果手机设置铃声教程(苹果手机设置铃声没有声音)

    苹果手机设置铃声教程(苹果手机设置铃声没有声音)

  • 淘宝双11什么时候开始抢红包(淘宝双11什么时候结束)

    淘宝双11什么时候开始抢红包(淘宝双11什么时候结束)

  • iphone11重启方法(iphone11重启怎么弄)

    iphone11重启方法(iphone11重启怎么弄)

  • 小米8可以用27w充电吗(小米8可以用27w快充吗)

    小米8可以用27w充电吗(小米8可以用27w快充吗)

  • 苹果6手机怎么备份(苹果6手机怎么换电池)

    苹果6手机怎么备份(苹果6手机怎么换电池)

  • miui11什么时候发布(miui11啥时候发布的)

    miui11什么时候发布(miui11啥时候发布的)

  • airpods2如何设置siri(airpod2怎么设置)

    airpods2如何设置siri(airpod2怎么设置)

  • 小米cc9跑分多少

    小米cc9跑分多少

  • 苹果无线耳机电量显示(苹果无线耳机电量在哪看)

    苹果无线耳机电量显示(苹果无线耳机电量在哪看)

  • 公众平台登录方法(公众微信平台登录)

    公众平台登录方法(公众微信平台登录)

  • 后入式耳机怎么带(耳机入耳式怎么用)

    后入式耳机怎么带(耳机入耳式怎么用)

  • 多级列表在哪里(多级列表在哪里设置)

    多级列表在哪里(多级列表在哪里设置)

  • mxoaldr.exe - mxoaldr是什么进程 有什么用

    mxoaldr.exe - mxoaldr是什么进程 有什么用

  • 增值税电子发票查询平台
  • 公司每年需要交钱吗
  • 印花税怎么计提和缴纳
  • 小规模纳税人怎么变成一般纳税人
  • 电子发票错误怎么重开
  • 发票抬头公司名称有空格
  • 建筑劳务公司业务范围是什么
  • 政府补贴是什么职能
  • 销售开红字的账务处理
  • 周转材料调拨调入单位如何做账
  • 差额事业单位发放科研奖励记账
  • 资本公积转增股本什么意思
  • 公司注销取不到采购发票怎么汇算清缴?
  • 出纳去银行
  • 出售使用过的固定资产如何开票 备注
  • 生活用品发票可以报销吗
  • 拿库存商品抵债怎么做账
  • win11怎么设置最佳能效模式
  • 每股收益增长率计算公式
  • 所得税到底按会计分录吗
  • php入门基础教程
  • linux命令行怎么用
  • win11电脑硬盘分区
  • Win10 KB5004945 更新后多个品牌打印机无法使用的解决方法
  • 企业职工工伤赔偿标准税前扣除
  • 000.exe病毒
  • 稀有品种茅膏菜
  • 房产税具体内容
  • php怎么发布
  • 分配股利会稀释股权吗
  • 桑吉尔夫个人简介
  • 银行结算方式有哪几种方式?其具体内容是什么?
  • 毕业论文笔记怎么写
  • GPT-4:关于下一代人工智能模型的事实、谣言和期望
  • 发票税额打印不全可以入账吗
  • 详解MySQL中EXPLAIN解释命令及用法讲解
  • 残疾人就业保障金是什么意思啊
  • 银行账本怎么记账
  • 社会团体要求
  • 盈余公积转增资本所有者权益会变吗
  • 向农业生产者收购的原木 进项
  • 如何降低应收账款成本
  • 调整事宜
  • 内地汇丰银行账户管理费
  • 期末应交税费有余额吗
  • 库存商品坏账准备怎么算
  • 什么是盈余公积和资本公积
  • 单位租赁个人房子怎么缴纳房产税
  • 付给农民的土地使用费
  • 计提本月工资社保怎么扣
  • 企业筹建期的开办费后期怎么算
  • 管理会计与核算会计的区别
  • 明细账要如何做账
  • 企业如何建账做账
  • mysql5.7最新版
  • UNIX系统中文件的索引表结构
  • 网关dns配置异常是什么意思
  • windowsxp休眠设置
  • windows 高分屏
  • auto tool怎么用
  • kmsss.exe是什么
  • 日历功能在哪里设置
  • node.js server-side
  • python djang
  • javascript编写
  • jquery插件开发方法
  • node.js入门教程
  • 超酷风格
  • jquery模拟表单提交
  • nodejs基础教程
  • jquery根据value获取元素
  • python语言的特殊符号
  • jquery实现图片横向移动
  • 江苏国税电子税局
  • 怎么在国家税务局查发票
  • 开个小型外卖店要多少钱
  • 税控盘口令密码怎么修改
  • 物业优质服务我们在行动
  • 江苏房产税如何计算公式
  • 2021房屋退税流程怎么操作
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设