首页 > 其他分享 >一、Vue.js介绍

一、Vue.js介绍

时间:2022-08-14 16:23:30浏览次数:89  
标签:Vue DOM vm 介绍 js JS data

一、介绍

Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。

vue.js是目前前端web开发最流行的工具库,由尤雨溪在2014年2月发布的。

VUE3文档:https://v3.cn.vuejs.org/guide/introduction.html

1.1、安装

Vue.js 设计的初衷就包括可以被渐进式地采用。这意味着它可以根据需求以多种方式集成到一个项目中。

将 Vue.js 添加到项目中主要有四种方式:

  1. 在页面上以 CDN 包的形式导入。

    <script src="https://cdnjs.cloudflare.com/ajax/libs/vue/3.0.5/vue.global.js"></script>

  

  1. 下载 JavaScript 文件并自行托管

  2. 使用 npm 安装它。

  3. 使用官方的 CLI 来构建一个项目,它为现代前端工作流程提供了功能齐备的构建设置 (例如,热重载、保存时的提示等等)。

1.2、基本使用

(1)基本案例

Vue.js 的核心是一个允许采用简洁的模板语法来声明式地将数据渲染进 DOM 的系统。我们不再和 HTML 直接交互了。一个 Vue 应用会将其挂载到一个 DOM 元素上 (对于这个例子是 #app) 然后对其进行完全控制。那个 HTML 是我们的入口,但其余都会发生在新创建的 Vue 实例内部。Vue是数据驱动页面。

 
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/vue/3.0.5/vue.global.js"></script>
</head>
<body>

<div id="app">
    <!-- 设置vue可以操作的html内容范围,值一般就是css的id选择器。 -->
    <p>{{ msg }}</p>
</div>

<script>

    const Counter = {
        data() {
            return {
                msg: "hello world"
            }
        }
    }

    vm = Vue.createApp(Counter).mount('#app')

</script>

</body>
</html>

(2)JS操作真实DOM的代价

用我们传统的开发模式,原生JS或JQ操作DOM时,浏览器会从构建DOM树开始从头到尾执行一遍流程。在一次操作中,我需要更新10个DOM节点,浏览器收到第一个DOM请求后并不知道还有9次更新操作,因此会马上执行流程,最终执行10次。例如,第一次计算完,紧接着下一个DOM更新请求,这个节点的坐标值就变了,前一次计算为无用功。计算DOM节点坐标值等都是白白浪费的性能。即使计算机硬件一直在迭代更新,操作DOM的代价仍旧是昂贵的,频繁操作还是会出现页面卡顿,影响用户体验。

(3)什么是虚拟DOM

Web界面由DOM树(树的意思是数据结构)来构建,当其中一部分发生变化时,其实就是对应某个DOM节点发生了变化,

虚拟DOM就是为了解决浏览器性能问题而被设计出来的。如前,若一次操作中有10次更新DOM的动作,虚拟DOM不会立即操作DOM,而是将这10次更新的diff内容保存到本地一个JS对象中,最终将这个JS对象一次性attch到DOM树上,再进行后续操作,避免大量无谓的计算量。**所以,**用JS对象模拟DOM节点的好处是,页面的更新可以先全部反映在JS对象(虚拟DOM)上,操作内存中的JS对象的速度显然要更快,等更新完成后,再将最终的JS对象映射成真实的DOM,交由浏览器去绘制。

Vue是数据驱动视图(数据的变化将引起视图的变化),但你发现某个数据改变时,视图是局部刷新而不是整个重新渲染,如何精准的找到数据对应的视图并进行更新呢?

整个过程还是比较简单的,新旧节点如果不相似,直接根据新节点创建dom;如果相似,先是对data比较,包括class、style、event、props、attrs等,有不同就调用对应的update函数,然后是对子节点的比较,子节点的比较用到了diff算法

vue的virtual dom的diff算法是基于snabbdom算法改造而来,与react的diff算法一样。仅在同级的vnode间做diff,递归的进行同级vnode的diff,最终实现整个DOM树的更新。

(4)MVVM 模式

MVVM 是Model-View-ViewModel 的缩写,它是一种基于前端开发的架构模式。

  • Model 指代的就是vue对象的data属性里面的数据。这里的数据要显示到页面中。

  • View 指代的就是vue中数据要显示的HTML页面,在vue中,也称之为“视图模板” 。

  • ViewModel 指代的是vue.js中我们编写代码时的vm对象了,它是vue.js的核心,负责连接 View 和 Model,保证视图和数据的一致性,所以前面代码中,data里面的数据被显示中p标签中就是vm对象自动完成的。

组件的 data 选项是一个函数。Vue 在创建新组件实例的过程中调用此函数。它应该返回一个对象,然后 Vue 会通过响应性系统将其包裹起来,并以 $data 的形式存储在组件实例中。为方便起见,该对象的任何顶级 property 也直接通过组件实例暴露出来

console.log(vm)     // 全局vue对象
console.log(vm.$data);  // vm对象要显示到页面中的数据
console.log(vm.$data.msg);  // 访问data里面的数据
console.log(vm.msg);  // 这个 name就是data里面声明的数据,也可以使用 vm.变量名显示其他数据,name只是举例.
vm.foo()

 

标签:Vue,DOM,vm,介绍,js,JS,data
From: https://www.cnblogs.com/xiaohaoge/p/16585628.html

相关文章

  • 解决小白安装vue-router后项目报错问题
    本人也正在学习Vue,记录一下学习过程中的问题今天用npminstallvue-router--save-dev命令安装vue-router,安装后启动项目报然后就开始搜大家的解决办法,说是可能vue版......
  • vue双向绑定原理分析
    1.vue双向绑定原理vue.js则是采用数据劫持结合发布者-订阅者模式的方式,通过Object.defineProperty()来劫持各个属性的setter,getter,在数据变动时发布消息给订阅者,触发相应......
  • base64.js
    --/*!*jquery.base64.js0.1-https://github.com/yckart/jquery.base64.js*MakesBase64en&-decodingsimplerasitis.**Basedupon:https://gist.gi......
  • 【前端】Windows升级nodejs到最新版本
    1、在GitHub官网,搜索gnvm,选择如下图所示的第一个,下载【gnvm.exe】可执行文件  2、将这个可执行文件放到自己安装的nodejs的根目录下,如C:\ProgramFiles\nodejs ......
  • 2022.8.14 模块化、Webpack、Vue-element-admin
    06、模块化相当于形成包6.1、简介模块化产生的背景随着网站逐渐变成”互联网应用程序”,嵌入网页的Javascript代码越来越庞大,越来越复杂。Javascript模块化编程,已经成......
  • 2022.8.17 vscode与nodejs
    大前端01、概述和前端工具vscode安装1.1、下载安装VScode下载地址:https://code.visualstudio.com/   1:双击打开vscode安装包2:指定安装目录     ......
  • vue 父子组件传值方法总结
    1、父组件向子组件传参:(1)父组件直接绑定在子组件的标签上,子组件通过props接收传递过来的参数。(2)父组件主动获取所有的参数和方法this.$refs.childrenName.(参数或方法名)......
  • ExtJS - ExtJS最佳实践
    更新记录转载请注明出处:https://www.cnblogs.com/cqpanda/p/16583543.html2022年8月14日发布。2022年8月13日从笔记迁移到博客。ExtJS教程汇总:https://www.cnblogs......
  • ExtJS - Sencha Inspector
    更新记录转载请注明出处:https://www.cnblogs.com/cqpanda/p/16583533.html2022年8月14日发布。2022年8月13日从笔记迁移到博客。ExtJS教程汇总:https://www.cnblogs......
  • three.js
    import*asTHREEfrom'three';//导入轨道控制器库import{OrbitControls}from"three/examples/jsm/controls/OrbitControls";//导入gltf模型载入库import{......