Vue2.0开发之——Vue组件-生命周期(37)

news2024/11/20 2:38:31

一 概述

  • 了解生命周期和生命周期函数的概念
  • 初步了解组件创建的过程
  • 了解beforeCreate和Created生命周期函数的特点
  • 了解beforeMount和mounted生命周期函数
  • 组件运行阶段的生命周期函数
  • 组件销毁阶段的生命周期函数

二 了解生命周期和生命周期函数的概念

2.1 生命周期&生命周期函数

  • 生命周期(Life Cycle)是指一个组件从创建-> 运行 -> 销毁的整个阶段,强调的是一个时间段
  • 生命周期函数:是由 vue 框架提供的内置函数,会伴随着组件的生命周期,自动按次序执行

注意:生命周期强调的是时间段生命周期函数强调的是时间点

2.2 组件生命周期函数的分类

三 初步了解组件创建的过程

3.1 生命周期图示

四 了解beforeCreate和Created生命周期函数的特点

4.1 beforeCreate的调用过程

创建Test.vue生命周期类

1-创建Test.vue类

2-定义Test.vue中的属性和data等

export default {
  props: ['info'],
  data() {
    return {
      message: 'hello vue.js',
    }
  },
  methods:{
  	show(){
  	console.log('调用了Test组件的show方法')
  	}
  }
}

3-Test.vue中的生命周期方法beforeCreate

 beforeCreate() {
    console.log(this.info)
    console.log(this.message)
    this.show()
  },

在App.vue中导入Test.vue并使用

import Test from '@/components/Test.vue'
  // 2. 注册组件
  components: {
    Left,
    Right,
    Test
  }
<template>
  <div class="app-container">
    <h1>App 根组件</h1>
    <div class="box">
      <!-- 3. 以标签形式,使用注册好的组件 -->
      <Left></Left>
      <Right></Right>
      <Test info="你好"></Test>
    </div>
  </div>
</template>  

查看beforeCreate调用结果

4.2 Created-调用initBookList并显示书本数

initBookList函数

// 使用 Ajax 请求图书列表的数据
initBookList() {
      const xhr = new XMLHttpRequest()
      xhr.addEventListener('load', () => {
        const result = JSON.parse(xhr.responseText)
        console.log(result)
        this.books = result.data
      })
      xhr.open('GET', 'http://www.liulongbin.top:3006/api/getbooks')
      xhr.send()
}

Created调用

created() {
    // created 生命周期函数,非常常用。
    // 经常在它里面,调用 methods 中的方法,请求服务器的数据。
    // 并且,把请求到的数据,转存到 data 中,供 template 模板渲染的时候使用!
    this.initBookList()
 },

数据定义及使用

数据定义

data() {
    return {
      message: 'hello vue.js',
      // 定义 books 数组,存储的是所有图书的列表数据。默认为空数组!
      books: []
    }
  },

数据使用

<h3 id="myh3">Test.vue 组件 --- {{ books.length }} 本图书</h3>

调用结果

五 了解beforeMount和mounted生命周期函数

5.1 beforeMount

 beforeMount() {
    // console.log('beforeMount')
    // const dom = document.querySelector('#myh3')
    // console.log(dom)
  }

说明:未成功创建元素,打印为null

5.2 mounted

 mounted() {
     console.log(this.$el)
     const dom = document.querySelector('#myh3')
    console.log(dom)
  },

说明:如果要操作当前组件的 DOM,最早,只能在 mounted 阶段执行

六 组件运行阶段的生命周期函数

组件运行阶段的生命周期函数有2个:beforeUpdate和updated

6.1 准备-界面元素

<template>
  <div class="test-container">
    <p id="pppp">message 的值是:{{ message }}</p>
    <button @click="message += '~'">修改 message 的值</button>
  </div>
</template>

6.2 beforeUpdate

beforeUpdate() {
     console.log('beforeUpdate')
     console.log(this.message)
     const dom = document.querySelector('#pppp')
     console.log(dom.innerHTML)
  },

说明:

  • 刷新页面时会触发此方法
  • 点击修改message的值时也会触发此方法

6.3 updated

  // 当数据变化之后,为了能够操作到最新的 DOM 结构,必须把代码写到 updated 生命周期函数中
  updated() {
     console.log('updated')
     console.log(this.message)
     const dom = document.querySelector('#pppp')
    console.log(dom.innerHTML)
  },

七 组件销毁阶段的生命周期函数

7.1 组件和数据

组件

<button @click="flag = !flag">Toggle Flag</button>
 <Test info="你好" v-if="flag"></Test>

数据

export default {
  data() {
    return {
      flag: true
    }
  },
}

7.2 生命周期函数-beforeDestroy和destroyed

  beforeDestroy() {
    console.log('beforeDestroy')
    this.message = 'aaa'
    console.log(this.message)
  },
  destroyed() {
    console.log('destroyed')
    // this.message = 'aaa'
  }

7.3 效果图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/156910.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

李宏毅ML-机器学习任务功略

文章目录机器学习任务功略机器学习框架训练模型通用指南1. training loss is large2. training loss is small2.1 training loss is small and testing loss is large2.2 training loss is small and testing loss is small3. 偏差与复杂度的平衡机器学习任务功略 机器学习框架…

Yolov5训练自己的数据集

一、从官网下载最新的yolov5代码二、新建VOCData文件夹三、VOCData文件夹结构新建Annotations文件夹&#xff0c;存放标签简单的xml文件&#xff0c;应该长这样复杂的xml文件&#xff0c;应该长这个样子新建images文件夹&#xff0c;存放图片数据注意&#xff1a;需要观察自己的…

1.1.2半导体二极管的结构、工作原理、参数、伏安特性;

1.结构 内部实际上是一个PN结&#xff0c;将电极引线和其封装在一起就构成了二极管 拓展&#xff1a;点接触型二极管&#xff0c;面接触型二极管 2.工作原理 3.参数&#xff08;以肖特基二极管SS56为例&#xff09; MAX Forward Voltage(最大导通电压) &#xff0c;因为SS5…

Jvm-hotspot 总结系列-完整版(1)类加载器

一、类加载器子系统的作用&#xff08;1&#xff09;类加载器子系统负责从文件系统或网络中加载class文件&#xff0c;class文件在文件开头有特定的文件标识&#xff08;cafebabe&#xff09;咖啡宝贝。&#xff08;2&#xff09;ClassLoader只负责class文件的加载&#xff0c;…

广告业务系统 之 核心通道 —— “日志中心-s2s监测上报”

文章目录广告业务系统 之 核心通道 —— “日志中心-s2s监测上报”s2s 监测上报s2s 、c2s曝光/互动/Win数据上报监测上报AB 实验平台广告业务系统 之 核心通道 —— “日志中心-s2s监测上报” s2s 监测上报 s2s 监测上报&#xff0c;是 ADX 将广告的曝光、互动[点击/播放/下载…

赛事推荐 | 建筑物细粒度实例分割——2023 IEEE GRSS 数据融合赛道1

1. 赛题名称 建筑物检测和屋顶类型分类 2. 赛题背景 该轨道侧重于从高分辨率卫星光学图像和 SAR 图像中检测和分类建筑物屋顶类型。SAR 和光学模态有望提供补充信息。给定的数据集涵盖了全球六大洲的十七个城市。分类任务由 12 种细粒度的预定义屋顶类型组成。图 1 显示了一…

缺乏长线思考是扼杀工程师前途的屠刀.

缺乏长线思考是扼杀工程师前途的屠刀。 死局 工作几年后&#xff0c;最容易陷入一个隐形的死局&#xff0c;开发只关注实现需求&#xff0c;运维只关注部署、故障。待到七八年&#xff0c;一定会出现后继无力。被替代&#xff0c;早晚而已。 我相信很多领导都讲过沉淀方法论&am…

RK3399平台开发系列讲解(内核调试篇)如何使用perf进行性能优化

🚀返回专栏总目录 文章目录 一、perf list命令二、perf record/report命令三、perf stat命令四、perf top命令五、火焰图沉淀、分享、成长,让自己和他人都能有所收获!😄 📢perf 可以在 CPU Usage 增高的节点上找到具体的引起 CPU 增高的函数,然后我们就可以有针对性地…

开源PPP软件PRIDE-PPPAR使用记录(一)GFZRNX预处理

我们使用PRIDE-PPPAR软件对GNSS观测数据进行解算时&#xff0c;会遇到观测文件不能识别的问题。观测文件不能识别的主要原因是格式不对&#xff0c;可通过GNSS预处理软件进行修复。本文介绍一款由德国波兹坦地学研究中心&#xff08;GFZ&#xff09;开发的GNSS预处理软件GFZRNX…

Mathorcup数学建模竞赛第六届-【妈妈杯】B题:车位分布的优化设计与评价(附一等奖获奖论文、lingo和matlab代码)

赛题描述 随着现代社会经济的快速发展,房地产成为国家经济发展中重要的经济增长点之一。而小区内汽车停车位的分布对于小区居民的上下班出行影响很大。请建立数学模型,解决下列问题: 问题1:分析评判小区汽车停车位分布是否合理的几个关键指标,建立评判车位分布合理的数学…

Qt之单选按钮和复选按钮(QRadioButton、QCheckBox)

文章目录QRadioButton属性示例代码&#xff1a;QCheckBox属性示例代码QRadioButton QRadioButton片这个按钮类应对多选一的场景。打开windows的画图软件&#xff0c;我们就可以看到下面的&#xff1a; 如果我们刚开始的是线&#xff0c;然后我们又想画矩形&#xff0c;则线这…

作用域、生命期和程序的组织结构

一、局部变量和全局变量 在函数内部或复合语句中定义的变量&#xff0c;称为局部变量&#xff08;local variable&#xff09;。 &#xff08;1&#xff09;在一个函数内部定义的变量&#xff1b; &#xff08;2&#xff09;函数的形式参数&#xff1b; &#xff08;3&…

微信小程序基础篇-模板与配置

本篇学习目标使用WXML渲染模板语法渲染页面结构使用WXSS样式美化结构使用app.json对项目进行全局配置使用page.json对页面进行个性化配置如何发起网络请求1.WXML模板语法1.1 数据绑定在data中定义数据&#xff1a;在页面的js文件在data对象中定义在wxml中使用数据&#xff1a;使…

记一次Windows Terminal的安装和配置

换的原因 之前一直用的cmder&#xff0c;结果突然一次更新之后&#xff0c;delete文本后显示文本错误&#xff0c;于是就换成Window Terminal了 安装 进微软商店搜或者官网跳转到微软商店 下载完后在winr里用wt可以进入 配置外观 配置&#xff08;因为我是已经配好再写博客…

【微服务笔记05】微服务组件之Ribbon负载均衡器组件介绍及其使用

这篇文章&#xff0c;主要介绍微服务组件之Ribbon负载均衡器及其使用。 目录 一、Ribbon负载均衡器 1.1、负载均衡介绍 &#xff08;1&#xff09;负载均衡概念 &#xff08;2&#xff09;负载均衡分类 &#xff08;3&#xff09;Ribbon负载均衡思想 1.2、Ribbon的使用 …

Mybatis一发入魂

文章目录Mybatis官方中文文档一、Mybatis简介二、简单入门使用2.1、在pom.xml中添加依赖2.2、使用xml配置文件2.3、创建接口2.4、创建映射文件2.6、获取sqlsession实例并执行方法三、Mybatis的Xml配置文件3.1、properties属性3.2、settings设置3.3、typeAliases类型别名3.4、en…

试题 基础练习 高精度加法(java)

试题 基础练习 高精度加法提交此题 评测记录 资源限制内存限制&#xff1a;512.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s问题描述输入两个整数a和b&#xff0c;输出这两个整数的和。a和b都不超过100位。算法描述由于a和b…

《架构300讲》学习笔记(151-200)

前言 内容来自B站IT老齐架构300讲内容。 151 Redis发布订阅机制是如何实现的&#xff1f; 152 阿里Seata分布式事务AT、TCC、SAGA、XA模式到底该怎么选&#xff1f; 153 超级实用&#xff01;十分钟掌握Prometheus与Grafana监控SpringBoot应用 154 如何利用Docker快速构建…

Java面试题每日10问(7)

Core Java - OOPs Concepts: final keyword Interview Questions 1. What is the final variable? the final variable is used to restrict the user from updating it.If we initialize the final variable, we can’t change its value.The final variable - which is not…

论文阅读笔记《Multilevel Graph Matching Networks for Deep Graph Similarity Learning》

核心思想 本文提出一种多级图匹配网络&#xff08;MGMN&#xff09;用于图相似性的度量。常见的图相似性网络都是利用图神经网络或其他图嵌入技术将整幅图转化为特征向量&#xff0c;然后计算两个特征向量之间的相似程度。这种做法的缺点在于只关注了图一级的信息交互&#xff…