device.js 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. /**
  2. * Copyright [2022] [https://www.xiaonuo.vip]
  3. * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
  4. * 1.请不要删除和修改根目录下的LICENSE文件。
  5. * 2.请不要删除和修改Snowy源码头部的版权声明。
  6. * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
  7. * 4.分发源码时候,请注明软件出处 https://www.xiaonuo.vip
  8. * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
  9. * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.xiaonuo.vip
  10. */
  11. import enquireJs from 'enquire.js'
  12. export const DEVICE_TYPE = {
  13. DESKTOP: 'desktop',
  14. TABLET: 'tablet',
  15. MOBILE: 'mobile'
  16. }
  17. export const deviceEnquire = function (callback) {
  18. const matchDesktop = {
  19. match: () => {
  20. callback && callback(DEVICE_TYPE.DESKTOP)
  21. }
  22. }
  23. const matchTablet = {
  24. match: () => {
  25. callback && callback(DEVICE_TYPE.TABLET)
  26. }
  27. }
  28. const matchMobile = {
  29. match: () => {
  30. callback && callback(DEVICE_TYPE.MOBILE)
  31. }
  32. }
  33. // screen and (max-width: 1087.99px)
  34. enquireJs
  35. .register('screen and (max-width: 576px)', matchMobile)
  36. .register('screen and (min-width: 576px) and (max-width: 1199px)', matchTablet)
  37. .register('screen and (min-width: 1200px)', matchDesktop)
  38. }