Vue2入门(安装Vue、devtools,创建Vue)以及MVVM分层思想

文章目录

  • 1.下载并安装Vue
  • 2.使用Vue
    • 2.1 创建Vue以及挂载Vue
    • 2.2 模板语句的数据来源:data
    • 2.3 template配置项详解
    • 2.4 Vue实例和容器的关系
  • 3.安装devtools
  • 4.MVVM分层思想
  • 5.通过vm可以访问哪些属性

1.下载并安装Vue

(1)Vue是一个基于JavaScript(JS)实现的框架。要使用它就需要先拿到Vue的js文件,可以从官网(https://v2.cn.vuejs.org/)下载vue.js文件
(2)下载:开发生产版本更小,上线后使用。开发版本更详细,写代码的时候用。
在这里插入图片描述
(3)当使用script进行Vue安装以后,上下文中就注册了一个全局变量:Vue

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>第一个vue程序</title>// 安装Vue<script src="../js/vue.js"></script>
</head>

2.使用Vue

2.1 创建Vue以及挂载Vue

<body>// 指定Vue实例的挂载位置<div id="app"></div><script>// 创建vue实例const myVue = new Vue({template : '<h1>hello vue!</h1>'})/** 将Vue实例挂载到id='app'的元素位置,Vue实例都有一个$mount()方法,这个方法的作用是将Vue实例挂载到指定位置**/myVue.$mount('#app')</script>
</body>

(1)为什么要new Vue(),直接调用Vue()函数不行吗?
不行,Vue.js的源码中直接调用Vue()函数会报错:Vue is a constructor and should be called with the ‘new’ keyword
(2)Vue构造函数的参数:options,
①options翻译为选项,Vue框架要求整个options参数必须是一个纯粹的JS对象:即使用{}来表示
②在{} 对象中可以编写大量的key:value,一个key:value就是一个配置项
(3)关于template配置项,template翻译为模板。Vue的模板语句是Vue框架自己搞的一套语法规则,写的时候要遵守Vue框架的模板语法规则。模板语句可以是一个纯碎的HTML代码,也可以是Vue中的特殊规则,还可以是HTML代码+Vue的特殊规则

2.2 模板语句的数据来源:data

(1)data选项可以可以给模板语句提供数据支持,data配置项的专业叫法是:Vue实例的数据对象
(2)data选项的类型是Object | Function(对象或函数),是对象的话必须是纯粹的对象(含有零个或多个的key/value对)
(3)使用{{data的key}}来插入到模板语句中,{{}}是Vue框架自己搞的一套语法,其他框架看不懂,浏览器也不能识别;只有Vue框架自己能看懂,这种语法在Vue框架中被称为:模板语法中的插值语法

2.3 template配置项详解

(1)template后面指定的是模板语句,模板语句中只能有一个根节点
①错误例子:

template: '<h1>hello {{name}} !</h1><h1>hello!</h1>',

②正确例子:

 template: `<div><h1>hello {{name}} !</h1><h1>hello!</h1>'</div>`,

(2)只要data中的数据发生变化,模板语句一定会重新编译
(3)如果使用template配置项的话,指定挂载位置元素的内容会被替换
(4)我们可以不使用template来编写模板语句,这些模板语句可以直接写到html标签中,Vue框架能够找到并编译,然后渲染。如果直接将模板语句编写到HTML标签中,指定的挂载位置就不会被替换了。

<body><div id="app"><div>{{name}}</div><div>{{age}}</div></div><script>const myVue = new Vue({data: {name: '狂飙',age: 28}})myVue.$mount('#app')</script>
</body>

(5)也可以不使用$mount('#app')的方式进行挂载,在Vue中有一个配置项:el可以和$mount达到同样的效果

<body><div id="app"><div>{{name}}</div><div>{{age}}</div></div><script>const myVue = new Vue({data: {name: '狂飙',age: 28},el: '#app'})</script>
</body>

2.4 Vue实例和容器的关系

一个Vue实例只能接管一个容器

3.安装devtools

(1)搜索极简插件
在这里插入图片描述
(2)搜索
在这里插入图片描述
(3)浏览器扩展程序中把解压过来的文件,开启开发者模式后直接拖过来就好
在这里插入图片描述

在这里插入图片描述
(4)注意:data中如果是纯中文,可能会导致显示不出来

4.MVVM分层思想

(1)MVVM是什么?
①M:Model(模型/数据),表示当前页面渲染时所依赖的数据源
②V:View(视图):表示当前页面所渲染的DOM结构
③VM:ViewModel(视图模型):它是MVVM的核心
(2)Vue框架虽然没有完全遵循MVVM模型,但是Vue框架基本上也是符合MVVM思想的。在文档中经常会使用vm(ViewModel的缩写)这个变量名来表示Vue实例
(3)ViewModel 作为 MVVM 的核心,是它把当前页面的数据源(Model)和页面的结构(View)连接在了一起。
在这里插入图片描述
①当数据源发生变化时,会被 ViewModel 监听到,VM 会根据最新的数据源自动更新页面的结构
②当表单元素的值发生变化时,也会被 VM 监听到,VM 会把变化过后最新的值自动同步到 Model 数据源中
③我们不再需要去编写操作DOM的JS代码了,开发效率提高了很多

5.通过vm可以访问哪些属性

(1)vue实例中的属性有很多,有的以$开始,有的以_开始
①所有以$开始的属性,可以看做是公开的属性,这些属性是供程序员使用的
②所有以_开始的属性,可以看做是私有的属性,这些属性是vue框架底层使用的,我们程序员很少使用
(2)通过vm也可以访问Vue实例对象的原型对象上的属性,例如:vm.$delete

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

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

相关文章

搭建高可用k8s

高可用只针对于api-server&#xff0c;需要用到nginx keepalived&#xff0c;nginx提供4层负载&#xff0c;keepalived提供vip(虚拟IP) 系统采用openEuler 22.03 LTS 1. 前期准备 因为机器内存只有16G&#xff0c;所有我采用3master 1node 1.1 修改主机配置&#xff08;所有节…

扩散模型会成为深度学习的下一个前沿领域吗?

文章目录 一、说明二、 第 1 部分&#xff1a;了解扩散模型2.1 什么是扩散模型2.2 正向扩散2.3 反向扩散 三、他们的高成本四、扩散模型的用处五、为什么扩散模型如此出色六、第 2 部分&#xff1a;使用扩散模型生成6.1 用于自然语言处理和 LLM 的文本扩散6.2 音频视频生成6.3 …

下载安装Thonny并烧录MicroPython固件至ESP32

Thonny介绍 一、Thonny的基本特点 面向初学者&#xff1a;Thonny的设计初衷是为了帮助Python初学者更轻松、更快速地入门编程。它提供了直观易懂的用户界面和丰富的功能&#xff0c;降低了编程的门槛。轻量级&#xff1a;作为一款轻量级的IDE&#xff0c;Thonny不会占用过多的…

RDK X3(aarch64) 测试激光雷达思岚A1

0. 环境 - 亚博智能的ROSMASTER-X3 - RDK X3 1.0 0.1 资料 文档资料 https://www.slamtec.com/cn/Support#rplidar-a-series SDK https://github.com/slamtec/rplidar_sdk ROS https://github.com/slamtec/rplidar_ros https://github.com/Slamtec/sllidar_ros2 1. robostu…

NestJs Prisma常见问题(避坑指南)

关联模型操作 查询子模型多对一情况下&#xff0c;不需要include被关联模型也能查出自己外键id多对一模型新增数据时&#xff0c;被关联的外键传值&#xff0c;如果model配置的外键为非必填(?)&#xff0c;创建将会报错&#xff0c;多对一不能将外键设置为空持久化数据到数据…

SpringBoot实现上传头像(查看头像)

SpringBoot实现上传头像给功能和查看头像功能 文章目录 目录 文章目录 1.上传头像 1.这里的AppConfig记得定义一下 2.引入AppConfig 3.上传文件代码 2.获取头像 1.实现readFile方法 1.上传头像 首先我的代码中在application.properties中设置了上传文件的根目录 project.folder…

1310. 子数组异或查询 异或 前缀和 python

有一个正整数数组 arr&#xff0c;现给你一个对应的查询数组 queries&#xff0c;其中 queries[i] [Li, Ri]。 对于每个查询 i&#xff0c;请你计算从 Li 到 Ri 的 XOR 值&#xff08;即 arr[Li] xor arr[Li1] xor ... xor arr[Ri]&#xff09;作为本次查询的结果。 并返回一…

CPASSOC代码详解

加载环境 library("MASS") require(MASS) # Modern Applied Statistics with S&#xff0c;"S"指的是S语言&#xff0c;由贝尔实验室的约翰钱伯斯&#xff08;John Chambers&#xff09;等人开发。S语言是R语言的前身&#xff0c;许多R语言的语法和功能都…

《精通ChatGPT:从入门到大师的Prompt指南》附录B:推荐阅读资源

作者&#xff1a;斯图尔特拉塞尔 (Stuart Russell) 和 彼得诺维格 (Peter Norvig) 简介&#xff1a;这本书被誉为人工智能领域的经典教材&#xff0c;内容涵盖了AI的基本原理、算法及其应用。无论是入门者还是专业研究者&#xff0c;都能从中获得启发。 2. 《深度学习》 作者…

【目标跟踪网络训练 Market-1501 数据集】DeepSort 训练自己的跟踪网络模型

前言 Deepsort之所以可以大量避免IDSwitch&#xff0c;是因为Deepsort算法中特征提取网络可以将目标检测框中的特征提取出来并保存&#xff0c;在目标被遮挡后又从新出现后&#xff0c;利用前后的特征对比可以将遮挡的后又出现的目标和遮挡之前的追踪的目标重新找到&#xff0…

企业网页制作

随着互联网的普及&#xff0c;企业网站已成为企业展示自己形象、吸引潜在客户、开拓新市场的重要方式。而企业网页制作则是构建企业网站的基础工作&#xff0c;它的质量和效率对于企业网站的成败至关重要。 首先&#xff0c;企业网页制作需要根据企业的特点和需求进行规划。在网…

前端 移动端 手机调试 (超简单,超有效 !)

背景&#xff1a;webpack工具构建下的vue项目 1. 找出电脑的ipv4地址 2. 替换 host 3. 手机连接电脑热点或者同一个wifi 。浏览器打开链接即可。

Spring运维之业务层测试数据回滚以及设置测试的随机用例

业务层测试数据回滚 我们之前在写dao层 测试的时候 如果执行到这边的代码 会在数据库 里面留下数据 运行一次留一次数据 开发有开发数据库&#xff0c;运行有运行数据库 我们先连数据库 在pom文件里引入mysql的驱动和mybatis-plus的依赖 在数据层写接口 用mybatis-plus进…

浅谈JDBC

文章目录 一、什么是 JDBC&#xff1f;二、JDBC 操作流程三、JDBC代码例子 一、什么是 JDBC&#xff1f; JDBC是一种可用于执行SQL语句的JAVA API&#xff0c;是链接数据库和JAVA应用程序的纽带。JDBC一般需要进行3个步骤&#xff1a;与数据库建立一个链接、向数据库发送SQL语…

当AGI能够自我复制并传播到任意电脑时,会怎样?

当人工通用智能&#xff08;AGI&#xff09;具备自我复制能力&#xff0c;并能够传播到任何一台计算机作为宿主机时&#xff0c;这种情景可能带来一系列深远的影响和挑战。以下是一些潜在的影响和可能的结果&#xff1a; 1. 安全威胁与恶意利用 AGI的自我复制和传播能力可能被…

openh264 场景变化检测算法源码分析

文件位置 openh264/codec/processing/scenechangedetection/SceneChangeDetection.cppopenh264/codec/processing/scenechangedetection/SceneChangeDetection.h 代码流程 说明&#xff1a; 通过代码流程分析&#xff0c;当METHOD_SCENE_CHANGE_DETECTION_SCREEN场景类型为时…

Web前端工资调整:深入剖析与全面解读

Web前端工资调整&#xff1a;深入剖析与全面解读 在快速发展的互联网行业中&#xff0c;Web前端技术日新月异&#xff0c;而与之紧密相关的工资调整也成为了业内热议的话题。本文将从四个方面、五个方面、六个方面和七个方面&#xff0c;深入剖析Web前端工资调整的原因、趋势、…

Linux -- 了解 vim

目录 vim Linux 怎么编写代码&#xff1f; 了解 vim 的模式 什么是命令模式&#xff1f; 命令模式下 vim 的快捷键&#xff1a; 光标定位&#xff1a; 复制粘贴&#xff1a; 删除及撤销&#xff1a; 注释代码&#xff1a; 什么是底行模式&#xff1f; ​编辑 ​编辑…

Java:111-SpringMVC的底层原理(中篇)

这里续写上一章博客&#xff08;110章博客&#xff09;&#xff1a; 现在我们来学习一下高级的技术&#xff0c;前面的mvc知识&#xff0c;我们基本可以在67章博客及其后面相关的博客可以学习到&#xff0c;现在开始学习精髓&#xff1a; Spring MVC 高级技术&#xff1a; …

输入与随机数

Java的两个类库 输入 如何实现键盘输入&#xff1f;我们需要了解到Scanner这个类&#xff0c;其作用于及键盘输入。 类库&#xff1a;java.util 如何使用&#xff1f;分为3步走&#xff1a; 导入包&#xff08;一般idea会帮做&#xff09; import java.util.Scanner;创建对…