bem.js 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. /**
  2. * bem helper
  3. * b() // 'button'
  4. * b('text') // 'button__text'
  5. * b({ disabled }) // 'button button--disabled'
  6. * b('text', { disabled }) // 'button__text button__text--disabled'
  7. * b(['disabled', 'primary']) // 'button button--disabled button--primary'
  8. */
  9. const ELEMENT = '__';
  10. const MODS = '--';
  11. const join = (name, el, symbol) => el ? name + symbol + el : name;
  12. const prefix = (name, mods) => {
  13. if (typeof mods === 'string') {
  14. return join(name, mods, MODS);
  15. }
  16. if (Array.isArray(mods)) {
  17. return mods.map(item => prefix(name, item));
  18. }
  19. const ret = {};
  20. Object.keys(mods).forEach(key => {
  21. ret[name + MODS + key] = mods[key];
  22. });
  23. return ret;
  24. };
  25. export default {
  26. methods: {
  27. b(el, mods) {
  28. const { name } = this.$options;
  29. if (el && typeof el !== 'string') {
  30. mods = el;
  31. el = '';
  32. }
  33. el = join(name, el, ELEMENT);
  34. return mods ? [el, prefix(el, mods)] : el;
  35. }
  36. }
  37. };