代码拉取完成,页面将自动刷新
/*
* @Author: error: error: git config user.name & please set dead value or install git && error: git config user.email & please set dead value or install git & please set dead value or install git
* @Date: 2023-04-19 11:27:32
* @LastEditors: error: error: git config user.name & please set dead value or install git && error: git config user.email & please set dead value or install git & please set dead value or install git
* @LastEditTime: 2023-04-19 15:01:16
* @FilePath: /ts-challenges/3326.BEMStyleString.ts
* @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
*/
/*
3326 - BEM style string
-------
by Songhn (@songhn233) #medium #template-literal #union #tuple
### Question
The Block, Element, Modifier methodology (BEM) is a popular naming convention for classes in CSS.
For example, the block component would be represented as `btn`, element that depends upon the block would be represented as `btn__price`, modifier that changes the style of the block would be represented as `btn--big` or `btn__price--warning`.
Implement `BEM<B, E, M>` which generate string union from these three parameters. Where `B` is a string literal, `E` and `M` are string arrays (can be empty).
> View on GitHub: https://tsch.js.org/3326
*/
/* _____________ Your Code Here _____________ */
type isNeverToStringM<T extends string> = [T] extends [never] ? '' : `--${T}`
type isNeverToStringE<T extends string> = [T] extends [never] ? '' : `__${T}`
type BEMObj<B extends string, E extends string[], M extends string[]> = {[k in `${B}${isNeverToStringE<E[number]>}${isNeverToStringM<M[number]>}`]:`${B}${isNeverToStringE<E[number]>}${isNeverToStringM<M[number]>}`}
type BEM<B extends string, E extends string[], M extends string[]> = BEMObj<B,E,M>[keyof BEMObj<B,E,M>]
type test = BEM<'btn', ['price'], []>
/* _____________ Test Cases _____________ */
import type { Equal, Expect } from '@type-challenges/utils'
type cases = [
Expect<Equal<BEM<'btn', ['price'], []>, 'btn__price'>>,
Expect<Equal<BEM<'btn', ['price'], ['warning', 'success']>, 'btn__price--warning' | 'btn__price--success' >>,
Expect<Equal<BEM<'btn', [], ['small', 'medium', 'large']>, 'btn--small' | 'btn--medium' | 'btn--large' >>,
]
/* _____________ Further Steps _____________ */
/*
> Share your solutions: https://tsch.js.org/3326/answer
> View solutions: https://tsch.js.org/3326/solutions
> More Challenges: https://tsch.js.org
*/
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。