首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

angular5面试题_大数据面试题

Module 延迟加载(Lazy-loading) 什么是指令(Directive) Promise 和 Observable的区别 如果提高Angular的性能 Angular 版本如何升级 关于Angular...脏值检测的基本原理是存储旧数值,并在进行检测时,把当前时刻的新值和旧值比对。若相等则没有变化,反之则检测到变化,需要更新视图。 angular2中有了Zone.js。...对于setTimeout,addEventListener、promise等都在ngZone中执行(换句话说,就是被zone.js封装重写了),angular并在ngZone中setup了相应的钩子,通知...Promise,无论是否调用then。promise都会立即执行;而observables只是被创建,当调用(subscribe)的时候才会被执行。...可以取消,Promise不可以 如果提高Angular的性能 Angular也还是网页应用,所以一般的提高网页西能的技巧都是通用的。

4.3K20

NodeJS中的异步编程经验

关于 Unhandled Rejection 一个 Promise 是一个异步操作的状态机,其可能处于这三种状态之一 pending:异步操作还在执行中 fulfilled:异步操作已经完成 rejected...在 Node.js 6.6.0 中增加了一个特性:对 Promise 中未处理的 rejection 默认会输出 UnhandledPromiseRejectionWarning 提示 例如:test.js...Promise API 中有 .catch() 这个方法,可以用来处理捕捉 rejection 进行处理 但是注意: 这个例子中虽然用 .catch() 捕捉处理了 Promise 中的...unhandledRejection 事件 在 node process 中有一个 unhandledRejection 事件,当没有对 Promise 的 rejection 进行处理就会抛出这个事件...async 异步函数返回的是 Promise,所以执行异步函数后,统一需要用 .catch() 对可能出现的 rejection 进行捕捉处理,否则统一也是会出现 UnhandledPromiseRejectionWarning

1.8K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    实战 | Change Detection And Batch Update

    Zone.js Angular2同Angular1一样都是直接操作数据的,框架都无法直接感知数据的变化,只能在特定的时机去做批量更新。...Angular1是通过封装自动调用$apply,但是存在手动调用的场景,为了解决这个问题,Angular2没有采用1的实现机制,转而使用了Zone.js。...Angular2更新机制大体如下: ngZone是对Zone.js的服务封装,Angular2会在每个task执行结束后触发更新。...小结 由于Zone.js的存在,我们可以在任何场景下更新数据而无需手动调用检测,Angular2也是批量更新。...我们可以通过将Vue.config.async设置为false,关闭异步更新机制,让它变成同步更新,看下面的例子: 打开控制台你会发现打印了1 2,但是最好别这么干 如果关闭了异步模式,Vue 在检测到数据变化时同步更新

    3.2K20

    进阶 | 重新认识Angular

    Angular 核心:使用脏检测(新/旧值比较)Diff 当Model发生变化,会检测所有视图是否绑定了相关数据,再更改视图 Zone.js(猴子补丁:运行时动态替换) 将Javascript中异步任务包裹一层...,使其运行在Zone上下文中 每一个异步任务为一个Task,提供钩子函数(hook) Angular2+变化 zone.js对异步任务进行跟踪 脏检查计算放进worker Angular2+中树结构,自上而下进行脏检查...---- Rxjs 很多时候我们都拿Rxjs和Promise来比较,但其实它们有很大的不一致。 以下很多内容来自《不要把Rx用成Promise》。...Promise需要调用then或者catch才能够执行,catch是另一种形式的then,调用then或者catch之后,它返回一个新的Promise,这样新的Promise也可以同样被调用,所以可以做成无限的...Promise的数据是一次性流出的,因为Promise内部维持着状态,初始化的pending,转成resolved或者rejected之后,状态就不可逆转了。

    2.6K10

    基于 qiankun 的微前端最佳实践(万字长文) - 从 0 到 1 篇

    接入 Angular 微应用 Angular 与 qiankun 目前的兼容性并不太好,接入 Angular 微应用需要一定的耐心与技巧。...", }, ]; export default apps; 通过上面的代码,我们就在主应用中注册了我们的 Angular 微应用,进入 /angular 路由时将加载我们的 Angular 微应用...micro-app 最后我们在主应用的入口文件,引入 zone.js,代码实现如下: Angular 运行依赖于 zone.js。...qiankun 基于 single-spa 实现,single-spa 明确指出一个项目的 zone.js 只能存在一份实例,所以我们在主应用注入 zone.js。...// micro-app-main/src/main.js // 为 Angular 微应用所做的 zone 包注入 import "zone.js/dist/zone"; 配置微应用 在主应用的工作完成后

    7K40

    Angular开发实践(六):服务端渲染

    Angular Universal Angular在服务端渲染方面提供一套前后端同构解决方案,它就是 Angular Universal(统一平台),一项在服务端运行 Angular 应用的技术。...标准的 Angular 应用会执行在浏览器中,它会在 DOM 中渲染页面,以响应用户的操作。...:server.ts import 'zone.js/dist/zone-node'; import 'reflect-metadata'; import { enableProdMode } from...当你的应用需要那些只有当运行在服务器实例中才需要的信息时,就要提供 extraProviders 参数。 ngExpressEngine 函数返回了一个会解析成渲染好的页面的承诺(Promise)。...8、创建服务端预渲染的程序:prerender.ts // Load zone.js for the server. import 'zone.js/dist/zone-node'; import 'reflect-metadata

    4.8K100

    仅仅是 Promise吗?

    昨天在研究 iOS JavaScriptCore 里边如何捕获未处理的 Promise rejection,发现 jscore 本身并不提供任何接口,只能想其他办法绕过去。...参考了 Egret Native 的实现,发现他们实现和自己的臆想也是吻合的,就是在 JS 侧对 Promise 做覆盖,或者叫 polyfill,这样就能完整的掌控 Promise 实现和 reject...本文就是简单探讨一下 await 后边可以跟什么内容,这个和我的目标——“捕获各种 Promise reject”是有关联的。...有个比较有趣的点是,无论是 js 侧 polyfill 实现的 Promise,还是浏览器原生的 Promise,都可以接在 await 后,为什么呢?...所以,当然,Promise 是一种 Thenable 实现,无论浏览器原生的 Promise 还是 polyfill 的 Promise 都符合 Thenable 规范,所以刚才第一种情况下的疑问也解开了

    1.6K20

    一文详聊前端异常原理

    当编译器检测到一个函数调用是尾递归的时候,它就覆盖当前的活动记录而不是在栈中去创建一个新的。 5. Error 与自定义异常 Error 是所有错误的基类,其他错误类型继承该类型。...主要注意的是,Promise 的 catch 方法用于处理 rejected 状态,而非处理异常。Rejected 状态未处理的话会触发 Uncaught Rejection....这种 Promise 的同步写法,通常会被开发者忽略 rejected 的处理,可以用 try catch 来捕获。...(‘unhandledrejection’,・・・); 捕获未处理的异步 reject window.addEventListener (‘error’, …) 捕获资源异常 重写 fetch, XMLHttpRequest...来捕获接口状态 总结 本文详细讲解了 ECMA 中 8 种异常的产生原理,涉及了 LHS&RHS、递归优化、ScriptError、finally、Promise 等知识点,希望在处理异常的工作中能给你带来帮助

    1.5K40
    领券