UNPKG

press-ui

Version:

简单、易用的跨端组件库,兼容 Vue2 和 Vue3,同时支持 uni-app和普通 Vue 项目

57 lines (45 loc) 1.14 kB
const PREFIX = 'van-'; const PREFIX2 = 'press-'; function join(name, mods, prefix) { name = prefix + name; mods = mods.map(mod => `${name}--${mod}`); mods.unshift(name); return mods.join(' '); } function traversing(mods, conf) { if (!conf) { return; } if (typeof conf === 'string' || typeof conf === 'number') { mods.push(conf); } else if (Array.isArray(conf)) { conf.forEach((item) => { traversing(mods, item); }); } else if (typeof conf === 'object') { Object.keys(conf).forEach((key) => { conf[key] && mods.push(key); }); } } export function bem(name, conf) { const mods = []; traversing(mods, conf); return join(name, mods, PREFIX); } export function bem2(name, conf) { const mods = []; traversing(mods, conf); return join(name, mods, PREFIX2); } export function bem3(name, conf, extraClassPrefix) { if (!extraClassPrefix) { return bem2(name, conf); } const mods = []; traversing(mods, conf); const classA = join(name, mods, extraClassPrefix); const classB = join(name, mods, PREFIX2); return `${classA} ${classB}`; } export default bem;