二、Angular 的$scope,controller和数据双向绑定($apply(),$digest(),$watch): $scope 对象在 AngularJS 中充当数据模型的作用,也就是一般...$rootScope是由angularJS加载模块的时候自动创建的,每个模块只会有1个rootScope。rootScope创建好会以服务的形式加入到 $injector中。...在AngularJS中,控制器Controller是一个Javascript函数(类型/类), 能通过表达式或者ng事件指令调用。(比如,ngClick),从而达到处理数据的目地。 ?...$apply()中(也可以用$watch来监控model变化),它会自动触发$rootScope.$digest(),从而让watchers被触发用以更新view。...工厂方法一般在模块中使用。 ? 九、AngularJs继承: AngularJS中没有提供内建的用于继承的特性,AngularJS组件中使用普通的JavaScript继承模式。
假设你在一个ng-click指令对应的handler函数中更改了scope中的一条数据,此时AngularJS会自动地通过调用$digest()来触发一轮$digest循环。...在上面的例子中,AngularJS并不直接调用$digest(),而是调用$scope.$apply(),后者会调用$rootScope.$digest()。...因此,一轮$digest循环在$rootScope开始,随后会访问到所有的children scope中的watchers。...$apply()会自动地调用$rootScope.$digest()。$apply()方法有两种形式。第一种会接受一个function作为参数,执行该function并且触发一轮$digest循环。...因此 $digest 循环会持续运行直到 model 不再发生变化,或者 $digest 循环的次数达到了 10 次(超过 10 次后抛出一个异常,防止无限循环)。
只有模型修改的执行在apply方法才能正确的被angular理解,举例,如果一个指令监听dom事件,比如ng-click,它必须计算表达式在 表达式计算后,apply方法执行digest.在digest...如果watch修改了模型中的值,将会触发一次 Creation / 创建 根作用域在应用启动的时候由$injector创建,在template linking阶段和指令时将会创建新的子作用域; Watcher...监听指令,像是ng-click,注册一个监听器在dom上。当dom的监听器触发后,这个指令将执行相关的表达式并且更新视图使用$apply方法。...这个编译循环将一直迭代直到这个模型稳定,这意味着evalAsync队列为空并且 $evalAsync队列用于调度工作,这需要发生在当前的堆栈帧外,在浏览器渲染视图之前。...在运行时阶段: 在input control上按下X键来让浏览器发出keydown事件。
避免这类问题出现的办法是,始终将页面中的元素绑定到对象的属性(data.x)而不是直接绑定到基本变量(x)上。 2,ng-repeat迭代数组的时候,如果数组中有相同值,会有什么问题,如何解决?...AngularJS在scope变量中使用脏值检查来实现了数据双向绑定,并且可以通过scope.watch来监听变化触发回调; angular中使用的是脏检查机制,在angular中每次你绑定一些东西到你的...当浏览器接受到可以被angular context处理的事件时就会触发digest循环,这个循环是由两个更小的循环组合起来的,一个是watch列表,一个是evalAsync列表,而watch列表在digest...="val=val+1">increase 1 click 时会产生一次更新的操作(至少触发两次 digest 循环) 按下按钮浏览器接收到一个事件,进入到angular context...apply会使ng进入 digest cycle , 并从rootScope开始遍历(深度优先)检查数据变更。
RxJS 是基于观察者模式和迭代器模式以函数式编程思维来实现的。 观察者模式 观察者模式在 Web 中最常见的应该是 DOM 事件的监听和触发。...迭代器模式 迭代器模式可以用 JavaScript 提供了 Iterable Protocol 可迭代协议来表示。...JavaScript 中像 Array、Set 等都属于内置的可迭代类型,可以通过 iterator 方法来获取一个迭代对象,调用迭代对象的 next 方法将获取一个元素对象,如下示例。...,那么迭代器模式在 RxJS 中如何体现呢?...在 RxJS 中,Observer 除了有 next 方法来接收 Observable 的事件外,还可以提供了另外的两个方法:error() 和 complete(),与迭代器模式一一对应。
在观察者模式中也有两个主要角色:Subject (主题) 和 Observer (观察者) 。..., value: undefined } 一个迭代器对象 ,知道如何每次访问集合中的一项, 并记录它的当前在序列中所在的位置。...在 JavaScript 中迭代器是一个对象,它提供了一个 next() 方法,返回序列中的下一项。这个方法返回包含 done 和 value 两个属性的对象。...SafeObserver - 更好的 Observer 上面的示例中,我们使用一个包含了 next、error、complete 方法的普通 JavaScript 对象来定义观察者。...一个普通的 JavaScript 对象只是一个开始,在 RxJS 5 里面,为开发者提供了一些保障机制,来保证一个更安全的观察者。
} return fn}考点:使用闭包, 同时要对JavaScript 的作用域链(原型链)有深入的理解重写函数的 toSting()方法// 测试,调用toString方法触发求值add(1).toString...(基于发布订阅模式) 有观察者,也有被观察者观察者需要放到被观察者中,被观察者的状态变化需要通知观察者 我变化了 内部也是基于发布订阅模式,收集观察者,状态变化后要主动通知观察者class Subject...在ES6中,实现一个迭代器生成函数并不是什么难事儿,因为ES6早帮我们考虑好了全套的解决方案,内置了贴心的 生成器 (Generator)供我们使用:// 编写一个迭代器生成函数function *iteratorGenerator...下面我们要做的,不仅仅是写一个迭代器对象,而是用ES5去写一个能够生成迭代器对象的迭代器生成函数(解析在注释里):// 定义生成器函数,入参是任意集合function iteratorGenerator...,我们实现了一个闭包,借助自由变量来做我们的迭代过程中的“游标”。
onerror: 当发生JavaScript运行时错误与资源加载失败时触发。 onabort: 发送到window的中止abort事件的事件处理程序,不适用于Firefox 2或Safari。...onreset: 窗口内表单重置时触发。 onselect: 窗口内表单元素中文本被选中时触发。 onsubmit: 窗口内表单中submit按钮被按下触发。...onanimationiteration: 此事件将会在CSS动画到达每次迭代结束时触发,当通过执行最后一个动画步骤完成对动画指令序列的单次传递完成时,迭代结束。...框架/图像相关 onabort: 图像的加载被中断。 onbeforeunload: 该事件在即将离开页面(刷新或关闭)时触发 onerror: 在加载文档或图像时发生错误。...onemptied: 当期播放列表为空时触发 onended: 事件在视频/音频播放结束时触发。 onerror: 事件在视频/音频数据加载期间发生错误时触发。
、智能指针 模板的实现中,用于生成可读性更好的实例化错误信息。...lock> 列表(TLS 存储;获取时记录,释放时移除) 创建时,断言 predecessor 已创建(如果 predecessor 不存在,可能顺序错误) 获取时,断言 predecessor 是当前线程最近获取的...lock(若不是,可能顺序错误) 2.4 观察者模式检查 在之前写的 令人抓狂的观察者模式 中,介绍了如何通过 : Chromium/base 提供的base::ObserverList,检查观察者模式的一些潜在问题...本次迭代中,继续通知 新加入的观察者 解决:被观察者参数 `base::ObserverListPolicy` 决定迭代过程中,是否通知 新加入的观察者 移除观察者 问题:循环内(间接)删除节点,导致迭代器失效...同一线程/序列 解决:被观察者成员 iteration_sequence_checker_ 在迭代开始时关联序列,在结束时解除关联,在迭代过程中检查 移除观察者/通知重入/销毁被观察者 操作是否序列安全
环境类通过抽象策略类中声明的方法在运行时调用具体策略类中实现的算法。...● ConcreteStrategy(具体策略类):它实现了在抽象策略类中声明的算法,在运行时, 具体策略类将覆盖在环境类中定义的抽象策略类对象,使用一种具体的算法实现某个业务处理。...抽象类中的模版方法正是通过实现类扩展的方法来完成业务逻辑。只要实现类中的扩展方法通过了单元测试, 在模版方法正确的前提下,整体功能一般不会出现大的错误。 模版方法的优点及适用场景 容易扩展。...观察者模式是一种常用的触发机制,它形成一条触发链,依次对各个观察者的方法进行处理。但同时,这也算是观察者模式一个缺点, 由于是链式触发,当观察者比较多的时候,性能问题是比较令人担忧的。...并且,在链式结构中,比较容易出现循环引用的错误,造成系统假死。
onload: 文档加载完成后触发。 onunload: 当窗口卸载其内容和资源时触发。 onerror: 当发生JavaScript运行时错误与资源加载失败时触发。...onabort: 发送到window的中止abort事件的事件处理程序,不适用于Firefox 2或Safari。 窗口相关 onblur: 窗口失去焦点时触发。...onselect: 窗口内表单元素中文本被选中时触发。 onsubmit: 窗口内表单中submit按钮被按下触发。 onhashchange: 当窗口的锚点哈希值发生变化时触发。...onanimationiteration: 此事件将会在CSS动画到达每次迭代结束时触发,当通过执行最后一个动画步骤完成对动画指令序列的单次传递完成时,迭代结束。...打印相关 onbeforeprint: 该事件在页面即将开始打印时触发 onafterprint: 该事件在页面已经开始打印或者打印窗口已经关闭时触发。
开始的时候,我在 _Layout.cshtml 母版页的顶部编写了一些服务器端代码。我所做的头两件事情就是让从程序集信息类中获取应用的序列号,从应用程序设置中获取检索的基本 URL。...在这种模式下,应用的版本序列号会被追加到捆绑中的所有JavaScript 文件的脚本标签中。对于标准的渲染脚本标签格式不包含追加版本号来说,这也算是个小弥补。...从 Visual Studio 中启动应用程序时,您可能会遇到浏览器缓存的问题。同时也可能会花时间来猜测,你运行的是否是最新版本的 JavaScript 文件。在浏览器中按 F5 可以解决这个问题。...不幸的是,直到 AngularJS 配置阶段完成之后,才能提供 AngularJS 服务和方法集,因此我无法在主页中创建一个没有 AngularJS 错误的服务。...我甚至没有使用 RequireJS 定义表述来预安装我的动态加载控制器。很多试验和错误之后,我已经达到了本文的目的。我现在可以通过客户端代码加载服务器端的捆绑。
该算法赋予每个页面一个访问字段,用来记录一个页面自上次被访问以来所经历的时间 t,当须淘汰一个页面时,选择现有页面中其 t 值最大的,即最近最少使用的页面予以淘汰通俗的解释:假如我们有一块内存,专门用来缓存我们最近发访问的网页...在ES6中,实现一个迭代器生成函数并不是什么难事儿,因为ES6早帮我们考虑好了全套的解决方案,内置了贴心的 生成器 (Generator)供我们使用:// 编写一个迭代器生成函数function *iteratorGenerator...下面我们要做的,不仅仅是写一个迭代器对象,而是用ES5去写一个能够生成迭代器对象的迭代器生成函数(解析在注释里):// 定义生成器函数,入参是任意集合function iteratorGenerator...,我们实现了一个闭包,借助自由变量来做我们的迭代过程中的“游标”。...(基于发布订阅模式) 有观察者,也有被观察者观察者需要放到被观察者中,被观察者的状态变化需要通知观察者 我变化了 内部也是基于发布订阅模式,收集观察者,状态变化后要主动通知观察者class Subject
策略模式(Strategy Pattern) 策略模式简单描述就是:对象有某个行为,但是在不同的场景中,该行为有不同的实现算法。...迭代器模式(Iterator Pattern) ES6中的迭代器 Iterator 相信大家都不陌生,迭代器用于遍历容器(集合)并访问容器中的元素,而且无论容器的数据结构是什么(Array、Set、Map...,返回Boolean next():查找并返回下一个元素 为Javascript的数组实现一个迭代器可以这么写: const item = [1, 'red', false, 3.14]; function...,当有内容更新时会收到推送;又比如JavaScript中的事件订阅响应机制。...使其取消订阅自己 fire(): 触发事件,通知到所有观察者 用JavaScript手动实现观察者模式: // 被观察者 function Subject() { this.observers =
最近在开发一个 JSSDK 的时候有一个需求:为了检测当前环境中是否已经加载过该脚本,需要在脚本开始运行时加入一层判断,如果检测到已存在该脚本导出的变量,则终止脚本的后续运行,否则再执行后续逻辑。...那么便碰上了本文标题的问题:如何终止 JS 程序的运行? 在很多其他语言比如 PHP 当中,存在 exit 函数来中止程序的运行。很遗憾的是 JavaScript 没有。...这里的错误包括语法错误、变量错误、程序错误等等,我们只需要用 throw new Error() 的方式抛出错误,就能达到目的。在抛出该错误之前的代码可正常执行不受影响,而在其之后的代码则不会执行。...你可以在你的程序中任意想中止的地方抛出错误,然后就能达到 exit 的目的。 但是,进一步思考,为什么 JavaScript 没有提供类似其他语言的 exit 函数呢?...实际上,这一切都是因为 JavaScript 是单线程语言,基于代码可以异步执行的考虑,才没有设置 exit 功能。那么,是不是在包含异步执行的代码中,我们的抛出错误的方法实际上也不能立刻终止程序呢?
JavaScript 的运行环境便逐渐发展到包含任务调度、多线程应用开发等强大的特性。事件循环便是 JavaScript 运行时安排和运行代码背后的机制,它相当于是主线程这条繁忙公路的交通指挥员。...任务队列一个 JavaScript 运行时包含了一个用于存储异步任务的任务队列(Task Queue),也称消息队列(Message Queue)。...在 JavaScript 开始运行的时候,所有同步代码会按书写顺序在调用栈中依次执行,而异步任务的回调函数则会被放入任务队列,等待执行。...MutationObserver(DOM 变化观察者)。Node.js 中的 process.nextTick()。...这个过程中如果创建了宏任务,则放入任务队列,等待执行;但如果创建了微任务,则会放入微任务队列、在本次迭代中执行。(可选)微任务队列清空后,如果页面需要更新,则执行这些必要的渲染和绘制。
yiuanli最近在研读书籍 深入浅出nodejs , 随手写下的一些笔记, 和大家分享~ 如有错误,欢迎指正~ Node简介 特点:事件驱动(在浏览器端广泛成熟的机制), 异步I/O 基于Chrome...每次Tick执行时会从红黑树中迭代取出定时器对象,检查是否超过定时时间,超过了就会形成事件,调用回调函数。 定时器的问题在于,他并非精确的(一般应该在容忍范围内)。...行为上,process.nextTick在每轮循环会把数组全部执行,而后者只会执行链表中的一个回调。...,即通过主循环加事件触发来运行程序 实质上异步I/O不仅仅运用在文件操作。...,并且再查看是否有回调函数 有回调函数则执行,并将控制器转移会 JavaScript 中 image.png Node通过事件循环的方式处理请求,无需为每一个请求创建额外的对应线程,可以省掉开销
这些更改将简化日常编码工作,并为 switch 中的模式匹配(JEP 305)做好准备。 4、JVM 常量 API 引入 API 对关键类文件和运行时工件建模,特别是可从常量池加载的常量。...在新的 java.lang.invoke.constant 包中定义了一系列基于值的符号引用(JVMS 5.1)类型,它们能够描述每种可加载常量。...7、可中止的 G1 Mixed GC 如果 G1 Mixed GC 存在超出暂停目标的可能性,则使其可中止。...观望 JDK 13 根据 JDK 13 的迭代计划,预计将于 2019 年 9 月发布 —— Java 现在采取“半年发布一次版本”的模式。...讨论 留意到不少开发者对 Raw String Literals 特性情有独钟,该特性类似于 JavaScript ES6 语法中的模板字符串,使用它基本可以告别丑陋的字符串拼接。
上一节讲解了迭代器的使用,如果对迭代器还不够了解的可以在回顾下《从理解到实现轻松掌握 ES6 中的迭代器》,目前在 JavaScript 中还没有被默认设定 [Symbol.asyncIterator...本文也是探索异步迭代器在 Node.js 中的都有哪些使用场景,欢迎留言探讨。...此时的迭代器会一直处于遍历中,虽然上面两个事件 emit 都触发了,但是迭代器并没有终止,什么时候终止呢?...MongoDB 中游标是以 hasNext() 返回 false 或 next() 返回为 null 来判断是否达到游标尾部,与之不同的是在我们的 JavaScript 可迭代协议定义中是要有一个 Symbol.asyncIterator...,则在 CoreCursor 的原型上设置 Symbol.asyncIterator 属性,返回基于 Promise 实现的异步迭代器对象,这符合 JavaScript 中关于异步可迭代对象的标准定义。
JVM Constants API JVM 常量 API 引入 API 对关键类文件和运行时工件建模,特别是可从常量池加载的常量。...在新的 java.lang.invoke.constant 包中定义了一系列基于值的符号引用(JVMS 5.1)类型,它们能够描述每种可加载常量。...为了实现向操作系统返回最大内存量的目标,G1 将在应用程序不活动期间定期执行或触发并发周期以确定整体 Java 堆使用情况。这将导致它自动将 Java 堆的未使用部分返回给操作系统。...观望 JDK 13 根据 JDK 13 的迭代计划,预计将于 2019 年 9 月发布 —— Java 现在采取“半年发布一次版本”的模式。...讨论 留意到不少开发者对 Raw String Literals 特性情有独钟,该特性类似于 JavaScript ES6 语法中的模板字符串,使用它基本可以告别丑陋的字符串拼接。
领取专属 10元无门槛券
手把手带您无忧上云