轻量级前端MVVM框架avalon - 控制器

简介:

引子:

最近工作挺忙,avalon只能断断续续的写下去了,大概看了下angular的源码,看到小一半就比较难坚持了,是块硬骨头,慢慢啃吧

不过angular的的文档中用词还是很优雅:

  • HTML编译器
  • 指令
  • 编译
  • 链接
  • 过滤器
  • 注入器
  • 控制器
  • 管道

      等等…看起来觉得老高级,其实avalon也间接的部分实现,原理也不是很复杂

avalon版本更新很快,新版的加入了AMD规范的模块加载器,还修复了很多BUG,不过相信短期内实现的核心还是不会变化,所以我依然以现在的版本分析为主


编译期

  • 视图背后的代码就是控制器,在mvvm中就是vm视图模型,它的主要工作就是构造模型,并把模型与回调方法一并发送到视图,视图可以看作作用到模版HTML上的投影
  • 所以在编译阶段,我们的控制器就会把用户定义的数据模型给构造出来
  • avalon中的modelFactory工厂方法构造出的model对象其实就是真正的控制器了,至于构造出来的控制器如何注入到视图上的,等以后分析到HTML编译器双向绑定吧
  • model 本来是系统内部定义的一个临时对象,将控制器和avalon的作用域对象给关联起来

接上一节

收集用户定义的scope在过滤的时候做了2个处理

 callGetters.push(accessor);
 callSetters.push(name);

收集控属性赋监与计算属性,是为了在初始化scpoe中的代码未处理的方法

 


处理监控属性

 

    //给控属性赋监值,调用对应监控属性的set ->accessor方法
    callSetters.forEach(function(prop) {
       // model.firstName = '司徒' ->调用了 model.firstName->set->accessor方法
        model[prop] = scope[prop]; //为空对象赋值
    });

遍历监控属性收集器,给初始化的空model对应的方法赋值

这里注意各重点,赋值的的时候实际是调用的accessor方法,因为set get给转换过了

accessor 源码

 

其实源码注释很清楚了,我们归纳下执行的流程

  • 判断参数是调用set还是get方法
  • stopRepeatAssign //阻止重复赋值,是这factory.apply(0, deps);重置上下文的时候处理的
  • 监控数组处理
  • 更新json  //收集原始的定义
  • notifySubscribers  //更新依赖,就是当前的操作会触发与之相关
  • model.$events 触发订阅的自定义事件

notifySubscribers  其实就是关键的执行点,执行当前作用域所依赖的所有的,这个在双向绑定的时候就可以仔细讨论了

 


 处理计算属性:

 

image

监控属性涉及用户定义的处理,所以要做很多关联的处理

流程:

  • 收集依赖关系
  • 处理用于定义的get方法
  • 更新json
  • 返回定义函数的结果

Publish 对象是将函数曝光到此对象上,方便访问器收集依赖

fn.nick 就是对应的计算属性方法名称,在过滤的时候 accessor.nick = name;附上的

同样执行了accessor方法,由于没有传递参数,实际上就是在处理收集依赖关系了

 

accessor 源码

 

 

collectSubscribers方法

image

很明显的处理,取出开始push到的Publish的处理回调,取出依赖列表,合并

ensure 法只有当前数组不存在此元素时只添加它

image

所有此时的 subscibers关联就有值了

最后执行定义的get方法,更新json

image

注意的一点

image

这里又涉及到取值的问题,所以又会关对应的执行各自的accessor

所以这里会进行一次收集依赖了

 


在转换的完毕model后,会给model增加订阅的特性与一些属性

  • model.$json = json;  //纯净的js对象,所有访问器与viewModel特有的方法属性都去掉

增加事件订阅

  • model.$events = {}; //VB对象的方法里的this并不指向自身,需要使用bind处理一下
  • model. w a t c h = O b s e r v a b l e . watch.bind(model);//用于监听ViewModel中的某属性变化,它将新值与旧值都传给回调
  • model. u n w a t c h = O b s e r v a b l e . unwatch.bind(model);//卸载$watch绑定的回调
  • model. f i r e = O b s e r v a b l e . fire.bind(model); //触发$watch指定的回调

ViewModel的ID,方便通过avalon.models[$id]访问

  • model.$id = generateID();

判断是否为模型中的原始数据

  • model.hasOwnProperty 方法

 

最后返回工厂转化后的model对象

 


主方法入口

avalon.define

image

其实这里有一种重点

image

作者再次把定义的模型给执行了一遍,用意呢?

请看

vm.xxx = 1;
 
vm.fullName = fucntion(){
       vm.xxxx               
 
}
 

在定义的VM中的方法中,如果再次访问vm.xxx属性,

这时候内部引用不对了 VM还是指向原来的普通JS对象,而不是真正的VM所以需要apply一次,改变

那么有个精妙的思路:

我们 factory.apply(0, deps); //重置它的上下文

所以把方法执行一次把内部引用换给model
因为转换了模型关系,所以监控属性与计算属性都会有对应的set get操作了,相对应的上下文也变成了vm了
stopRepeatAssign return 阻止了,防止重复赋值

 

avalon.models[name] = model; 挂到了全局的models中,方面以后使用

 

本文转自艾伦 Aaron博客园博客,原文链接:http://www.cnblogs.com/aaronjs/p/3166694.html,如需转载请自行联系原作者

相关文章
|
6月前
|
JavaScript 前端开发 Java
制造业ERP源码,工厂ERP管理系统,前端框架:Vue,后端框架:SpringBoot
这是一套基于SpringBoot+Vue技术栈开发的ERP企业管理系统,采用Java语言与vscode工具。系统涵盖采购/销售、出入库、生产、品质管理等功能,整合客户与供应商数据,支持在线协同和业务全流程管控。同时提供主数据管理、权限控制、工作流审批、报表自定义及打印、在线报表开发和自定义表单功能,助力企业实现高效自动化管理,并通过UniAPP实现移动端支持,满足多场景应用需求。
543 1
|
7月前
|
前端开发 Java 物联网
智慧班牌源码,采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署
智慧班牌系统是一款基于信息化与物联网技术的校园管理工具,集成电子屏显示、人脸识别及数据交互功能,实现班级信息展示、智能考勤与家校互通。系统采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署与私有化定制。核心功能涵盖信息发布、考勤管理、教务处理及数据分析,助力校园文化建设与教学优化。其综合性和可扩展性有效打破数据孤岛,提升交互体验并降低管理成本,适用于日常教学、考试管理和应急场景,为智慧校园建设提供全面解决方案。
419 70
|
7月前
|
JavaScript 前端开发 API
|
9月前
|
安全 前端开发 开发工具
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
435 5
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
|
12月前
|
前端开发 JavaScript API
前端界的秘密武器:掌握这些框架,让你轻松秒杀99%的同行!
前端开发日新月异,掌握几个明星框架如React、Vue.js和Angular,不仅能让工作更得心应手,还能轻松超越同行。React以高效的虚拟DOM和组件化著称;Vue.js简洁易懂,灵活性高;Angular提供全面的解决方案,适合大型应用。此外,轻量级的Svelte也值得关注,其编译时处理设计提升了应用性能。掌握这些框架,结合深刻理解和灵活运用,助你在前端领域脱颖而出。
170 9
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
959 14
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
283 0
|
人工智能 自然语言处理 运维
前端大模型应用笔记(一):两个指令反过来说大模型就理解不了啦?或许该让第三者插足啦 -通过引入中间LLM预处理用户输入以提高多任务处理能力
本文探讨了在多任务处理场景下,自然语言指令解析的困境及解决方案。通过增加一个LLM解析层,将复杂的指令拆解为多个明确的步骤,明确操作类型与对象识别,处理任务依赖关系,并将自然语言转化为具体的工具命令,从而提高指令解析的准确性和执行效率。
422 6
|
SpringCloudAlibaba JavaScript 前端开发
谷粒商城笔记+踩坑(2)——分布式组件、前端基础,nacos+feign+gateway+ES6+vue脚手架
分布式组件、nacos注册配置中心、openfegin远程调用、网关gateway、ES6脚本语言规范、vue、elementUI
谷粒商城笔记+踩坑(2)——分布式组件、前端基础,nacos+feign+gateway+ES6+vue脚手架
|
存储 弹性计算 算法
前端大模型应用笔记(四):如何在资源受限例如1核和1G内存的端侧或ECS上运行一个合适的向量存储库及如何优化
本文探讨了在资源受限的嵌入式设备(如1核处理器和1GB内存)上实现高效向量存储和检索的方法,旨在支持端侧大模型应用。文章分析了Annoy、HNSWLib、NMSLib、FLANN、VP-Trees和Lshbox等向量存储库的特点与适用场景,推荐Annoy作为多数情况下的首选方案,并提出了数据预处理、索引优化、查询优化等策略以提升性能。通过这些方法,即使在资源受限的环境中也能实现高效的向量检索。
538 1

热门文章

最新文章

  • 1
    Vue 3 + TypeScript 现代前端开发最佳实践(2025版指南)
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
  • 3
    前端如何存储数据:Cookie、LocalStorage 与 SessionStorage 全面解析
  • 4
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
  • 5
    前端如何禁止用户打开 F12 开发者工具
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
  • 下一篇
    开通oss服务