Vue基础知识点

一、Vue中的MVVM的理解

M - 模型(Model):数据模型。负责数据存储。泛指后端进行的各种业务逻辑处理和数据操控,主要围绕数据库西戎展开。
V - View 视图:负责页面展示,也就是用户界面。主要由HTML和CSS来构建。
VM - 视图模型:负责业务逻辑处理(比如Ajax请求等),对数据进行加工后交给视图展示。
通过vue类创建的对象叫Vue实例化对象,这个对象就是MVVM模式中的VM层,模型通过它可以将数据绑定到页面上,视图可以通过它将数据映射到模型上。
优点:

1、低耦合。视图(View)可以独立与Model辩护和修改。
2、可重用性。可以把一些试图逻辑放在一个ViewModel里面,让很多view重用这段视频逻辑。
3、前后端分离。开发人员可以专注于业务逻辑(ViewModel)和数据的开发,设计人员可以专注于页面设计。

二、Vue渐进式的javascript框架

Vue允许将一个网页分割成可复用的组件,每个组件都包含属于自己的HTML、CSS、JAVASCRIPT以用来渲染网页中相应的地方。对于Vue的使用可大可小它都会有相应的方式来整合到你的项目中。所以说它是一个渐进式的框架。Vue是响应式的(reactive)这是Vue最独特的特性,也就是说我们的数据变更时,Vue会帮你更新所有的网页中用到它的地方。

三、Vue生命周期

beforeCreate(创建前):组件实例被创建之初,组件的属性生效之前
// beforeCreate生命周期执行的时候,data和methods中的数据还没有初始化,不能在这个阶段使用data中的数据和methods中的方法
created(创建后):组件实例已经完全创建,属性也绑定,但真实的 dom 还没有生成,$el 还不能使用
// data和methods都应经被初始化好了,如果要调用methods 中的方法,或者操作 data 中的数据,最早可以在这个阶段中操作
beforeMount(挂在前):在挂在开始之前被调用,相关的 render 函数首次被调用
// 执行到这个钩子的时候,在内存中已经编译好了模板了,但是还没有挂载到页面中,此时,页面还是旧的
mounted(挂载后):在 el 被新创建的 vm.$el 替换,并挂载到实力上去之后调用该钩子
// 到mounted周期的时候,Vue实例已经初始化完成了。此时组件脱离了创建阶段,进入到了运行阶段。如果我们想要通过插件操作页面上的 dom 节点,最早可以在这个阶段中进行
beforeUpdate(更新前):组建数据更新之前调用,真实 dom 还没被渲染
// 当执行这个钩子时,页面中显示的数据还是旧的,data 中的数据是更新后的,页面还没有和罪行的数据保持同步
updata(更新后):组件数据更新之后
// 页面现实的数据和data中的数据已经保持同步了,都是最新的
activated(激活前):keep-alive 专属,组件被激活时调用
// 当组件被切回来时,再去缓存里照这个组件、触发 activated 钩子函数。
deactivated(激活后):keep-alive专属,组件被销毁是调用
// 当组件被换掉时,会被缓存到内存中、触发 deactivated 生命周期
beforeDestory(销毁前):组件销毁前调用
// Vue 实例从运行阶段进入到销毁阶段,这个时候上所有的 data、methods、指令、过滤器... 都是处于可用状态,还没有真正被销毁,
destoryed(销毁后):组件销毁后调用
// 这个时候所有的 data、methods、指令、过滤器... 都是处于不可用状态。组件已经被销毁了。

Vue实例从创建到销毁的过程,就是生命周期。从开始创建、初始化数据、编译模板、挂载 dom -> 渲染、更新->渲染、销毁等一系列过程,被称之为Vue 的生命周期

Vue子组件和父组件的执行顺序

加载渲染过程:beforeCreate(父) -> cerated(父) -> beforeMount(父) -> beforeCreate(子) -> cearted(子) -> beforeMount(子) -> mounted(子) -> mounted(父)
更新过程:beforeUpdate(父) -> beforeUpdate(子) -> updatad(子) -> updatad(父)
父组件更新:beforeUpdate(父) -> updatad(父)
销毁过程:beforeDestory(父) -> beforeDestory(子) -> destoryed(子) -> destoryed(父)

v-el 作用是什么

提供一个在页面上已经存在的 DOM 元素最为 Vue 实例的挂载目标。可以使 CSS 选择器。也可以是一个 HTMLElement 实例。

Vue实现数据上想绑定的原理:Object.defineProperty()

Vue 实现数据双向绑定主要是:采用数据劫持结合发布者-订阅者的方式,通过Object.defineProperty()来劫持各个属性的settergetter,在数据变动时发布给订阅者,触发相应的监听回调。
Vue的数据双向绑定,将MVVM作为数据绑定入口,整合ObserverCompileWatcher三者,通过Observer来监听自己的model的数据变化,通过Compile来解析编译模板指令(Vue 中是用来解析{{}}),最终利用Watcher搭起ObserverCompile之间的通信桥梁,达到 数据变化->视图更新;视图交互变化(input)-> 数据model变更双向绑定效果。
数据双向绑定示例

<body>
    <div id="app">
    <input type="text" id="txt">
    <p id="show"></p>
</div>
</body>
<script type="text/javascript">
    var obj = {}
    Object.defineProperty(obj, 'txt', {
        get: function () {
            return obj
        },
        set: function (newValue) {
            document.getElementById('txt').value = newValue
            document.getElementById('show').innerHTML = newValue
        }
    })
    document.addEventListener('keyup', function (e) {
        obj.txt = e.target.value
    })
</script>

注:https://blog.csdn.net/qq_45659769/article/details/119564784

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352

推荐阅读更多精彩内容

  • https://juejin.im/post/5d5375a0f265da03db076f59#heading-3...
    world_7735阅读 511评论 0 1
  • 每个 Vue 应用都是通过用 Vue 函数创建一个新的 Vue 实例开始的: 实例生命周期钩子 每个 Vue 实例...
    Timmy小石匠阅读 1,376评论 0 11
  • 前言 本文以前端面试官的角度出发,对 Vue 框架中一些重要的特性、框架的原理以问题的形式进行整理汇总,意在帮助作...
    lessonSam阅读 377评论 0 0
  • 概述 Vue 的特点是: 响应式编程:保持状态和视图的同步(数据绑定) 组件化:一切都是组件 Vue 只关注 da...
    bowen_wu阅读 258评论 0 0
  • vue的特点 Vue.js是一款轻量级的以数据驱动(数据的变化将引起视图的变化)的构建单页面应用的mvvm框架,它...
    阿踏阅读 1,919评论 1 11