前言

本文通过console.log的一些特性,结合vue.js的源码,通过一个简单的例子,让你了解Vue的各个过程的变化.


控制台输出的效果图

请用chrome查看,并打开控制台看效果

演示地址

准备

vue-console.html的创建

下载vue.js文件,在vue-console.html中引入,我写了一个简单的例子,涵盖:初始化视图->点击后更新视图(包括各个钩子函数)


代码如下:

  1. <script src="./vue.js"></script>
  2. <div id="app">
  3. <div id="hi" @click="changeName">{{name}}</div>
  4. </div>
  5. </div>
  6. <script>
  7. var style = 'font-size: 20px;color: blue'
  8. var vm = new Vue({
  9. el:'#app',
  10. data() {
  11. return {
  12. name: '点我',
  13. }
  14. },
  15. beforeCreate () {
  16. console.log('%cI am beforeCreate------ 我在选项里写的', style)
  17. },
  18. created () {
  19. console.log('%cI am created------ 我在选项里写的', style)
  20. },
  21. beforeMount () {
  22. console.log('%cI am beforeMount------ 我在选项里写的', style)
  23. },
  24. mounted () {
  25. console.log('%cI am mounted------ 我在选项里写的', style)
  26. },
  27. beforeUpdate () {
  28. console.log('%cI am beforeUpdate------ 我在选项里写的',style)
  29. },
  30. updated () {
  31. console.log('%cI am updated------ 我在选项里写的', style)
  32. },
  33. methods: {
  34. changeName () { // 点击是文本发生变化
  35. this.name = 'jike'
  36. }
  37. }
  38. })
  39. </script>

console.log样式的配置


  1. var tagLeftStyle = [
  2. 'color: #fff',
  3. 'border-top-left-radius:3px',
  4. 'border-bottom-left-radius:3px',
  5. 'background-color: #564b4f',
  6. 'padding: 5px'
  7. ].join(';')
  8. var tagRightStyle = function (color) {
  9. color = color?color:'#0BCF1B'
  10. return [
  11. 'color: #fff',
  12. 'border-top-right-radius:3px',
  13. 'border-bottom-right-radius:3px',
  14. `background-color: ${color}`,
  15. 'padding: 5px'
  16. ].join(';')
  17. }
  18. // ...
  19. // 一些样式省略,具体可以去看源码
  20. var tagVariable = function (obj, tag, desc, num, detail, color) {
  21. console.log(`%c${lineNo} %o%c<---%c${tag}%c${desc} %c源码${num}行 %c说明: %o`, noStyle, obj, arrowStyle ,tagLeftStyle, tagRightStyle(color), sourceNoStyle, detailStyle, detail)
  22. lineNo++
  23. }
  24. // %c代表后面的文本,使用css样式,%o代表对象输出



上面的代码只要调用tagVariable(...)传递参数,就实现上图的标签效果,

还可以console.log显示图片,加了一下讲解图方便理解;



通过调用上面封装的函数在vue.js某些时刻调用,就达到很好的效果

项目过程

我将整个过程分为四个阶段: 构造函数阶段初始化阶段挂载阶段更新阶段,

会以上面提到的例子贯穿的

构造函数阶段

平常我们使用Vue,都是用new Vue({}),其实就是调用它的构造函数创建实例,如下图

初始化阶段

会对我们传入datamethods等处理,便于后面阶段的调用及一些功能的实现

如例子的dataname会被代理到vm实例上,所以我们可以用this.name调用

  1. data() {
  2. return {
  3. name: '点我',
  4. }
  5. }

挂载阶段

  1. <div id="app">
  2. <div id="hi" @click="changeName">{{name}}</div>
  3. </div>

会将上面的html渲染成视图(这里面包括渲染函数,虚拟dom的实现等)

更新阶段

点击页面上的文本时发生更新,这个过程包括:wathcer的触发、patch算法对比新旧vnode,更新dom

说明

具体的可以去看源码,在github上,觉得可以的话帮忙star一下

参考文章: Vue技术内幕

Vue.js 源码解析

用console.log分析Vue源码的更多相关文章

  1. 入口文件开始,分析Vue源码实现

    Why? 网上现有的Vue源码解析文章一搜一大批,但是为什么我还要去做这样的事情呢?因为觉得纸上得来终觉浅,绝知此事要躬行. 然后平时的项目也主要是Vue,在使用Vue的过程中,也对其一些约定产生了一 ...

  2. [Vue源码]一起来学Vue模板编译原理(一)-Template生成AST

    本文我们一起通过学习Vue模板编译原理(一)-Template生成AST来分析Vue源码.预计接下来会围绕Vue源码来整理一些文章,如下. 一起来学Vue双向绑定原理-数据劫持和发布订阅 一起来学Vu ...

  3. [Vue源码]一起来学Vue模板编译原理(二)-AST生成Render字符串

    本文我们一起通过学习Vue模板编译原理(二)-AST生成Render字符串来分析Vue源码.预计接下来会围绕Vue源码来整理一些文章,如下. 一起来学Vue双向绑定原理-数据劫持和发布订阅 一起来学V ...

  4. [Vue源码]一起来学Vue双向绑定原理-数据劫持和发布订阅

    有一段时间没有更新技术博文了,因为这段时间埋下头来看Vue源码了.本文我们一起通过学习双向绑定原理来分析Vue源码.预计接下来会围绕Vue源码来整理一些文章,如下. 一起来学Vue双向绑定原理-数据劫 ...

  5. vue源码逐行注释分析+40多m的vue源码程序流程图思维导图 (diff部分待后续更新)

    vue源码业余时间差不多看了一年,以前在网上找帖子,发现很多帖子很零散,都是一部分一部分说,断章的很多,所以自己下定决定一行行看,经过自己坚持与努力,现在基本看完了,差ddf那部分,因为考虑到自己要换 ...

  6. vue源码构建代码分析

    这是xue源码学习记录,如有错误请指出,谢谢!相互学习相互进步. vue源码目录为 vue ├── src #vue源码 ├── flow #flow定义的数据类型库(vue通过flow来检测数据类型 ...

  7. 前端Vue 源码分析-逻辑层

    Vue 源码分析-逻辑层 预期的效果: 监听input的输入,input在输入的时候,会触发 watch与computed函数,并且会更新原始的input的数值.所以直接跟input相关的处理就有3处 ...

  8. [Vue源码分析] v-model实现原理

    最近小组有个关于vue源码分析的分享会,提前准备一下… 前言:我们都知道使用v-model可以实现数据的双向绑定,及实现数据的变化驱动dom的更新,dom的更新影响数据的变化.那么v-model是怎么 ...

  9. Vue源码分析(二) : Vue实例挂载

    Vue源码分析(二) : Vue实例挂载 author: @TiffanysBear 实例挂载主要是 $mount 方法的实现,在 src/platforms/web/entry-runtime-wi ...

随机推荐

  1. Linux-CentOS5/6启动流程

    Linux-CentOS5/6启动流程

  2. yii2.0缓存篇之片段缓存

    片段缓存指的是缓存页面内容中的某个片段.默认缓存 60秒. return $this->renderPartial("ca");                        ...

  3. #ifdef__cplusplus

    百度知道: 一般用于将C++代码以标准C形式输出(即以C的形式被调用),这是因为C++虽然常被认为是C的超集,但是C++的编译器还是与C的编译器不同的.C中调用C++中的代码这样定义会是安全的. 一般 ...

  4. HTML学习----------DAY1 第一节

    什么是 HTML? HTML 是用来描述网页的一种语言. HTML 指的是超文本标记语言 (Hyper Text Markup Language) HTML 不是一种编程语言,而是一种标记语言 (ma ...

  5. Docker入门实践(三) 基本操作

    Docker安装完毕.我们就能够试着来执行一些命令了.看看docker能够干什么. (一) 创建一个容器 首先.让我们执行一个最简单的容器,hello-world.假设安装没有问题.并执行正确的话,应 ...

  6. 我持续推动Rust语言支持Windows XP系统

    前言 Rust好像长期以来不支持Windows XP系统.有不少用户发帖提议官方支持XP,基本上都被Rust官方开发人员明白的拒绝了.他们的对话大致上是以这种形式開始和结束的(当中乙方代表官方及其拥趸 ...

  7. xml里面product的值在哪里设置的?

    转载请注明出处:http://blog.csdn.net/droyon/article/details/39890469 在进行Android应用程序开发时,善于运用xml中的product配置,能够 ...

  8. cocos2d-x 3.1.1学习笔记[23]寻找主循环 mainloop

    文章出自于  http://blog.csdn.net/zhouyunxuan cocos2d到底是怎样把场景展示给我们的,我一直非常好奇. 凭个人猜想,引擎内部的结构类似于这样 while(true ...

  9. 如何卸载visualsvn for visual studio

    新入职的公司,电脑上的visual studio已经安装了visualsvn 尝试在tools-->extensions and updates中卸载 但是uninstall按钮是被禁用掉的 谷 ...

  10. json的键为变量而不是字符串时,怎么写?

    看栗子 /* 首先你创建了一个window的属性叫b, 并给它赋值为'cccddd' * 然后你创建了一个对象"a", 声明了一个它的属性叫b, 并且给b赋值为6 * 注意第一行的 ...