日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JavaScript常用工具函數匯總(瀏覽器環境)

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

前端業務中比較常用的JavaScript工具函數,瀏覽器環境常用,可直接拷貝在項目里使用。這里統一整理,方便查閱,本文章會持續更新。

一、file轉為base64

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

二、blob流轉換為base64

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

三、base64轉換為blob

/** * base64轉換為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轉換為file,IE低版本不兼容

/** * 將base64轉換為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轉化成base64

/** * 圖片url轉化成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 }}

七、瀏覽器環境檢測

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內置瀏覽器export const isQQInstalled = () => ua.indexOf(’ qq’) > -1 && ua.indexOf(’mqqbrowser’) < 0

八、開啟與關閉全屏

// 開啟全屏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() }}// 關閉全屏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() }}

九、返回頂部/指定位置,實現滾動動畫

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

十、實現錨點滾動

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

以上就是JavaScript常用工具函數匯總(瀏覽器環境)的詳細內容,更多關于JavaScript 工具函數的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
女生影院久久| 国产精品中文字幕制服诱惑| 成人在线免费观看网站| 精品视频免费| 日韩欧美精品综合| 欧美aa国产视频| 国产精品三上| 午夜精品影视国产一区在线麻豆| 免费人成精品欧美精品| 影音先锋久久精品| 亚洲v天堂v手机在线| 亚洲欧美在线专区| 久久伊人亚洲| 久久精品av| 日本综合精品一区| 欧美激情另类| 合欧美一区二区三区| 日本aⅴ精品一区二区三区| 国产精品黄网站| 欧美不卡高清一区二区三区| 999在线观看精品免费不卡网站| 综合激情五月婷婷| 精品欧美视频| 亚洲深夜影院| 麻豆中文一区二区| 99久久精品国产亚洲精品| 亚洲日本三级| 国产一二在线播放| 亚洲一区二区小说| 天堂√8在线中文| 亚洲欧洲日韩精品在线| 中文字幕成在线观看| 亚洲视频二区| 亚洲黄色免费看| 亚洲精品少妇| 久久精选视频| 欧美国产三级| 欧美中文日韩| 国产美女高潮在线观看| 亚洲精品少妇| 电影天堂国产精品| 欧美久久精品| 伊人精品在线| 日韩深夜视频| 国产精品白丝av嫩草影院| 在线日韩视频| 精品一二三区| 日本免费一区二区视频| 欧美日韩色图| 国产96在线亚洲| 日本麻豆一区二区三区视频| 亚洲国内欧美| 福利一区二区免费视频| 日本不卡高清| 国产精品日本欧美一区二区三区| 精品日本视频| 国产乱人伦丫前精品视频| 亚洲一区欧美激情| 日韩精品麻豆| 福利视频一区| 麻豆高清免费国产一区| 亚洲毛片在线| 美女国产精品| 五月天久久777| 日韩国产欧美| 久久影院一区二区三区| 欧美影院精品| 日韩在线观看一区二区三区| 国产精品美女久久久| 欧美91精品| 日韩欧美中文| 岛国av在线网站| 精品香蕉视频| 欧美激情亚洲| 久久不见久久见中文字幕免费| 日韩激情一二三区| 亚洲1区在线观看| 亚洲欧洲美洲国产香蕉| 乱人伦精品视频在线观看| 亚州av乱码久久精品蜜桃| 精品免费av在线| 伊伊综合在线| 欧美精品日日操| 久久久蜜桃一区二区人| 日韩免费一区| 国产精品久久久久久久免费观看 | 亚洲精品高潮| 一区二区视频欧美| 91九色精品| 欧美高清不卡| 欧美日韩精品在线一区| 日韩精品中文字幕第1页| 日韩精品电影| 电影天堂国产精品| 欧美亚洲在线日韩| 亚洲二区视频| 久久福利精品| 日本不卡高清| 欧美日韩夜夜| 精品国产美女a久久9999| 国产suv精品一区| 日韩中文在线播放| 欧美 日韩 国产一区二区在线视频 | 日本视频一区二区| 91成人在线网站| 国产精品va视频| 国产成人精品一区二区三区免费| 精品淫伦v久久水蜜桃| 国产成人免费视频网站视频社区| 日韩电影免费在线观看| 婷婷综合五月| 亚洲精品护士| 毛片不卡一区二区| 国产v综合v| 午夜在线视频观看日韩17c| 在线精品视频一区| 久久国产三级| 麻豆理论在线观看| 精品一区三区| 日本精品另类| 国产suv精品一区| 欧美日韩在线二区| 亚洲美女91| 国产成人精品一区二区免费看京| 日韩欧美一区二区三区免费看| 一区久久精品| 国产剧情一区二区在线观看| 日韩深夜视频| 亚洲另类视频| 粉嫩av一区二区三区四区五区| av资源中文在线天堂| 婷婷综合五月| 国产精品一区二区三区www| 欧美aa在线视频| 91精品电影| 久久精品超碰| 久久中文亚洲字幕| 日韩国产精品久久久久久亚洲| 91中文字幕精品永久在线| 麻豆亚洲精品| 国产一区二区三区四区五区| 红桃视频亚洲| 美女在线视频一区| 亚洲国产成人精品女人| 国产精品中文字幕亚洲欧美| 久久精品国产亚洲夜色av网站 | 麻豆理论在线观看| 亚洲资源网站| av一区在线| 国产精品一区二区三区av| 日韩精品一区二区三区免费观影| 日本成人在线视频网站| 久久精品中文| 国产精品一区二区av交换| 婷婷丁香综合| 美女免费视频一区| 亚洲视频二区| 国产欧洲在线| 欧美日韩99| 国产精品日韩| 精品国模一区二区三区| 国产日韩在线观看视频| 亚洲大全视频| 国产一区二区视频在线看| 日韩精品一区二区三区中文| 国产一区观看| аⅴ资源天堂资源库在线| 青青草91久久久久久久久| 黄色av一区| 国产粉嫩在线观看| 国产亚洲字幕| 亚洲精品美女| 亚洲成人一区| 日韩在线综合| 久久精品国产成人一区二区三区| 亚洲va久久久噜噜噜久久| 九九久久婷婷| 午夜精品久久久久久久久久蜜桃| 麻豆一区二区99久久久久| 日韩国产在线不卡视频| 亚洲黄页一区| 色婷婷久久久| 欧美xxxx中国| 麻豆精品视频在线观看免费| 日韩激情综合| 最新亚洲国产| 石原莉奈在线亚洲二区| 99精品在线观看| 日韩国产专区| 97精品国产一区二区三区| 国产高清亚洲| 国产欧美日韩影院| 欧美一区精品| 欧美日韩一视频区二区| 日韩av影院| 欧美日韩调教| 国产香蕉精品| 欧美国产另类| 国产一区二区三区免费在线| 精品91福利视频|