亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

JavaScript常用工具函數(shù)匯總(瀏覽器環(huán)境)

瀏覽:51日期:2023-10-13 13:49:48

前端業(yè)務(wù)中比較常用的JavaScript工具函數(shù),瀏覽器環(huán)境常用,可直接拷貝在項(xiàng)目里使用。這里統(tǒng)一整理,方便查閱,本文章會(huì)持續(xù)更新。

一、file轉(zhuǎn)為base64

/** * file轉(zhuǎn)為base64 * @param {*} file file對(duì)象 * @param {*} callback */export const fileToDataURL = (file, callback) => { let freader = new FileReader(); freader.readAsDataURL(file); freader.onload = function (e) { callback(e.target.result); }}

二、blob流轉(zhuǎn)換為base64

/** * blob流轉(zhuǎn)換為base64 * @param {*} blob blob對(duì)象 * @param {*} callback */export const blobToDataURL = (blob, callback) => { let freader = new FileReader(); freader.readAsDataURL(blob); freader.onload = function (e) { callback(e.target.result); }}

三、base64轉(zhuǎn)換為blob

/** * base64轉(zhuǎn)換為blob * @param {*} dataurl base64 */export const dataURLtoBlob = (dataurl) => { let arr = dataurl.split(’,’), mime = arr[0].match(/:(.*?);/)[1], bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n); while (n--) { u8arr[n] = bstr.charCodeAt(n); } return new Blob([u8arr], { type: mime });}

四、base64轉(zhuǎn)換為file,IE低版本不兼容

/** * 將base64轉(zhuǎn)換為file,IE低版本不兼容 * @param {*} dataurl base64 * @param {*} filename 文件名 */export const dataURLtoFile = (dataurl, filename) => { let arr = dataurl.split(’,’), mime = arr[0].match(/:(.*?);/)[1], bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n); while (n--) { u8arr[n] = bstr.charCodeAt(n); } return new File([u8arr], filename, { type: mime });}

五、圖片url轉(zhuǎn)化成base64

/** * 圖片url轉(zhuǎn)化成base64 * @param {*} url 圖片url * @param {*} callback * @param {*} outputFormat 圖片格式 */export const imgUrlToDataURL = (url, callback, outputFormat) => { let canvas = document.createElement(’canvas’), ctx = canvas.getContext(’2d’), img = new Image; img.crossOrigin = ’Anonymous’; img.src = url + '?timeStamp=' + new Date().getTime(); img.onload = function () { canvas.height = img.height; canvas.width = img.width; // ctx.drawImage(img, 0, 0); ctx.drawImage(this, 0, 0, img.width, img.height); let dataURL = canvas.toDataURL(outputFormat || ’image/png’); // callback.call(this, dataURL); callback && callback(dataURL) canvas = null; };}

六、獲取窗口尺寸

export function getViewportSize() { let w = 0; let h = 0; if (window.innerWidth) { w = window.innerWidth h = window.innerHeight } else if (document.body && document.body.clientWidth) { w = document.body.clientWidth h = document.body.clientHeight } else if (document.documentElement && document.documentElement.clientWidth) { w = document.documentElement.clientWidth h = document.documentElement.clientHeight } return { w, h }}

七、瀏覽器環(huán)境檢測(cè)

const ua = window.navigator.userAgent.toLowerCase()// 是否微信export const isWx = () => ua.match(/MicroMessenger/i) == ’micromessenger’// 是否ipadexport const isIpad = () => ua.indexOf(’ipad’) > -1// 是否iphoneexport const isIphone = () => ua.indexOf(’iphone os’) > -1// 是否ucexport const isUc = () => ua.indexOf(’ucweb’) > -1// 是否windows pcexport const isWindows = () => ua.indexOf(’windows’) > -1// 是否androidexport const isAndroid = () => ua.indexOf(’android’) > -1 || ua.indexOf(’adr’) > -1// 是否iosexport const isIos = () => /(iphone|ipod|ipad|ios)/i.test(ua)// 是否qq瀏覽器export const isQq = () => ua.indexOf(’mqqbrowser’) > -1 && ua.indexOf(’ qq’) < 0// 是否qq內(nèi)置瀏覽器export const isQQInstalled = () => ua.indexOf(’ qq’) > -1 && ua.indexOf(’mqqbrowser’) < 0

八、開啟與關(guān)閉全屏

// 開啟全屏export function launchFullscreen(element) { element = element || document.documentElement if (element.requestFullscreen) { element.requestFullscreen() } else if (element.mozRequestFullScreen) { element.mozRequestFullScreen() } else if (element.msRequestFullscreen) { element.msRequestFullscreen() } else if (element.webkitRequestFullscreen) { element.webkitRequestFullScreen() }}// 關(guān)閉全屏export function exitFullscreen() { if (document.exitFullscreen) { document.exitFullscreen() } else if (document.msExitFullscreen) { document.msExitFullscreen() } else if (document.mozCancelFullScreen) { document.mozCancelFullScreen() } else if (document.webkitExitFullscreen) { document.webkitExitFullscreen() }}

九、返回頂部/指定位置,實(shí)現(xiàn)滾動(dòng)動(dòng)畫

/** * @param {*} number 距離頁(yè)面頂部的距離 * @param {*} time 滾動(dòng)所需時(shí)間 單位ms */const scrolling = (number = 0, time) => { if (!time) { document.body.scrollTop = document.documentElement.scrollTop = number; return number; } // 設(shè)置循環(huán)的間隔時(shí)間 值越小消耗性能越高 const spacingTime = 20; // 計(jì)算循環(huán)的次數(shù) let spacingInex = time / spacingTime; // 獲取當(dāng)前滾動(dòng)條位置 let nowTop = document.body.scrollTop + document.documentElement.scrollTop; // 計(jì)算每次滑動(dòng)的距離 let everTop = (number - nowTop) / spacingInex; let scrollTimer = setInterval(() => { if (spacingInex > 0) { spacingInex--; ScrollTop(nowTop += everTop); } else { clearInterval(scrollTimer); // 清除計(jì)時(shí)器 } }, spacingTime);};// 滾動(dòng)到距離頁(yè)面頂部500px的位置 動(dòng)畫時(shí)間為300ms// scrolling(500, 300);

十、實(shí)現(xiàn)錨點(diǎn)滾動(dòng)

// 運(yùn)用了H5的scrollIntoView方法,這是一個(gè)實(shí)驗(yàn)中的功能,IE 8以下、Safari 6以下、Safari on iOS 5以下不兼容const scrollToAnchor = (anchorName) => { if (anchorName) { // 找到錨點(diǎn) let anchorElement = document.getElementById(anchorName); // 如果對(duì)應(yīng)id的錨點(diǎn)存在,就跳轉(zhuǎn)到錨點(diǎn) if (anchorElement) { anchorElement.scrollIntoView({behavior: ’auto’, // 定義動(dòng)畫過(guò)渡效果, 'auto'或 'smooth' 之一。默認(rèn)為 'auto'block: ’start’, // 定義垂直方向的對(duì)齊, 'start', 'center', 'end', 或 'nearest'之一。默認(rèn)為 'start'inline: ’nearest’, // 定義水平方向的對(duì)齊, 'start', 'center', 'end', 或 'nearest'之一。默認(rèn)為 'nearest' }); } }}

以上就是JavaScript常用工具函數(shù)匯總(瀏覽器環(huán)境)的詳細(xì)內(nèi)容,更多關(guān)于JavaScript 工具函數(shù)的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 免费观看亚洲 | 国产不卡的一区二区三区四区 | 中国一级毛片欧美一级毛片 | 欧美日韩高清在线 | 国产色窝| 久久综合九色综合97手机观看 | 中文字幕日本不卡一二三区 | 美女黄色在线网站大全 | 国产精品videossex激情 | 青青国产成人久久91 | 国产麻豆入在线观看 | 国产91长腿美女在线观看 | 伊人久久精品成人网 | 国产精品一级毛片不收费 | 日本巨乳中文字幕 | 午夜国产福利视频一区 | a级毛片免费高清毛片视频 a级毛片免费播放 | 岛国大片在线观看免费版 | 国产精品任我爽爆在线播放66 | 黄色一级片美国 | 99久久香蕉 | 在线精品国产成人综合第一页 | 国产l精品国产亚洲区久久 国产ppp在线视频在线观看 | 亚洲成人在线视频播放 | 操片免费| 亚洲国产日韩欧美一区二区三区 | 人人干人人玩 | 九九热在线视频免费观看 | 看一级毛片一区二区三区免费 | 国产精品久久久久久福利69堂 | 亚洲经典在线观看 | 精品国产高清毛片 | 国产一级片在线 | 一级做a爱过程免费视频麻豆 | 视频自拍网 | 国内精品福利在线视频 | 亚洲人成亚洲人成在线观看 | 日韩精品欧美在线 | 国内成人精品视频 | 亚洲高清视频在线播放 | 1区1区3区4区产品亚洲 |