带你了解 vue-next(Vue 3.0)之 初入茅庐

栏目: IT技术 · 发布时间: 4年前

内容简介:这几天,陆续学习了解了关于vue-next(Vue 3.0)(https://github.com/vuejs/vue-next)的一些新特性,尤其是新的笔者在阅读源码看到,

带你了解 vue-next(Vue 3.0)之 初入茅庐

这几天,陆续学习了解了关于vue-next(Vue 3.0)(https://github.com/vuejs/vue-next)的一些新特性,尤其是新的 CompositionAPI 的用法。这套新的API中最重要、最核心的部分,恐怕就是实现响应式功能的这一块了。而且,这套响应式API不仅可以在 vue-next 环境下使用,也可以独立使用。

笔者在阅读源码看到, vue-next 已全部由 TypeScript 构建,看来 ts 必学技能。接下来带你了解vue-next。

vue-next 计划并已实现的主要架构改进和新功能:

  • 使用模块化架构

  • 优化 "Block tree"

  • 更激进的 static tree hoisting 功能

  • 支持 Source map

  • 内置标识符前缀(又名 "stripWith")

  • 内置整齐打印(pretty-printing)功能

  • 移除 source map 和标识符前缀功能后,使用 Brotli 压缩的浏览器版本精简了大约  10KB

运行时(Runtime)的更新主要体现在以下几个方面:

  • 速度显著提升

  • 同时支持 Composition API 和 Options API,以及 typings

  • 基于 Proxy 实现的数据变更检测

  • 支持 Fragments

  • 支持 Portals

  • 支持 Suspense w/ async setup()

最后,还有一些 2.x 的功能尚未移植过来,如下:

  • SFC compiler

  • Server-side rendering (服务端渲染SSR)

==目前不支持IE11==

vue-next(Vue 3.0) 的源码虽然发布了,但是预计最早也需要等到 2020 年第一季度才有可能发布 3.0 正式版。

目录剖析

代码仓库中有个 packages 目录,里面主要是 vue-next 的相关源码功能实现,具体内容如下所示。

  • compiler-core: 平台无关的编译器,它既包含可扩展的基础功能,也包含所有平台无关的插件。 暴露了 AST 和 baseCompile 相关的 API,它能把一个字符串变成一棵 AST

  • compiler-dom: 基于compiler-core封装针对浏览器的compiler

  • runtime-core: 与平台无关的运行时环境。 支持实现的功能有虚拟 DOM 渲染器、Vue 组件和 Vue 的各种API, 可以用来自定义 renderer ,vue2中也有

  • runtime-dom: 针对浏览器的 runtime。 其功能包括处理原生 DOM API、DOM 事件和 DOM 属性等, 暴露了重要的render和createApp方法

const { render, createApp } = createRenderer<Node, Element>({

patchProp,

...nodeOps

})


export { render, createApp }

  • runtime-test: 一个专门为了测试而写的轻量级 runtime。 比如对外暴露了renderToString方法,在此感慨和react越来越像了

  • server-renderer: 用于 SSR,尚未实现。

  • shared: 没有暴露任何 API,主要包含了一些平台无关的内部帮助方法。

  • vue: 「完整」版本,引用了上面提到的 runtime 和 compiler目录。 入口文件代码如下

'use strict'


if (process.env.NODE_ENV === 'production') {

module.exports = require('./dist/vue.cjs.prod.js')

} else {

module.exports = require('./dist/vue.cjs.js')

}

  • 所以想阅读源码,还是要看构建流程,这个和vue2也是一致的

回顾 Vue2.0 响应式原理机制 - defineProperty

这个原理老生常谈了,就是拦截对象,给对象的属性增加 setget 方法,因为核心是 defineProperty 所以还需要对数组的方法进行拦截

对对象进行拦截

数组方法劫持

Object.defineProperty缺点:

  • 无法监听数组的变化

  • 需要深度遍历,浪费内存

vue-next 预备知识

无论是阅读这篇文章,还是阅读 vue-next 响应式模块的源码,首先有两个知识点是必备的:

  • Proxy(https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Proxy):对象用于定义基本操作的自定义行为(如属性查找,赋值,枚举,函数调用等)。ES6 中新的代理内建 工具 类。

  • Reflect(https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Reflect):是一个内置的对象,它提供拦截 JavaScript 操作的方法。这些方法与proxy handlers的方法相同。Reflect不是一个函数对象,因此它是不可构造的。ES6 中新的反射工具类

Proxy

defineproperty 优秀的 就是数组和对象都可以直接触发 gettersetter , 但是数组会触发两次,因为获取 push 和修改 length 的时候也会触发

Proxy 取代 deineProperty 除了性能更高以外,还有以下缺陷,也是为啥会有$set,$delete的原因 :

  1. 属性的新加或者删除也无法监听;

  2. 数组元素的增加和删除也无法监听

Reflect

多次触发和深层嵌套问题

之后会带你看下 vue-next 是怎么解决的。

初始化项目

依赖 项目 vue.global.js【推荐】

  1. clone 项

    $ git clone https://github.com/vuejs/vue-next.git

  2. 编辑文件 

    $ npm run dev

  3. 拷贝文件, 运行上面命令后,就会生成 [项目根路径]/packages/vue/dist/vue.global.js 文件

依赖 @vue/composition-api

  1. 安装 vue-cli  

$ npm install -g @vue/cli

# OR

$ yarn global add @vue/cli

2. 创建项目

$ vue create my-project

# OR

$ vue ui

3. 在项目中安装 composition-api 体验 vue-next 新特性

$ npm install @vue/composition-api --save

# OR

$ yarn add @vue/composition-api

    4. 在使用任何 @vue/composition-api 提供的能力前,必须先通过 Vue.use() 进行安装

    import Vue from 'vue'

    import VueCompositionApi from '@vue/composition-api'


    Vue.use(VueCompositionApi)

    安装插件后,您就可以使用新的 Composition API 来开发组件了。

vue-next 尝鲜

直接拷贝下面代码,去运行看效果吧。推荐使用高版本的chrome浏览器,记得打开F12调试工具哦!

这个 reactive 和react-hooks越来越像了, 大家可以去Composition API RFC(https://vue-composition-api-rfc.netlify.com/#api-introduction)这里看细节。

  1. template 和之前一样,同样 vue-next 也支持手写 render 的写法, template render 同时存在的情况,优先 render

  2. setup 选项是新增的主要变动,顾名思义, setup 函数会在组件挂载前( beforeCreate created 生命周期之间)运行一次,类似组件初始化的作用, setup 需要返回一个对象或者函数。 返回对象会被赋值给组件实例的 renderContext ,在组件的模板作用域可以被访问到,类似 data 的返回值。 返回函数会被当做是组件的 render 具体可以细看文档。

  3. reactive 的作用是将对象包装成响应式对象,通过 Proxy 代理后的对象。

  4. 上面的计数 器的例子,在组件的 setup 函数中,创建了一个响应式对象 state 包含一个 age 属性。 然后创建了一个 increment 递增的函数,最后将 state increment 返回给作用域,这样 template 里的 button 按钮就能访问到 increment 函数绑定到点击的回调, age 我们点击按钮,按钮上的数值就能跟着递增。

参考

  • 快速进阶Vue3.0:https://segmentfault.com/a/1190000020709962?utm_source=tag-newest

  • Vue Function-based API RFC:https://zhuanlan.zhihu.com/p/68477600

相信大家已经对 vue-next(Vue 3.0) 有了初步认识,并且已经成功运行尝鲜代码了吧。

下一章 vue-nextVue3.0)之小试牛刀 继续带你掌握 vue-next 函数式的API。

带你了解 vue-next(Vue 3.0)之 初入茅庐


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

玻璃笼子

玻璃笼子

[美]尼古拉斯·卡尔 / 杨柳 / 中信出版社 / 2015-11 / 49.00元

这是一本关于自动化的书,它提醒我们自动化对人类的影响,人们心安理得享受技术带来的便利却忽视了,它已经渗透进了生活和工作改变了我们的思维和认知方式。商家在设计程序和应用时,早就把他们的想法埋入了编程和APP中。 卡尔的作品无疑是给我们这个时代灌入了的一剂清醒药。他独特的思考问题角度,犀利甚至略为偏激 的言论再加上丰富的*前沿的科技案例会让人读起来畅快淋漓,且醍醐灌顶,意识到自动化等高科技潜移默......一起来看看 《玻璃笼子》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具