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

搭建 karma + jasmine 测试环境

什么是 karma karma 是由Angular团队开发一款测试工具,帮助开发者更好更快速地在多种环境下执行测试代码,拿到测试结果。...根据配置项选择安装插件 (1) 测试框架选择jasmine,安装步骤如下: $ npm install jasmine-core karma-jasmine -D 复制代码 这里要装两个,一个是jasmine...核心,另一个是karma对jasmine封装。...Babel及其相关插件: $ npm install babel-cli babel-preset-env babel-plugin-transform-es2015-modules-umd -D $...结束 按照上述步骤,大家应该可以配置好自己 karma + jasmine 测试环境,如果遇到问题或者文中有写错地方,欢迎大家来讨论。文章末尾是需要安装模块链接,大家可以一键直达。

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

Angular2 之 单元测试

组件测试 单独service测试 Angular测试工具 Angular测试工具类包含了TestBed类和一些辅助函数方法,当时这不是唯一,你可以不依赖Angular DI(依赖注入)系统,...组件注入器是fixtureDebugElement属性。 出人意料是,请不要引用测试代码里提供给测试模块userServiceStub对象。它是行不通!...通过将测试代码放到特殊异步测试区域来运行,async函数简化了异步测试程序代码。 接受无参数函数方法,返回无参数函数方法,变成Jasmineit函数参数。...测试代码是将模拟英雄(expectedHero)赋值给组件hero属性。...如果组件想期待那样工作,click()通知组件selected属性发出hero对象,测试程序通过订阅selected事件而检测到这个值,所以测试应该成功。

5.5K20

Angular-内存溢出问题

本项目用angular6搭建,用动态组件形式来显示页面,之前遇到过因为内存溢出而导致无法aot问题, Angular4以上该方法都适用 解决方法:手动改写内存上限 修改目录: my-project..._@angular_compiler-cli@4.0.1@@angular\compiler-cli\src\main.js" %* ) 至于到底是什么原因导致内存溢出,还不清楚,只是有如下猜测: 1...)文件过多; 2)订阅数据没有销毁占用内存,(看了下订阅数据很少,应该不是的); 3)因为所有的组件都在一个根目录下(上面说了,用动态组件没用路由),导致需要编译组件过多?...暂时还不清楚只能先用设置内存上限方法来解决,有大神的话望不吝指教; 还有一个问题就是用动态组件方式,组件都在根目录下,会导致首次加载时间过长。...", "@types/node": "~8.9.4", "codelyzer": "~4.3.0", "jasmine-core": "~2.99.1", "jasmine-spec-reporter

2.3K20

JavaScrip最容易犯十大错误及其避免方法()

Uncaught TypeError: Cannot read property 如果你是一个javascript开发者,你肯定看到过此错误 读取属性或调用方法对象未定义 这可能由于许多原因而发生,...反过来,这意味着ItemList将项目定义为未定义,并且您在控制台中收到错误 - “Uncaught TypeError无法读取未定义属性’map’”。 这很容易解决。...: ‘undefined’ is not an object 3TypeError: null is not an object 有趣是,在JavaScript中,null和undefined不一样,...Uncaught TypeError: Cannot set property 当我们尝试访问未定义变量时,它总是返回undefined,我们无法获取或设置undefined任何属性。...在这种情况下,应用程序将抛出“Uncaught TypeError无法设置未定义属性”。 10.

11510

来自1000多个项目的10大JavaScript错误浅析

TypeError: ’undefined’ is not an object 在Safari里读取未定义对象属性或调用未定义对象方法时就会发生这个错误,在Safari开发者控制台可以很容易地重现这个错误...TypeError: null is not an object 在Safari里读取空(null)对象属性或调用空对象方法时就会发生这个错误,在Safari开发者控制台可以很容易地重现这个错误。...TypeError: Object doesn’t support property 在IE里读取未定义对象属性或调用未定义对象方法时就会发生这个错误,在IE开发者控制台可以很容易地重现这个错误。...TypeError: Cannot read property ‘length’ 在Chrome里读取undefined变量length属性时会发生这个错误,这个错误可以在Chrome开发者控制台重现...Uncaught TypeError: Cannot set property 我们无法对undefined变量进行赋值或读取操作,否则的话会抛出“Uncaught TypeError: cannot

6.2K80

2017年前端框架、类库、工具大比拼

也许本文无法告诉你哪个是最好,但是最适合自己项目的,就是最好。 类库 类库是一个有组织功能集合。典型类库包括字符串处理、日期、HTML DOM元素、事件、Cookie、动画、网络请求等功能。...学习曲线陡峭 大代码库 无法升级到Angular 2.x Angular 2.x(现在是Angular 4.x) Angular 类型 框架 网站...它支持异步测试,并且经常与Chai配合使用,这样可以使测试代码以可读取方式表达。...Jasmine Jasmine 网站 jasmine.github.io 知识库 github.com/jasmine/jasmine-npm...过去只有少量基本类库可以选择,但是现在可供选择类库已经铺天盖地。也许无法确定哪个类库、框架和工具是最好,但是最适合自己项目的,就是最好

2.3K10

10 种 JavaScript 最常见错误

当你读取一个未定义对象属性或调用其方法时,这个错误会在 Chrome 中出现。 您可以很容易在 Chrome 开发者控制台中进行测试。 ?...我们来看一个在真实应用程序中发生例子:我们选择 React,但该情况也同样适用于 Angular、Vue 或任何其他框架。...2、 TypeError: ‘undefined’ is not an object 这是在 Safari 中读取属性或调用未定义对象上方法时发生错误。...3、 TypeError: null is not an object 这是在 Safari 中读取属性或调用空对象上方法时发生错误。...8、 TypeError: Cannot read property ‘length’ 这是因为读取未定义变量长度属性而发生错误。 您可以在 Chrome 开发者控制台中进行测试。 ?

8.4K20

AngularJS面试常见问题汇总

1.angular数据绑定采用什么机制?详述原理 脏检查机制。 双向数据绑定是 AngularJS 核心机制之一。...MVVM:Model-View-ViewModel Model就是我们常说数据模型,用于数据构造,数据驱动, 主要提供基础实体属性以及每个属性验证逻辑....View主要用于界面呈现,与用户输入设备进行交互 ViewModel是MVVM架构中最重要部分,ViewModel中包含属性,命令,方法,事件,属性验证等逻辑,用于逻辑实现,负责View与Model之间通信...7.接口访问代码放在哪里? 放在service里。 8.如何进行angular单元测试?...使用karam+jasmine 进行单元测试,我们通过ngMock引入angular app然后自行添加我们测试用例。

2K20

10 种最常见 Javascript 错误

当你读取一个未定义对象属性或调用其方法时,这个错误会在 Chrome 中出现。 您可以很容易在 Chrome 开发者控制台中进行测试(尝试)。 ?...我们来看一个在真实应用程序中发生例子:我们选择 React,但该情况也同样适用于 Angular、Vue 或任何其他框架。...TypeError: ‘undefined’ is not an object 这是在 Safari 中读取属性或调用未定义对象上方法时发生错误。...TypeError: null is not an object 这是在 Safari 中读取属性或调用空对象上方法时发生错误。...TypeError: Cannot read property ‘length’ 这是 Chrome 中发生错误,因为读取未定义变量长度属性。 您可以在 Chrome 开发者控制台中进行测试。

6.8K80

AngularDart4.0 英雄之旅-教程-08HTTP 顶

响应JSON有一个单一数据属性,它拥有主叫方想要英雄列表。 所以你抓住这个列表并把它作为已解决Future值返回。 请注意服务器返回数据形状。...} catch (e) { throw _handleError(e); } 这是关键一步。 您必须预见HTTP失败,因为它们经常出于无法控制原因而发生。...正如所料,* ngFor从组件英雄属性重复英雄对象。 但正如你很快就会看到,英雄财产现在是一个英雄列表流,而不仅仅是一个英雄名单。...'package:angular_router/angular_router.dart'; import 'package:stream_transform/stream_transform.dart...初始化英雄属性(ngOnInit) 您可以将搜索条件流转换为英雄列表流,并将结果分配给heroes属性

11K30

重温 ES6 Symbol

// TypeError 6.Symbol 工厂函数返回 symbol,可作为对象属性名,可以避免属性冲突,在 for...in 迭代中不可枚举 var obj = {}; obj[Symbol(...类私有属性和方法 const myPrivateMethod = Symbol("myPrivateMethod"); const myPrivateProperty = Symbol("myPrivateProperty...'.search('ng') // 4 该示例执行流程: 解析 'angular'.search('ng') 把 ‘angular’ 转换为字符串对象 new String('angular') 把...‘ng’ 转换为正则对象 new Regexp('ng') 调用 ‘angular’ 字符串对象 search 方法,该方法内部会自动调用 ng 正则对象 Symbol.search 方法 具体可以参考以下伪代码...) 语句 把 ‘Angular7’ 转换为字符串对象 new String("Angular7") 由于 article 是对象,这里不需要进行转换 调用 ‘Angular7’ 字符串对象 search

89420
领券