JavaScript常用工具函數(shù)匯總(瀏覽器環(huán)境)
前端業(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'
// 是否ipad
export const isIpad = () => ua.indexOf('ipad') > -1
// 是否iphone
export const isIphone = () => ua.indexOf('iphone os') > -1
// 是否uc
export const isUc = () => ua.indexOf('ucweb') > -1
// 是否windows pc
export const isWindows = () => ua.indexOf('windows') > -1
// 是否android
export const isAndroid = () => ua.indexOf('android') > -1 || ua.indexOf('adr') > -1
// 是否ios
export 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
八、開(kāi)啟與關(guān)閉全屏
// 開(kāi)啟全屏
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)畫(huà)
/**
* @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)畫(huà)時(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)畫(huà)過(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)注腳本之家其它相關(guān)文章!
相關(guān)文章
javascript replace()用法詳解附實(shí)例代碼
在javascript中,String的函數(shù)replace()簡(jiǎn)直太讓人喜愛(ài)了。它靈活而強(qiáng)大的字符替換處理能力,讓我不禁想向大家介紹它。2008-10-10
JS 用6N±1法求素?cái)?shù) 實(shí)例教程
顯然,當(dāng)N≥1時(shí),6N,6N+2,6N+3,6N+4都不是素?cái)?shù),只有形如6N+1和6N+5的自然數(shù)有可能是素?cái)?shù)。所以,除了2和3之外,所有的素?cái)?shù)都可以表示成6N±1的形式(N為自然數(shù))。2009-10-10
Cropper.js進(jìn)階之裁剪后保存至本地實(shí)現(xiàn)示例
這篇文章主要為大家介紹了Cropper.js進(jìn)階之裁剪后保存至本地實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
js+css實(shí)現(xiàn)文字散開(kāi)重組動(dòng)畫(huà)特效代碼分享
這篇文章主要介紹了js+css實(shí)現(xiàn)文字散開(kāi)重組動(dòng)畫(huà)特效,需要的朋友可以參考下2015-08-08
只需五句話搞定JavaScript作用域(經(jīng)典)
javascript作用域是前端開(kāi)發(fā)比較難理解的知識(shí)點(diǎn),下面小編給大家提供五句話幫助大家很快的了解js作用域,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧2016-07-07

