欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

angular組件間傳值測試的方法詳解

 更新時間:2020年05月07日 09:41:41   作者:小強(qiáng)Zzz  
這篇文章主要給大家介紹了關(guān)于如何測試angular組件間傳值的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用angular組件具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

前言

我們知道angular組件間通訊有多種方法,其中最常用的一種方法就是借助于 @Input 和 @Output 進(jìn)行通訊。具體如何通訊請參考angular組件間通訊,本文不再贅述,我們來講講關(guān)于此方法如何進(jìn)行單元測試。

創(chuàng)建假組件

我們單元測試父組件與子組件的的交互是否符合我們的要求,我們在父組件進(jìn)行測試,就需要模擬一個假的子組件出來,這樣排除其他因素對測試的影響。

比如現(xiàn)在我在分頁組件里寫了一個每頁大小選擇組件,現(xiàn)在要測試一下組件間交互?,F(xiàn)在分頁組件就是我們的父組件,每頁大小組件就是我們的子組件。我們現(xiàn)在需要去模擬一個假的子組件出來。我們先模擬一個假模塊出來。

我們的子組件在core模塊里,我們在core模塊下創(chuàng)造一個core-testing模擬模塊。再在core-testing模塊下創(chuàng)造一個core組件,因為我們是一個模擬模塊,我們只需要ts文件即可。

@Component({
 selector: 'app-size',
 template: `
 <p>
  size-select works!
 </p>
 `,
 styles: []
})
export class SizeComponent implements OnInit {
 constructor() {
 }

 ngOnInit() {
 }
}

為了我們可以在父組件的測試文件中得到模擬的子組件,我們還需要一個controller,在core-testing文件夾下創(chuàng)建一個core-testing-controller.ts文件。CoreTestingController類繼承TestingController。

export class CoreTestingController extends TestingController {
}

同時在我們的core-testing.module里聲明CoreTestingController為提供者

providers: [
 CoreTestingController
 ]

此時我們的目錄樹

 core-testing git:(134) ✗ tree  
.
├── core-testing-controller.ts
├── core-testing.module.ts
├── page
│   └── page.component.ts
└── size
    └── size.component.ts

因為我們是模擬的子組件,所以我們應(yīng)該添加子組件的@Input 和 @Output,同時在構(gòu)造函數(shù)里把這個模擬的子組件添加到CoreTestingController里。

export class SizeComponent implements OnInit {
 @Input() size: number;

 @Output() onChangeSize = new EventEmitter<number>();

 constructor(private controller: CoreTestingController) {
 this.controller.addUnit(this);
 }
}

此時我們的準(zhǔn)備工作就完成了。

單元測試

首先我們引入假組件并聲明提供者

import {CoreTestingController} from '../core-testing/core-testing-controller';
import {SizeComponent} from '../core-testing/size/size.component';

beforeEach(async(() => {
 TestBed.configureTestingModule({
  declarations: [ PageComponent, SizeComponent ],
  imports: [FormsModule],
  providers: [
  CoreTestingController
  ]
 })
 .compileComponents();
 }));

我你們這里引入的是我們創(chuàng)造的假的SizeComponent,因為我們父組件與子組件在同一個模塊里,所以我們直接引入SizeComponent就可以。

此時我們父組件想要子組件時就會使用假的子組件。

我們先斷言@Input,我們斷言父組件的值與我們假的子組件值相等

it('選擇每頁大小', () => {
 const controller = TestBed.get(CoreTestingController) as CoreTestingController;
 const sizeComponent = controller.get(SizeComponent) as SizeComponent;
 expect(sizeComponent.size).toBe(component.size);
 });

我們這里的get方法就對應(yīng)的我們之前的構(gòu)造函數(shù)的addUnit方法,具體參考TestingController類定義的方法。

然后我們再斷言子組件向父組件@Output也沒有問題,我們先spyon父組件接收子組件值的方法,然后定義一個變量并傳給父組件,然后斷言父組件接收到的值與子組件傳的值相同。

spyOn(component, 'onSizeSelected');
const emitSize = 4;
sizeComponent.onChangeSize.emit(emitSize);
expect(component.onSizeSelected).toHaveBeenCalledWith(4);

這時我們就達(dá)到了我們測試的目的。

我們啟動測試,發(fā)現(xiàn)我們本來的選擇下拉框變成了文字,這就是我們假的子組件的效果。

總結(jié)

我們進(jìn)行單元測試,就需要除被測組件外,其他引用組件盡量為假,才能達(dá)到我們的目的。

到此這篇關(guān)于angular組件間傳值測試的文章就介紹到這了,更多相關(guān)angular組件間傳值測試內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • AngularJS 中ui-view傳參的實例詳解

    AngularJS 中ui-view傳參的實例詳解

    這篇文章主要介紹了AngularJS 中ui-view傳參的實例詳解的相關(guān)資料,這里提供實例幫助大家學(xué)習(xí)理解這部分內(nèi)容,需要的朋友可以參考下
    2017-08-08
  • Angular.JS中select下拉框設(shè)置value的方法

    Angular.JS中select下拉框設(shè)置value的方法

    select 是 AngularJS 預(yù)設(shè)的一組directive。下面這篇文章主要給大家介紹了關(guān)于Angular.JS中select下拉框設(shè)置value的方法,文中介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。
    2017-06-06
  • Angular.js中$resource高大上的數(shù)據(jù)交互詳解

    Angular.js中$resource高大上的數(shù)據(jù)交互詳解

    這篇文章主要給大家介紹了關(guān)于Angular.js中$resource高大上的數(shù)據(jù)交互的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用angular.js具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編來一起看看吧。
    2017-07-07
  • AngularJS過濾器filter用法分析

    AngularJS過濾器filter用法分析

    這篇文章主要介紹了AngularJS過濾器filter用法,結(jié)合實例形式分析了過濾器filter的功能、分類、使用方法與相關(guān)注意事項,需要的朋友可以參考下
    2016-12-12
  • 實例詳解angularjs和ajax的結(jié)合使用

    實例詳解angularjs和ajax的結(jié)合使用

    本篇文章給大家介紹angularjs和ajax的結(jié)合使用,本文介紹的非常詳細(xì),對angularjs和ajax感興趣的朋友一起參考下吧
    2015-10-10
  • 淺談Angular2 ng-content 指令在組件中嵌入內(nèi)容

    淺談Angular2 ng-content 指令在組件中嵌入內(nèi)容

    本篇文章主要介紹了淺談Angular2 ng-content 指令在組件中嵌入內(nèi)容,具有一定的參考價值,有興趣的可以了解一下
    2017-08-08
  • AngualrJS中每次$http請求時的一個遮罩層Directive

    AngualrJS中每次$http請求時的一個遮罩層Directive

    AngularJS是一款非常強(qiáng)大的前端MVC框架。接下來通過本文給大家介紹AngualrJS中每次$http請求時的一個遮罩層Directive,本文非常具有參考借鑒價值,特此分享供大家學(xué)習(xí)
    2016-01-01
  • Angular中使用Intersection Observer API實現(xiàn)無限滾動效果

    Angular中使用Intersection Observer API實現(xiàn)無限滾動效果

    這篇文章主要介紹了Angular中使用Intersection Observer API實現(xiàn)無限滾動,實現(xiàn)原理為 在data下面加一個loading元素 如果此元素進(jìn)入視窗 則調(diào)用api獲取新的數(shù)據(jù)加到原來的數(shù)據(jù)里面,這時loading就會被新數(shù)據(jù)頂下去,感興趣的朋友一起看看吧
    2023-12-12
  • AngularJS監(jiān)聽路由的變化示例代碼

    AngularJS監(jiān)聽路由的變化示例代碼

    這篇文章給大家分享了如何利用AngularJS監(jiān)聽路由的變化,文中給出了示例代碼相信對大家的理解很有幫助,有需要的朋友們可以參考借鑒。
    2016-09-09
  • angularjs學(xué)習(xí)筆記之完整的項目結(jié)構(gòu)

    angularjs學(xué)習(xí)筆記之完整的項目結(jié)構(gòu)

    這篇文章主要介紹了angularjs學(xué)習(xí)筆記之完整的項目結(jié)構(gòu)的相關(guān)資料,需要的朋友可以參考下
    2015-09-09

最新評論