UNPKG

lixin-web

Version:

vue and bootstrap

71 lines (65 loc) 2.5 kB
import {util} from '../vuex' import {store} from './store' const pixelRatio = typeof window.devicePixelRatio == 'number' && window.devicePixelRatio; export const hasWebP = () => { return new Promise(function (resolve, reject) { var image = new Image(); image.onload = resolve image.onerror = function () { reject('Could not load image'); }; image.src = ''; }); } util.checkWebP = store.get('isWebP') export const preloadImage = (filename, condition = true, { ext = 'jpg', retina = false, img = new Image, bg = null, checkWebp = () => { }, isWebP = util.checkWebP} = {}) => { if (condition) { if (Array.isArray(filename)) { return Promise.all(filename.map(file => preloadImage(file, condition, { ext, retina, isWebP }))) } else { return new Promise(function (resolve, reject) { let path = retina && pixelRatio > 1 ? `/img/sample/${filename}_${pixelRatio}x_preload` : `/img/sample/${filename}_preload` let url; img.onload = () => { if (bg) { if (bg.nodeType == 1) bg.style.backgroundImage = `url(${url})` if (typeof bg == 'string') document.querySelector(bg).style.backgroundImage = `url(${url})` } return resolve(url) } img.onerror = reject const setWebp = () => { retina && pixelRatio > 1 ? (url = img.srcset = `${path}.webp ${pixelRatio}x`) : (url = img.src = `${path}.webp`) } const setOrigin = () => { retina && pixelRatio > 1 ? (url = img.srcset = `${path}.${ext} ${pixelRatio}x`) : (url = img.src = `${path}.${ext}`) } if (isWebP) { return setWebp() } else if (isWebP === false) { return setOrigin() } hasWebP().then( () => { setWebp(); checkWebp() }, setOrigin ) }) } } } // export const setWebPBg = (filename, condition = !isMobileScreen, element = bodyElement, ext = 'jpg') => { // if (condition) { // let path = `/img/sample/${filename}_preload` // hasWebP().then( // () => element.style.backgroundImage = `url(${path}.webp)`, // () => element.style.backgroundImage = `url(${path}.${ext})` // ) // } // }