- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我收到以下错误消息:在使用 karma/ Jasmine 的Angular 6单元测试中,this.handler.handle不是函数。当我在项目文件夹中键入“ng test”命令时,在命令行中会出现此错误。
Chrome 67.0.3396 (Windows 10.0.0) AppComponent should create FAILED
Failed: _this.handler.handle is not a function
TypeError: _this.handler.handle is not a function
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { RouterTestingModule } from '@angular/router/testing';
import { AppComponent } from './app.component';
import { CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
import { FormsModule, FormBuilder } from '@angular/forms';
import { HttpClientModule, HttpClient, HttpHandler } from '@angular/common/http';
describe('AppComponent', () => {
let component: AppComponent;
let fixture: ComponentFixture<AppComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
imports: [FormsModule, RouterTestingModule, HttpClientModule],
schemas: [CUSTOM_ELEMENTS_SCHEMA],
declarations: [AppComponent],
providers: [HttpClientModule, HttpClient, HttpHandler]
}).compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(AppComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', async(() => {
expect(component).toBeTruthy();
}));
});
import { Component, ViewChild, OnInit } from '@angular/core';
import { AuthorizationService } from 'src/app/authorization.service';
import { Router } from '@angular/router';
import { MdcDrawer } from '@angular-mdc/web';
import { tap, catchError } from 'rxjs/operators';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.scss']
})
export class AppComponent {
@ViewChild(MdcDrawer) sidenav: MdcDrawer;
flip = false;
constructor(private router: Router, private authorizationService: AuthorizationService) {
this.authorizationService.getAuthorization().subscribe();
}
toggleState() {
if (this.flip) {
this.flip = false;
} else {
this.flip = true;
}
}
goToPage(route: String) {
this.router.navigate([route]).catch(err => {
console.log(err);
});
this.sidenav.close();
}
close() {
console.log('CLOSE');
this.sidenav.close();
}
}
import { BrowserModule } from '@angular/platform-browser';
import { NgModule, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
import { HttpModule } from '@angular/http';
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
import { AppRoutingModule } from './app-routing.module';
import { AppComponent } from './app.component';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { LayoutModule } from '@angular/cdk/layout';
import * as MATERIAL_MODULES from '@angular/material/';
import * as MDC_MODULES from '@angular-mdc/web';
import { TrackUpdateComponent } from './track-update/track-update.component';
import { TrackUpdatePromptComponent } from './track-update-prompt/track-update-prompt.component';
import { NavigationBarComponent } from './navigation-bar/navigation-bar.component';
import { ActionToolbarComponent } from './action-toolbar/action-toolbar.component';
import { SaveButtonToolbarComponent } from './save-button-toolbar/save-button-toolbar.component';
import { HttpClientModule, HttpClient, HTTP_INTERCEPTORS } from '@angular/common/http';
import { EquipmentCardComponent } from './equipment-card/equipment-card.component';
import { EquipmentCardListComponent } from './equipment-card-list/equipment-card-list.component';
import { ListOptionsComponent } from './list-options/list-options.component';
import { EquipmentCardLoadingComponent } from './equipment-card-loading/equipment-card-loading.component';
import { GoToTopComponent } from './go-to-top/go-to-top.component';
import { TapActionListComponent } from './tap-action-list/tap-action-list.component';
import { JumpActionComponent } from './jump-action/jump-action.component';
import { GlobalErrorsComponent } from './global-errors/global-errors.component';
import { SwitchActionListComponent, AssignTrackForm } from './switch-action-list/switch-action-list.component';
import { AddActionComponent } from './add-action/add-action.component';
import { ErrorHandler } from './global-errors/error_handler';
import { RequestInterceptor } from './global-errors/http_interceptor';
import { ActionService } from './action.service';
import { TrackIdService } from './track-id-service.service';
import { TrackInquiryService } from './track-inquiry.service';
import { UserPreferenceService } from './user-preference.service';
import { AuthorizationService } from './authorization.service';
import { EquipmentInsertCardComponent } from './equipment-insert-card/equipment-insert-card.component';
import { LoadingIconComponent } from './loading-icon/loading-icon.component';
@NgModule({
declarations: [
AppComponent,
TrackUpdatePromptComponent,
NavigationBarComponent,
TrackUpdateComponent,
ActionToolbarComponent,
SaveButtonToolbarComponent,
EquipmentCardComponent,
EquipmentCardListComponent,
ListOptionsComponent,
EquipmentCardLoadingComponent,
GoToTopComponent,
TapActionListComponent,
JumpActionComponent,
GlobalErrorsComponent,
SwitchActionListComponent,
AssignTrackForm,
AddActionComponent,
EquipmentInsertCardComponent,
LoadingIconComponent
],
entryComponents: [GlobalErrorsComponent, AssignTrackForm],
imports: [
BrowserModule,
AppRoutingModule,
BrowserAnimationsModule,
LayoutModule,
FormsModule,
ReactiveFormsModule,
HttpClientModule,
MDC_MODULES.MdcButtonModule,
MDC_MODULES.MdcCheckboxModule,
MDC_MODULES.MdcFormFieldModule,
MDC_MODULES.MdcToolbarModule,
MDC_MODULES.MdcIconModule,
MDC_MODULES.MdcListModule,
MDC_MODULES.MdcSelectModule,
MDC_MODULES.MdcAppBarModule,
MDC_MODULES.MdcIconToggleModule,
MDC_MODULES.MdcDrawerModule,
MDC_MODULES.MdcTextFieldModule,
MDC_MODULES.MdcDialogModule,
MATERIAL_MODULES.MatButtonModule,
MATERIAL_MODULES.MatCheckboxModule,
MATERIAL_MODULES.MatMenuModule,
MATERIAL_MODULES.MatIconModule,
MATERIAL_MODULES.MatTableModule,
MATERIAL_MODULES.MatCardModule,
MATERIAL_MODULES.MatInputModule,
MATERIAL_MODULES.MatSelectModule,
MATERIAL_MODULES.MatToolbarModule,
MATERIAL_MODULES.MatListModule,
MATERIAL_MODULES.MatTooltipModule,
MATERIAL_MODULES.MatSortModule,
MATERIAL_MODULES.MatDialogModule,
MATERIAL_MODULES.MatSlideToggleModule,
MATERIAL_MODULES.MatSidenavModule,
MATERIAL_MODULES.MatAutocompleteModule,
MATERIAL_MODULES.MatSnackBarModule,
MATERIAL_MODULES.MatExpansionModule
],
providers: [
HttpModule,
HttpClientModule,
HttpClient,
ErrorHandler,
ActionService,
TrackIdService,
TrackInquiryService,
UserPreferenceService,
AuthorizationService,
{
provide: HTTP_INTERCEPTORS,
useClass: RequestInterceptor,
multi: true
}
],
bootstrap: [AppComponent],
schemas: [CUSTOM_ELEMENTS_SCHEMA]
})
export class AppModule {}
最佳答案
对我而言,此问题来自尝试将HttpClient
和HttpHandler
包括在我的提供者的TestBed.configureTestingModule
中,如下所示:
providers: [
HttpClient,
HttpHandler
]
_TypeError: this.handler.handle is not a function
的行抛出错误
HttpClient
和
HttpHandler
,而是将
HttpClientTestingModule
添加到我的导入中,如下所示:
imports: [
HttpClientTestingModule
]
关于angular - TypeError : _this. handler.handle不是函数错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51364455/
我想使用foreach 来等待线程终止。但是,出现以下错误,没有实现。请告诉我。 cannot move out of `*handle` which is behind a shared refer
如果在TypoScript中未配置给定的typeNum,则TYPO3将抛出Exception/CMS/1294587217。 背景:从另一个系统迁移到TYPO3后,我们遇到了许多此类异常,因为在那里使
我需要一个带有 2 个 handle 的 slider ,一个可拖动,另一个固定。我正在使用 Jquery UI slider 。这是我到目前为止尝试过的:http://jsfiddle.net/8K
给定文件的HANDLE(例如C:\\FolderA\\file.txt),我想要一个函数,该函数会将HANDLE返回到包含的目录(在前面的示例中,它将是C:\\FolderA的HANDLE)。例如:
我想通过Automic在Unix中检查文件。如果该文件不存在,则应切换主机并检查文件是否存在。 问题是,我现在不执行错误处理。 每当脚本对象正在处理并且找不到文件时,skript都会中止。我在skri
鉴于: fruitid('Apple', 'Granny Smith', 1). fruitid('Apple', 'Cox', 2). fruitid('Pear', 'Bartlett', 3).
我有一个基于Spring的Wicket应用程序。 有一个池化的数据源bean。 现在,当MySQL死了时,我得到了带有堆栈跟踪的默认Wicket错误页面。 我想处理这种情况,只允许某些页面完全显示(静
我希望能够一次查询多个句柄,其中表格具有相同的格式,例如: 句柄:8000,8001,8003表:foo 想要做这样的事情: x:hopen `8000`8001`8003 x select from
我对在Swift 3中引发自定义异常有些困惑。 在C++中,我可以执行此操作以立即停止方法中的进程,抛出错误并进行处理,而无需进一步进行操作。 void foo() { try {
我一直在阅读MSDN开发人员COM指南。但是this page上的代码令人困惑。在此处复制: The following code sample shows the recommended way o
我有一个计划的批处理文件每天都会启动的过程。如果有错误,我需要内置错误处理才能重启进程。所有这些在大多数情况下都有效,但是我每个月都会收到一次超时错误,所以这是不可避免的。该进程不会将错误级别输出到b
我正在尝试从 chartlyrics API 获取歌词。我编写了一个可以运行但不能在循环内运行的 R 函数。我的脚本是: library(httr) library(RCurl) library(XM
在libuv事件循环中调用prepare handle callback和check handle callback的原因是什么? 最佳答案 I/O 操作发生在这两者之间,因此您可能希望在阻塞 I/O
我正在尝试在 R 中安装 BTYplus 包。 devtools::install_github("mplatzer/BTYDplus", dependencies=TRUE) library(BTY
我有一个Arduino,可以使用pySerialTransfer库通过串行与Mac正常通信,并且可以运行数小时。然后是某种形式的串行中断-尽管一夜间发生时我一直无法确定原因,但只要从笔记本电脑上拔下A
我是hooks和async/await的新手。我正在尝试处理Axios调用中的错误,并且不确定如何使用then/catch或try/catch处理我的API调用中的错误。 在基于类的React中,我将
我正在尝试向脚本中添加一些内容,以便让我知道我复制的文件是否已被完全复制。 基本上,我要压缩一堆文件,然后将它们发送到网络上的映射驱动器。然后,一旦文件被成功复制,我将脚本删除原始位置的文件。该脚本可
我有一个圆形 slider ,其中绘制了一条贝塞尔弧,一个圆弧在 slider 的起点和终点有两个 handle ,圆弧是在圆形 slider 中绘制的。 借助开始和结束 handle ,我可以沿着圆
删除 NULL 指针是安全的。 int* p = NULL; delete p; // ok, secure 句柄是什么? HANDLE h = NULL; CloseHandle(h
如果您没有在 dojo.connect 期间返回的“句柄”,您如何删除 dojo 连接事件? 我的示例涉及将一组事件动态分配给一组对象。 (为简单起见,事件是 onclick 和 ondblclick
我是一名优秀的程序员,十分优秀!