复习V2+V3之——01 前言回顾

news2024/12/23 9:34:46

前言

Vue的特点

  • 采用组件化的模式,提高代码复用率,让代码更好维护

  • 声明式编码,开发者无需直接操作DOM,提高开发效率

  • 使用虚拟DOM + Diff算法,尽量复用DOM节点

    • 虚拟DOM(Virtual DOM):
      在Vue中,虚拟DOM)是一种用JS对象表示真实DOM的轻量级表示形式。它是Vue的核心概念之一,用于提高性能并优化DOM操作。
      当我们编写Vue模板时,实际上是在描述应该如何渲染真实的DOM结构。而虚拟DOM则是根据这个模板生成的一棵以JavaScript对象表示的树形结构,它与真实的DOM节点对应。

    • Diff算法:
      diff算法是虚拟DOM实现的关键步骤,用于比较新旧虚拟DOM树的差异。它的核心思想是通过最小化操作来更新DOM,使得整个更新过程更加高效。

    在这里插入图片描述

Vue官网

V2官网这里有很多好用的第三方库:
在这里插入图片描述

初识Vue

1.准备好一个容器,比如这里我在body里面写了一个id为root的div:
在这里插入图片描述

2.想让Vue工作,就必须创建一个Vue实例,并且传入一个配置对象:
在这里插入图片描述

3.root容器里面的东西仍然符合HTML规范,只不过会混合一些Vue语法,Vue去解析容器里面的Vue语法,把其替换成Vue实例里面的内容。

Vue模板语法

HTML中包含了一些JS的语法代码,分为

  • 插值语法(双大括号表达式) —用于指定标签体内容(就是被一个html标签包裹起来的内容)
  • 指令语法(以v-开头)—功能很强大,可以用来解析标签

插值语法是用来解析标签体的内容,语法:{{xxxx}} , xxxx就会作为js的表达式被解析。xxxx要写js的表达式,且xxxx可以自动读取到data中的所有属性。一旦data中的数据产生变化,那么页面中使用该数据的地方会自动变化。

指令语法:
(1)功能:解析标签属性、解析标签内容、绑定事件。
(2)举例:v-bind:href=“xxxx” , xxxx就会作为js的表达式被解析。
v-bind: 可以简写为 :

数据绑定

单向数据绑定

1.语法:v-bind:href = "xxx" 或者简写为 :href="xxx"
2.特点:数据只能从data流向页面,反之不行。

双向数据绑定

1.语法:v-model:value = "xxx" 或者简写为 v-model="xxx"

  • 注意:双向数据绑定一般都应用在表单类元素上面(如inputselect等等) 。
  • v-model:value 可以简写为 v-model ,因为它默认收集的就是value值。

2.特点:数据不仅能从data流向页面,还能从页面流向data。

el的两种写法

  • el的两种写法你用哪一种都可以。
    在这里插入图片描述
    在这里插入图片描述

data的两种写法

  • data的两种写法,对象式和函数式。
  • 在之后用组件来写Vue的时候,一般用函数式来写data。
    在这里插入图片描述
  • 要注意的是,在用函数式写data的时候,函数体不要写成箭头函数,就写成普通函数,否则this就不是指向这个函数本身了,而是指向全局window。另外,一般还可以把:function 省略,则直接写成这样
data(){
	console.log('@@@',this)
	return{
    	name:'尚硅谷'
    }
}

Vue与MVVM模型

在这里插入图片描述

Object.defineProperty 方法

基本配置项

比如说我们现在有这么一个对象person

let person = {
	name:'张三',
	sex:'男性'
}

然后我们要对它追加一个age属性,那就可以这么写:

Object.defineProperty(person,'age',{
	value:18,
	enumerable:true,//控制属性是否可以枚举,默认值是false
	writable:true,//控制属性是否可以被修改,默认值是false
	configurable:true //控制属性是否可以被删除,默认值是false
})

此时我们就会得到追加age属性的一个Object对象:
在这里插入图片描述

getter

除了value, enumerable, writable, configurable这些基本配置之外,还有一些高级配置,比如说:getter函数

let number = 18
let person = {
	name:'张三',
	sex:'男性'
}

Object.defineProperty(person,'age',{
	// 当有人读取person的age属性的时候,get函数(getter)就会被调用,且返回值就是age的值
	get:function(){
		return 'hello'
	}
})

这样一来,我们一开始加载出来的就是:
在这里插入图片描述

然后我们再点一下括号里面的省略号,就会变成这样:
在这里插入图片描述

还可以把return的值改成


 get: function () {
                return number
            }

在控制台改变number的属性值,就会变成这样:
在这里插入图片描述

setter

还有可能是这样:

let number = 18
let person = {
	name:'张三',
	sex:'男性'
}

Object.defineProperty(person,'age',{
	get: function () {
         return number
    },

	// 当有人修改了person的age属性的时候,set函数(setter)就会被调用,且会收到修改的具体值
	set(value){
		console.log('有人修改了age属性,且值是',value)
		number = value
	}
})

在这里插入图片描述

小结:

number 和 person 本身是独立的,但是在Object.defineProperty里面,借助gettersetter,两个函数起到的就是桥梁的作用,通过该函数,一旦我们修改了对象中属性的值→触发了setter,那么getter就会自动触发,这样就可以直接更新dom元素,我们就可以直观的看到页面更新。
(靠getter去读取,靠setter去修改)

在 Vue2.x 的版本中,双向绑定是基于 Object.defineProperty 方式实现的。

Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性,并返回此对象。

该方法接受三个参数,第一个参数是 obj:要定义属性的对象,第二个参数是 prop:要定义或修改的属性的名称或 Symbol,第三个参数是 descriptor:要定义或修改的属性描述符。

在这里插入图片描述

那么为什么Object.defineProperty方法能够用于实现数据的双向绑定呢?

在Vue.js中,在初始化数据对象时,会使用Object.defineProperty方法将数据对象的属性转化为gettersetter,从而实现对数据的监听。当访问数据对象的属性时,实际上会触发定义的getter函数,而当对属性进行赋值时,会触发定义的setter函数。这样,Vue.js能够在数据变动时得到通知,并执行相应的操作,比如更新视图。

通过拦截属性的读取和设置过程,Vue.js能够跟踪依赖的属性以及触发属性变化时需要更新的操作,从而实现了数据的响应式。

在上面的例子中,我们通过Object.defineProperty将person对象的age属性转化为getter和setter。当修改data.age的值时,会调用setter函数并执行相关的更新操作;而当获取data.name的值时,会调用getter函数并返回this.age的值。

Vue.js利用了Object.defineProperty的这个特性,通过劫持数据对象的属性,实现了对数据的监听和更新,从而实现了响应式的数据绑定。

理解数据代理

比如说我们现在的页面是这样写的:
在这里插入图片描述
我们现在在Vue实例vm里面写了data对象,并且在里面写了name和address
当有人在页面中读取name的时候,getter就会去读取data.name的内容
当有人在页面中修改name的时候,setter就会去修改data.name的内容
接下来我们来验证一下这个过程(也就是这两根线)
在这里插入图片描述

用浏览器打开页面:
在这里插入图片描述
那么我们之所以可以在页面上面看到name的地方显示的是尚硅谷,就是因为它访问了vm.name,然后vm.namegetter函数工作获取到了data里面的name的具体内容,所以可以显示出来尚硅谷

我们再在控制台修改vm.name,这个时候就是调用了settter,setter收到了你要改的vm.name的内容,然后去改data里面的name的内容。

可以看到,页面的显示内容也发生了改变:
在这里插入图片描述
再来看看data的内容:确实也发生了改变。
在这里插入图片描述

小结

数据代理其实就是把vm里面的_data里面的数据,copy了一份放在vm身上,从而使得我们写代码更加方便,可以直接用{{name}}去访问,这一波操作都是通过Object.defineProperty来实现的
在这里插入图片描述

	1.Vue中的数据代理:
		通过vm对象来代理data对象中属性的操作(读/写)
	2.Vue中数据代理的好处:
		更加方便的操作data中的数据
	3.基本原理:
		通过Object.defineProperty()把data对象中所有属性添加到vm上
		为每一个添加到vm上的属性,都指定一个getter/setter
		在getter/setter内部去操作(读/写)data中对应的属性

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

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

相关文章

JAVA 牛客网 NC32求平方根

题目如图&#xff1a; 先展示代码&#xff1a; import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定&#xff0c;请勿修改&#xff0c;直接返回方法规定的值即可*** param x int整型* return int整型*/public int sqrt (int x) {if(x<2)…

递归回溯两个例题:1.数组组合 2.在矩阵中搜索单词

题目1&#xff1a;组合 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案。 输入&#xff1a;n 4, k 2 输出&#xff1a; [ [2,4], [3,4], [2,3], [1,2], [1,3], [1,4], ] 解题思路&#xff1a; 1.定…

Mac苹果电脑也可以玩原神了,运行流程,nice~

最近发现了一个很棒的工具&#xff0c;他可以让你的 Mac 苹果电脑运行原神&#xff0c;而且画质和流畅度都是在线的&#xff0c;今天分享给大家 软件名字叫 playCover &#xff0c;根据作者的介绍这款软件最初就是国外的一位博主想在 Mac 上玩原神特意开发的一款软件&#xff…

代码随想录二刷 day45 | 动态规划 之 70. 爬楼梯 (进阶) 322. 零钱兑换 279.完全平方数

day45 70. 爬楼梯 &#xff08;进阶&#xff09;1. 确定dp数组以及下标的含义2.确定递推公式3.dp数组如何初始化4.确定遍历顺序5.举例来推导dp数组 322. 零钱兑换1. 确定dp数组以及下标的含义2.确定递推公式3.dp数组如何初始化4.确定遍历顺序5.举例推导dp数组 279.完全平方数1.…

作为一名研究生/博士生,我应该知道什么

今天分享的是一位深度学习领域的大佬在2020年7月份写的一篇博客&#xff0c;看完或许对有缘的你带来些启发。 英文原址&#xff1a;大佬博客地址 https://theorangeduck.com/page/reproduce-their-results 1&#xff1a;我希望作为一名研究生我知道什么 在我攻读博士学位之初…

vue 多级导航菜单

目录&#xff0c;三个文件 tree-node.vue <template><div class"tree-node-container"><node-content></node-content><divclass"tree-node-children":style"{paddingLeft: indent}"v-if"nextShow">&l…

力扣 47. 全排列 II

题目来源&#xff1a;https://leetcode.cn/problems/permutations-ii/description/ C题解1&#xff1a;这道题需要有两个不同的数组来标记使用过的元素&#xff0c;一个存放同层使用过的元素&#xff0c;根据元素数值来判断&#xff0c;范围为[-10,10]&#xff0c;在同层更新即…

95、基于STM32单片机烟雾温度报警器设计火灾防火检测可燃气体监测系统设计(程序+原理图+任务书+参考论文+开题报告+元器件清单等)

摘 要 本设计采用使用STM32F103作为控制器件&#xff0c;MQ-2型半导体可燃气体敏感元件烟雾传感器作为检测烟雾器件&#xff0c;DS18B20温度传感器作为温度检测器件&#xff0c;蜂鸣器和电源指示灯作为报警器件&#xff0c;继电器作为水泵的控制器件。烟雾报警器主要由烟雾信…

动态多目标优化算法:基于自适应启动策略的混合交叉动态约束多目标优化算法(MC-DCMOEA)求解CEC2015(提供MATLAB代码)

一、动态多目标优化问题 1.1问题定义 1.2 动态支配关系定义 二、 基于自适应启动策略的混合交叉动态多目标优化算法 基于自适应启动策略的混合交叉动态多目标优化算法&#xff08;Mixture Crossover Dynamic Constrained Multi-objective Evolutionary Algorithm Based on S…

mysql sysdate()不走索引问题解析

1.常规比较 结论: SYSDATE()返回执行时间,而NOW()返回时间常量 2.索引比较 结论: 因为SYSDATE()是非确定性的,索引不能用于评估求值引用它的表达式,所以不走索引

隐语1.0正式发布|MVP部署体验包、资源调度框架Kuscia全新亮相!

2023 年 7 月 7 日&#xff0c;在世界人工智能大会组委会办公室指导下&#xff0c;隐语开源社区携手蚂蚁集团和机器之心共同主办的数据要素与隐私计算论坛在上海世博会议中心举行。论坛上&#xff0c;蚂蚁集团隐私计算部总经理、隐语社区负责人王磊发布了隐语 1.0 版本&#xf…

java项目之美食推荐管理系统(ssm+mysql+jsp)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于ssm的美食推荐管理系统。 开发环境&#xff1a; 后端&#xff1a; 开发语言&#xff1a;Java 框架&#xff1a;ssm&#xff0c;mybatis JDK版…

docker环境部署postgres版本nacos

1、docker安装postgres 执行命令&#xff1a;docker pull postgres 拉取最新版postgres 2、查看postgres镜像是否安装成功: docker imags(查看镜像)&#xff0c;可以看到已经拉取到了最新版本 的postgres镜像 3、编辑一个docker-compose.yml文件&#xff0c;账号是postgres&a…

信息化建设的需求下,企业如何部署管理平台?并保障其应用落地?

系统部署已久&#xff0c;为何始终无法落地应用&#xff1f; 随着信息化建设的快速发展&#xff0c;企业高效管理的需求日益增长。传统IT服务缺乏统一管理平台&#xff0c;服务流程不够灵活&#xff0c;运维工作效率低下&#xff0c;亟需一个灵活、高效的运维管理模式。 而在认…

大禹智库:下一代向量数据库——具备可视化的AI 原生云向量数据库

日前&#xff0c;业界正式发布国内首个 具备可视化和自动化的AI 原生云向量数据库 " 据悉&#xff0c;向量数据库专门用于存储和查询向量数据&#xff0c;业界称之为大模型的 " 海马体 "&#xff0c;可解决大模型预训练成本高、没有 " 长期记忆 "、知…

Spring Mvc:初识SpringMvc

编译软件&#xff1a;IntelliJ IDEA 2019.2.4 x64 操作系统&#xff1a;win10 x64 位 家庭版 Maven版本&#xff1a;apache-maven-3.6.3 Mybatis版本&#xff1a;3.5.6 SpringMvc版本&#xff1a;5.3.1 文章目录 一、SpringMvc是什么&#xff1f;二、SpringMvc是如何执行业务流…

OpenGL入门教程——PT1

由于自己不是计算机图形学出身&#xff0c;所以采纳了一些教材、博客、GPT的综合答案&#xff0c;尽可能作为一篇认识图形学&#xff0c;学会OpenGL简单函数库的博客&#xff01;多多包涵 我会从最基础的显示相关知识逐步导入OpenGL 一、屏幕是如何工作的&#xff0c;为什么电…

Apache Doris 0.15.3升级至1.1.5避坑实用总结

概述&#xff1a; ​ Apache Doris 从0.15到1.1.5属于一个大版本升级&#xff0c;部分语法和使用方式也发生了较大的变化&#xff0c;本文除前期兼容性调研&#xff08;可以通过官网查到到一部分兼容性问题&#xff09;已知问题外&#xff0c;生产环境正式升级之后遇到的突发问…

【Web 安全】刚开始学渗透,零基础怎么入门?

上周旁听了一个大学学长组织的线上网络安全交流会&#xff0c;里边不乏充斥着各位行业大牛&#xff0c;讲的内容确实精彩&#xff0c;可能对于网络安全经验 5 年的人来说&#xff0c;是受益匪浅&#xff0c;欢迎程度极高&#xff0c;恨不得跳出屏幕来表示赞同&#xff0c;毕竟很…

2022年06月份青少年软件编程Scratch图形化等级考试试卷三级真题(含答案)

2022-06 Scratch三级真题 分数&#xff1a;100 题数&#xff1a;38 测试时长&#xff1a;60min 一、单选题(共25题&#xff0c;共50分) 1.点击绿旗&#xff0c;舞台上的角色会说出&#xff1f;&#xff08; &#xff09;(2分) A. 2022年5月1日 B. 1日5月2022年 C. 2022…