理解vue实现原理,实现一个简单的Vue框架资料.pdfVIP

理解vue实现原理,实现一个简单的Vue框架资料.pdf

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
理解 vue 实现原理,实现一个简单的 Vue 框架 其实对 JS我研究不是太深,用过很多次,但只是实现功能就算了。最近 JS实在是太火,从前端到后端,应用越来越广泛,各种框架层出不 穷,忍不住也想赶一下潮流。 Vue 是近年出的一个前端构建数据驱动的 web 界面的库,主要的特色是响应式的数据绑定,区别于以往的命令式用法。也就是在 var a=1; 的过程中,拦截’ =’的过程,从而实现更新数据, web 视图也自动同步更新的功能。而不需要显式的使用数据更新视图(命令式)。这种用法我 最早是在 VC MFC 中见过的,控件绑定变量,修改变量的值,输入框也同步改变。 Vue 的官方文档,网上的解析文章都很详细,不过出于学习的目的,还是了解原理后,自己实现一下记忆深刻,同时也可以学习下 Js 的一 些知识。搞这行的,一定要多 WTFC(Write The Fucking Code) 。 一、思考设计 其实这里的思考是在看过几篇文章、看过一些源码后补上的,所以有的地方会有上帝视角的意思。但是这个过程是必须的,以后碰到问题 就会有思考的方向。 先看看我们想要实现什么功能,以及现在所具有的条件: 效果图如下: 这里写图片描述 使用 Vue 框架代码如下: !DOCTYPE html html lang=en head meta charset=UTF-8 titleMVVM/title /head body script src=src/vue.js/script div id=msg {{b.c}} 这是普通文本 {{b.c+1+message}} 这是普通文本 p{{message}}/p pinput type=text v-model=message//p p{{message}}/p pbutton type=button v-on:click=clickBtn(message)click me/button/p /div script var vm = new Vue({ el:#msg, data:{ b:{ c:1 }, message:hello world }, methods:{ clickBtn:function(message){ vm.message = clicked; } } }); /script /body /html 然后我们还知道一个条件, Vue 的官方文档所说的: 把一个普通对象传给 Vue 实例作为它的 data 选项, Vue.js 将遍历它的属性,用 Object.defineProperty 将它们转为 getter/setter 。这是 ES5 特性, 不能打补丁实现,这便是为什么 Vue.js 不支持 IE8 及更低版本。 用这个特性实现这样的功能,我们需要做什么呢? 首先,需要利用 Object.defineProperty ,将要观察的对象,转化成 getter/setter ,以便拦截对象赋值与

文档评论(0)

tianya189 + 关注
官方认证
文档贡献者

该用户很懒,什么也没介绍

认证主体阳新县融易互联网技术工作室
IP属地上海
统一社会信用代码/组织机构代码
92420222MA4ELHM75D

1亿VIP精品文档

相关文档