本文整理汇总了TypeScript中lodash-es/memoize.default函数的典型用法代码示例。如果您正苦于以下问题:TypeScript default函数的具体用法?TypeScript default怎么用?TypeScript default使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了default函数的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的TypeScript代码示例。
示例1: memoize
memoize((a: Date|number) => memoize((b: Date|number) => memoize((local: boolean) : boolean => {
if (typeof a === 'number') {
if (isNaN(a)) {
return false;
}
a = timestampToDate(a);
}
if (typeof b === 'number') {
if (isNaN(b)) {
return false;
}
b = timestampToDate(b);
}
return local ? (
a.getFullYear() === b.getFullYear() &&
a.getMonth() === b.getMonth() &&
a.getDate() === b.getDate()
) : (
a.getUTCFullYear() === b.getUTCFullYear() &&
a.getUTCMonth() === b.getUTCMonth() &&
a.getUTCDate() === b.getUTCDate()
);
})))
开发者ID:cyph,项目名称:cyph,代码行数:26,代码来源:time.ts
示例2: compareDates
memoize((date: number|Date) =>
memoize((noToday: boolean) : string|undefined => {
date = timestampToDate(date);
return compareDates(date, now, true) ?
noToday ? undefined : strings.today :
compareDates(date, now - 86400000, true) ?
strings.yesterday :
date.getFullYear() === timestampToDate(now).getFullYear() ?
`${
date.toLocaleDateString(undefined, {weekday: 'long'})
}, ${
date.toLocaleDateString(undefined, {month: 'long'})
} ${
getOrdinal(date.getDate())
}` :
`${
date.toLocaleDateString(undefined, {month: 'long'})
} ${
getOrdinal(date.getDate())
}, ${
date.getFullYear()
}`
;
})
开发者ID:cyph,项目名称:cyph,代码行数:25,代码来源:time.ts
示例3:
memoize((startPadding: number) =>
memoize((endPadding: number) =>
getTimesInternal(
{
end: {hour: endHour, minute: endMinute},
start: {hour: startHour, minute: startMinute}
},
increment,
startPadding,
endPadding
)
)
开发者ID:cyph,项目名称:cyph,代码行数:12,代码来源:time.ts
示例4: timestampToDate
memoize((now?: Date|number) =>
memoize((startTime?: Date|number) : number => {
if (
(typeof now !== 'number' && !(now instanceof Date)) ||
(typeof startTime !== 'number' && !(startTime instanceof Date)) ||
!compareDates(now, startTime)
) {
return 0;
}
if (typeof now === 'number') {
now = timestampToDate(now);
}
return (
(now.getMinutes() + (now.getHours() * 60)) -
(timeRange.start.minute + (timeRange.start.hour * 60))
);
})
开发者ID:cyph,项目名称:cyph,代码行数:19,代码来源:time.ts
示例5: Date
memoize((noZero: boolean) =>
memoize((timestamp?: number) : Date =>
timestamp === undefined || isNaN(timestamp) || (noZero && timestamp === 0) ?
new Date() :
new Date(timestamp)
)
开发者ID:cyph,项目名称:cyph,代码行数:6,代码来源:time.ts
示例6:
import {SecurityContext} from '@angular/core';
import {SafeStyle, SafeUrl} from '@angular/platform-browser';
import memoize from 'lodash-es/memoize';
import {MaybePromise} from '../maybe-promise-type';
import {staticDomSanitizer} from './static-services';
/** Converts a URL into a `url()` SafeStyle. */
/* tslint:disable-next-line:no-null-keyword */
export const urlToSafeStyle =
memoize(async (url: MaybePromise<string|SafeUrl|null|undefined>) : Promise<SafeStyle> => {
const domSanitizer = await staticDomSanitizer;
const urlValue = await url;
const urlString = typeof urlValue === 'string' || !urlValue ?
urlValue :
domSanitizer.sanitize(SecurityContext.URL, urlValue)
;
return domSanitizer.bypassSecurityTrustStyle(urlString ? `url(${urlString})` : '');
})
;
开发者ID:cyph,项目名称:cyph,代码行数:22,代码来源:safe-values.ts
示例7: FormControl
import {FormControl} from '@angular/forms';
import memoize from 'lodash-es/memoize';
import {combineLatest, concat, of} from 'rxjs';
import {map} from 'rxjs/operators';
import {safeStringCompare} from './compare';
/** Creates a form control that has to match a specified value. */
export const formControlMatch = (o: {value: string}, initialValue: string = '') =>
new FormControl(initialValue, [control =>
!safeStringCompare(control.value, o.value) ?
{mismatch: true} :
/* tslint:disable-next-line:no-null-keyword */
null
])
;
/** Observes a form control. */
export const watchFormControl = memoize((control: FormControl) => concat(
of(control),
combineLatest(
control.statusChanges,
control.valueChanges
).pipe(
map(() => control)
)
));
开发者ID:cyph,项目名称:cyph,代码行数:27,代码来源:form-controls.ts
示例8: memoize
import memoize from 'lodash-es/memoize';
import {translate} from './translate';
/** Converts variable name into human-friendly title-style text. */
export const titleize = memoize((s: string) => translate(
s.
replace(/^([a-z])/g, c => c.toUpperCase()).
replace(/([A-Z])/g, ' $1').
replace(/ And /g, ' & ').
trim()
));
开发者ID:cyph,项目名称:cyph,代码行数:12,代码来源:titleize.ts
注:本文中的lodash-es/memoize.default函数示例由纯净天空整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论