npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

vue2-project

v1.0.0

Published

vue2 手写

Downloads

1

Readme

vue2 手写

目录结构

  • src
    • complier
      • generat.js --------- ast 语法树转代码片段
      • index.js --------- 模板编译入口,接收代码片段,转成 render 函数
      • parser.js --------- 正则分词,解析模板,生成 ast 语法树
    • observe
      • array.js --------- 数组方法重写
      • index.js --------- 观察者类 真正的数据劫持方法
    • vdom
      • index.js --------- 创建虚拟 dom
      • patch.js --------- dom diff, 创建真实 dom
    • index.js --------- 入口文件
    • initMixin.js --------- vue 挂载init 方法
    • state.js --------- 数据劫持入口
    • utils.js --------- 工具方法

vue2 执行关键步骤

// --------------------------- 数据劫持 ----------------------------
// @1 new Vue 会调用 _init 方法进行初始化操作
// @2 会将用户的选项放到 vm.$options 上
// @3 会对当前属性上搜索有没有 data 数据,有则初始化 --- initState 方法
// @4 有 data 则判断 data 是不是一个函数,如果是函数取返回值 initData
// @5 observe 去观测 data 中的数据
// @6 vm 上取值也能取到 data 中的数据,原因是做了一层取值代理 vm.a => vm._data.a
// @7 如果更新对象不存在的属性,会导致视图不能更新,如果是数组更新索引和长度,则不会触发更新
// @8 赋值成一个新对象,新对象会被进行劫持,如果是数组存放新内容 push unshift 等新增的元素也会被劫持。
// @9 通过 __ob__ 进行标识这个对象是否被监控过
// @10 如果就是想通过索引更改数组触发更新,使用 $set 方法,该方法内部使用 splice