VueJS学习之旅 01

近期VueJS非常的火,于是就想学学它是如何开发的。

以往学习一个新的框架,都是从官方的文档和一些大神的博文开始的。这次想换个思路,从源码开始。

接触前端技术也有几年了,用过了不少的框架和工具库。一直都是知其然而不知其所以然,也想借助框架源码的学习,来巩固一下基础知识。前端技术发展迅猛,习之如同逆水行舟,不进则退啊。呜呼,哀哉。。。

当然,开始之前也到官网简单的了解了一下基本原理和API。


OK! Let's go!

首先必然是从github上clone一份vuejs的源码到本地

git clone -b master https://github.com/vuejs/vue.git

我们先来看看dist目录下面都有哪些东西。

$ ls dist/
README.md  vue.common.js  vue.js  vue.min.js  vue.runtime.common.js  vue.runtime.js  vue.runtime.min.js

可以看到6个js文件和一个readme,那这些文件有哪些区别,可以到readme中看看。

  1. 第一行给出了一个规则解释:以 common.js 结尾的文件是为构建工具准备的,不以 common.js 结尾的文件是为浏览器直接运行而准备的。
  2. vue.js和vue.min.js,支持在浏览器中直接用script标签引入。其中vue.js硬编码为开发模式,vue.min.js硬编码为生产模式。
  3. vue.common.js基于CommonJS标准构建,同时包含compiler。它是为打包工具(Webpack或Browserify)准备的。有别于浏览器构建版本,用来判断 开发/生产 模式的 process.env.NODE_ENV ,可以在构建过程中指定(非硬编码)。当运行于node环境时,vuejs会读取node环境的 process.env.NODE_ENV
  4. vue.runtime.common.js,也是基于CommonJS标准构建,但是不包含compiler,这意味着你不能能使用 template 选项。但是仍然可以在 .vue 但文件组建中使用,因为如 vue-loader vueify 等会默认预编译模板。
  5. vue.runtime.js,浏览器构建版本,不包含compiler。硬编码为开发模式。
  6. vue.runtime.min.js,同vue.runtime.js。硬编码为生产模式。

接下来我们看看package.json还给我们提供了哪些信息。
打开package.json,其中有一行

"main": "dist/vue.runtime.common.js"

这意味着在使用模块化系统中通过一些代码引用模块时,默认引入的是 vue.runtime.common.js 文件。(既不能在代码中直接使用 template 选项)

import Vue from 'vue';
or 
var Vue = require('vue');

如果需要使用 template 该怎么做?

Webpack中可以用resolve.alias将vue模块指向其他的构建版本

resolve: {
 alias: {
   vue$: 'vue/dist/vue.common.js'
 }
}

Browserify中 aliasify 同样可以实现

OK,了解了这些之后,我们应该来看看具体的代码了。

打开dist/vue.js,发现文件不小,同时也不容易找到重点。不如我们直接打开src目录,看看代码结构。一目了然,结构很清晰。但是entries文件夹下的内容是做什么的,第一时间没有猜到,看来有必要结合以下build过程来了解一下。

下面来看看项目是如何build的吧。

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

推荐阅读更多精彩内容

  • 转载 :OpenDiggawesome-github-vue 是由OpenDigg整理并维护的Vue相关开源项目库...
    果汁密码阅读 23,112评论 8 124
  • 前几日听到一句生猛与激励并存,可怕与尴尬同在,最无奈也无解的话:“90后,你的中年危机已经杀到”。这令我很受触动。...
    王钰峰阅读 4,378评论 1 22
  • 早上6点半闹钟如约而至的响起,然而我却向上帝祈祷了,祈求您把时钟走的慢一点。是那么困,那么有点不明白自己到底在折腾...
    Sophia路阅读 427评论 4 5
  • 随着我们的两个宝贝儿子的降生我们的生活发生了翻天覆地的变化。 虽然已过而立之年,以前也迫切的想要个孩子,但孩子们来...
    philipzhibin阅读 240评论 0 2