问题 #
type case1 = BEM<'btn', ['price'], []> // 'btn__price'
type case2 = BEM<'btn', ['price'], ['warning', 'success']> // 'btn__price--warning' | 'btn__price--success'
type case3 = BEM<'btn', [], ['small', 'medium', 'large']> // 'btn--small' | 'btn--medium' | 'btn--large'
解答 #
type BEM<B extends string, E extends string[], M extends string[]> = `${B extends '' ? '' : B}${E['length'] extends 0 ? '' : `__${E[number]}`}${M['length'] extends 0 ? '' : `--${M[number]}`}`
拆分 #
利用
[number]
用来索引数组用
${B}
和${E}
和${M}
分别拼接