思路:a标签的download属性的使用
window.URL.createObjectURL()生成DOMString的使用,参考文献:https://developer.mozilla.org/zh-CN/docs/Web/API/URL/createObjectURL
文本类本地下载(和服务端无交互)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<!-- <img class="grayscale" src="myPicture.png" alt="Description of my picture" /> -->
</head>
<body>
<script>
var file = new File(["i'm very happy beacuse i hava learn how to use js "], "footxt", {type: "text/plain",});
var blob = new Blob(['ni hao '], { 'type': 'text\/xml' });
vetruLabel("a","exported.txt", blob);
function vetruLabel(lableName,FileName,fileContent){
var a = document.createElement(lableName);
//URL.createObjectURL() 静态方法会创建一个 DOMString,DOMString 是一个UTF-16字符串。由于JavaScript已经使用了这样的字符串,
//所以DOMString 直接映射到 一个String 链接地址:https://developer.mozilla.org/zh-CN/docs/Web/API/URL/createObjectURL
a.href = window.URL.createObjectURL(fileContent);
a.innerText = '下载';
document.body.appendChild(a)
a.download = FileName;
}
</script>
</body>
</html>
图片类本地下载(和服务端无交互)
适用于服务端返回的是dataUrl格式的数据
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
function vetruLabel(lableName, FileName, fileContent) {
var a = document.createElement(lableName);
//URL.createObjectURL() 静态方法会创建一个 DOMString,DOMString 是一个UTF-16字符串。由于JavaScript已经使用了这样的字符串,
//所以DOMString 直接映射到 一个String 链接地址:https://developer.mozilla.org/zh-CN/docs/Web/API/URL/createObjectURL
a.href = window.URL.createObjectURL(fileContent);
a.innerText = '下载';
document.body.appendChild(a)
a.download = FileName;
}
/**
*
* dataUrl转Bolb
* */
function dataURLtoBlob(dataurl) {
var 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 });
}
var blob = dataURLtoBlob('');
vetruLabel("a", "exported.png", blob);
</script>
</body>
</html>
服务端交互需要的操作
上传数据
网络图像文件转Base64字符串
/**
*img 为dom元素
**/
function getBase64Image(img) {
var canvas = document.createElement("canvas");
canvas.width = img.width;
canvas.height = img.height;
var ctx = canvas.getContext("2d");
ctx.drawImage(img, 0, 0, img.width, img.height);
//获取图片的格式(png jpg)
var ext = img.src.substring(img.src.lastIndexOf(".") + 1).toLowerCase();
var dataURL = canvas.toDataURL("image/" + ext);
return dataURL;
}
Base64字符串转二进制
/**
*dataurl 为base64字符串
**/
function dataURLtoBlob(dataurl) {
var 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);
}
console.log(new Blob([u8arr], {
type: mime
}))
return new Blob([u8arr], {
type: mime
});
}
下载并显示
base64设置到img标签显示
document.getElementById('img').setAttribute('src', ' DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==');
JS字符串和二进制相互转换
string —> binary array
方法一
var str = 'test string.';
var arr = Array.prototype.map.call( str , function( c ) { return c.charCodeAt(0); } );
方式二
const encoder = new TextEncoder()
const view = encoder.encode('taowuhua,真帅')
binary array —> string
String.fromCharCode.apply( null , arr );
数组转为字符串
方式一
String(arr).replace(/,/g, "")
方式二
arr.join("")
对象转字符串
var obi = {'name':'taowuhua'}
console.log(JSON.stringify(obi))
判断数组中是否存在某个值
如果存在返回数组元素的下标,否则返回-1
let arr = ['apple', 'banana', 'fruit', 'origin'];
let index = arr.indexOf('apple');