vue知识

一、初始vue

Vue核心 Vue简介 初识 (yuque.com)

1.想让Vue工作,就必须创建一个Vue实例,且要传入一个配置对象

2.root容器里的代码依然符合html规范,只不过混入了一些特殊的Vue语法

3.root容器里的代码被称为【Vue模板】

4.Vue实例和容器是一一对应的

5.真实开发中只有一个Vue实例,并且会配合着组件一起使用

6.{{xxx}}中的xxx要写js表达式,且xxx可以自动读取到data中的所有属性

7.一旦data中的数据发生改变,那么模板中用到该数据的地方也会自动更新


注意区分:js表达式 和js代码(语句)
        1.表达式:一个表达式会产生一个值,可以放在任何一个需要值的地方    

        (1).a

        (2).a+b

        (3).demo(1)

        (4).x === y?'a’:'b'
        2.js代码(语句)

        (1).if(){}

        (2).for(){}

 

二、模板语法(插值语法、指令语法) 

Vue核心 模板语法 数据绑定 (yuque.com)

Vue模板语法有2大类

1.插值语法:

功能:用于解析标签体内容。

写法:{{xxx}},xxx是js表达式,且可以直接读取到data中的所有属性

2.指令语法:
功能:用于解析标签(包括:标签属性、标签体内容、绑定事件....)

举例:v-bind:href="xxx"或简写为:href="xxx",xxx同样要写js表达式,且可以直按读取到data中的所有属性。

备注:Vue中有很多的指令,且形式都是:v-????,此处我们只是拿v-bind举个例子

三、数据绑定(单向绑定v-bind、双向绑定v-model)

Vue中有2种数据绑定的方式:

1.单向绑定(v-bind):数据只能从data流向页面。
2.双向绑定(v-model):数据不仅能从data流向页面,还可以从页面流向data。

备注:
1.双向绑定一般都应用在表单类元素上(如:input、select等)
2.v-model:value 可以简写为v-model,因为v-model默认收集的就是value值。

四、el与data的两种写法

Vue核心 el与data的两种写法 (yuque.com)

data与el的2种写法:

        1.el有2种写法

                (1).new Vue时候配置el属性。

                (2).先创建Vue实例,随后再通过vm.$mount('#root')指定el的值。

        2.data有2种写法

                (1).对象式

                (2).函数式

                如何选择:目前哪种写法都可以,以后学习到组件时,data必须使用函数式否则会报错。

        3.一个重要的原则:
                由Vue管理的所数,一定不要写箭头函数,一旦写了头所数,this就不再是vue实例了。

使用箭头函数,this就变成了window实例了

el两种写法:用el'XXX'指定哪个标签

                 或者使用v.$mount'XXX'指定那个标签

Data的两种写法

一种是对象式

另一种为函数式

注意this用法(不能用箭头函数)

五、MVVM模型(VUE参考了MVVM模型)

Vue核心 MVVM模型 数据代理 (yuque.com)

MVVM模型:

1.M:模型(Model):data中的数据

2.V:视图(View):模板代码

3.VM:视图模型(ViewModel):Vue实例

观察发现:

1.data中所有的属性,最后都出现在了vm身上。

2.vm身上所有的属性 及 Vue原型上所有属性,在Vue模板中都可以直接使用。

简单理解就是 html页面里的就是view

data中的数据是model

New Vue 就是viewModel(其中包含这data的属性,在vue模板中(html页面的{{}}中)可以直接使用)

六、数据代理(通过一个对象代理对另一个对象中属性的操作(读/写))

1、回顾defineProperty:

Object.defineProperty()是一个JavaScript内置函数,用于在对象上定义或修改属性的访问器。它接受三个参数:对象、属性名和属性描述符。

属性描述符是一个对象,其中包含了有关该属性的各种信息,例如是否可枚举、是否只读、是否可删除等。

读obj2.x可以读到obj.x的值

修改obj2.x可以修改obj.x的值

数据代理的值是隐藏的 下面都有对应的getter和setter

vm中的属性就是data中的属性,就是通过数据代理完成的

vm中的_data.name和vm中的name是一样的

vuedata中数据拷贝了一份到_data属性中,然后将_data中的属性数据通过defineProperty实现数据代理

七、事件处理(methods)

Vue核心 事件处理 (yuque.com)

事件的基本用法:

1、使用v-on:xxx或@xxx绑定事件,其中xxx是事件名

2、事件的回调需要配置在methods对象中,最终会在vm上

3、methods中配置的函数,不要用箭头函数,否在this就不是vm了

4、methods中配置的函数,都是被Vue所管理的函数,this的指向是vm或组件实例对象

5、@click=“demo"和@click=”demo($event)“效果一致,但后者可以传参

事件修饰符:

键盘事件:

八、计算属性

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker各目录含义

目录含义builder构建docker镜像的工具或过程buildkit用于构建和打包容器镜像,官方构建引擎,支持多阶段构建、缓存管理、并行化构建和多平台构建等功能containerd负责容器生命周期管理,能起、停、重启,确保容器运行。负责镜管理&am…

Git Tag:为你的代码版本打上优雅的标签

为你的代码版本打上优雅的标签 在软件开发过程中,版本控制是项目管理的重要一环。Git 作为最流行的版本控制系统之一,为我们提供了强大的工具来管理代码版本。其中,git tag 命令允许我们为代码仓库中的特定提交打上标签,这些标签…

没有京牌车如何面对五一小长假?

随着五一小长假的来临,许多人都计划着出游,享受假期的快乐。然而,对于没有京牌车的市民来说,出行可能会面临一些困扰。那么,没有京牌车该如何应对五一小长假的出行需求呢?下面北京盛昂京牌小编沐沐将为您提…

设计模式-01 设计模式单例模式

设计模式-01 设计模式单例模式 目录 设计模式-01 设计模式单例模式 1定义 2.内涵 3.使用示例 4.具体代码使用实践 5.注意事项 6.最佳实践 7.总结 1 定义 单例模式是一种设计模式,它确保一个类只能被实例化一次。它通过在类内部创建类的唯一实例并提供一个全…

实验报告5-Spring MVC实现页面

实验报告5-SpringMVC实现页面 一、需求分析 使用Spring MVC框架,从视图、控制器和模型三方面实验动态页面。模拟实现用户登录,模拟的用户名密码以模型属性方式存放在Spring容器中,控制器相应用户请求并映射参数,页面收集用户数据或…

力扣HOT100 - 131. 分割回文串

解题思路&#xff1a; class Solution {List<List<String>> res new ArrayList<>();List<String> pathnew ArrayList<>();public List<List<String>> partition(String s) {backtrack(s,0);return res;}public void backtrack(Str…

C++复盘(一)

文章目录 常量标识符命名规则数据类型sizeof关键字浮点数字符型转义字符字符串型布尔类型bool 比较运算符switch-case语句rand()随机数种子srand() goto语句一维数组函数函数的声明函数的分文件编写 指针指针所占内存空间空指针野指针const修饰指针1、常量指针2、指针常量3、co…

SpringBoot集成Flowable案例

前言 Flowable 是一个使用 Java 编写的轻量级业务流程引擎。Flowable 流程引擎可用于部署 BPMN2.0 流程定义&#xff08;用于定义流程的行业 XML 标准&#xff09;&#xff0c;创建这些流程定义的流程实例&#xff0c;进行查询&#xff0c;访问运行中或历史的流程实例与相关数…

SAP-MM-SD批次管理的影响点M3530

业务场景: 业务部门在创建物料主数据时,勾选了“批次管理”实际不需要。收货时提示输入批次,不能收货了,那回到物料主数据修改,取消勾选“批次管理”发现取消不了,报错M3530,大致内容如下: “显示错误”按钮仅在对话框模式下出现,而不是在数据传输或大规模维护中。 步…

【代码问题】【Pytorch】训练模型时Loss为NaN或INF

解决方法或者问题排查&#xff1a; 加归一化层&#xff1a; 我的问题是我新增的一个模块与原来的模块得到的张量相加&#xff0c;原张量是归一化后的&#xff0c;我的没有&#xff1a; class Module(nn.Module):def __init__(self,dim,):super().__init__()# 新增一个LayerNo…

一、交换网络基础

目录 1.交换机的转发行为 2.数据帧的类型 3.ARP地址解析步骤 Hub&#xff1a;物理层设备 交换机&#xff1a;数据链路层设备 1.交换机的转发行为 泛洪&#xff08;Flooding&#xff09;&#xff08;有可能是单播帧&#xff08;未知单播帧&#xff09;&#xff0c;也有可能是…

有没有一种可能性,你不投递简历,让HR主动联系你

你是否觉得自己得主动给某个公司投递了简历,他们才会联系你,亦或者是自己得主动在招聘APP上联系那个BOSS,他才会反过来跟你说话,又或者是你千方百计的跟他打招呼了,还是没有回应,这一节有可能让你明白,有时候是可以,你不主动,他也会主动联系你的。 目录 1 简历是如何…