Taro⼩程序⽣成⼆维码保存本地步骤 ⽣成⼆维码 - 获取⼆维码的ba64 - 获取权限 - 获得地址 – 保存
import{ QRCode }from"taro-code";
const ref = uRef<any>();
<TView ref={ref}>
<QRCode
text='world'
size={200}
scale={4}
errorCorrectLevel='M'
typeNumber={2}
/>
</TView>
在外⾯加⼀层View 是为了获取taro-code⽣成的image 从⽽获得src 也就是ba64格式的⼆维码图⽚处理权限相关操作
import{
getSetting,
authorize,
saveImageToPhotosAlbum,
getFileSystemManager,
env,
}from"@tarojs/taro";
const handleSaveCode =uCallback(()=>{
getSetting({
success:function({ authSetting }){
//没有权限则申请
if(!authSetting["scope.writePhotosAlbum"]){
authorize({
scope:"scope.writePhotosAlbum",
success:()=>{
//存储⼆维码
handleWriteFile();
},
});
}el handleWriteFile();
},
});
},[]);
handleWriteFile
存储本地逻辑
const handleWriteFile =uCallback(()=>{
const{ src }= ref.current.childNodes[0].props;
const data = src.split(",")[1];
const filePath =`${env.USER_DATA_PATH}/${w()}.png`; const{ writeFile }=getFileSystemManager();
// 写⼊获得⽂件路径
writeFile({
data,
filePath,
encoding:"ba64",
success:()=>{
//存⼊相册
saveImageToPhotosAlbum({
filePath,
success:()=>{
console.log(" ");
},
});
},
fail:(err)=>{
<(err);
},
});
},[]);
完整代码 未必能直接⽤ 进攻参考
import{FC, ReactElement, uCallback, uRef, uState }from"react"; import{ View as TView }from"@tarojs/components";
import{
getSetting,
authorize,
saveImageToPhotosAlbum,
getFileSystemManager,
env,
}from"@tarojs/taro";
import{ Button, FlexView, View }from"../BUI";
import{ ICode }from"./types";
import Mask from"./Mask";
//@ts-nocheck
import{ QRCode }from"taro-code";
import"./feedQRCode.css";
import{ createCode }from"../../api/feedQRCodeAPI";
interface IProps {
code: ICode;
}
const GenerateQRCode:FC<IProps>=({ code }): ReactElement =>{ const[show, tShow]=uState(fal);
const[loading, tLoading]=uState(fal);
const ref = uRef<any>();
const handlePostCode =uCallback(()=>{
console.log(code);
tLoading(true);
createCode(code)
.then((res)=>{
console.log("res", res);
tLoading(fal);
})
.catch((err)=>{
console.log("err", err);
});
},[code]);
const handleGenerate =uCallback(()=>{
tShow(!show);
//发送请求
if(!show)handlePostCode();
},[handlePostCode, show]);
const handleWriteFile =uCallback(()=>{
const ba64 = ref.current.childNodes[0].props.src;
const data = ba64.split(",")[1];
const filePath =`${env.USER_DATA_PATH}/${w()}.png`; console.log(filePath);
const{ writeFile }=getFileSystemManager();
writeFile({
data,
filePath,
encoding:"ba64",
success:(res)=>{
console.log(res);
//
saveImageToPhotosAlbum({
filePath,
success:()=>{
console.log(" ");
},
});
},
fail:(err)=>{
<(err);
},
});
},[]);
const handleSaveCode =uCallback(()=>{
getSetting({
success:function({ authSetting }){
//没有权限则申请
if(!authSetting["scope.writePhotosAlbum"]){
authorize({
scope:"scope.writePhotosAlbum",
success:()=>{
/
/存储⼆维码
handleWriteFile();
},
});
}el handleWriteFile();
},
});
},[]);
return(
<View
className='container'
style={{ bottom: show ?0:"calc(46px - 50vh)"}}
>
<Button
width='100%'
onClick={handleGenerate}
letterSpacing='2px'
radius='0'
>
⽣成⼆维码
</Button>
<FlexView
column
width='100%'
alignItems='center'
justifyContent='space-evenly'
style={{
filter: loading ?"blur(10rpx)":undefined,
flex:1,
}}
>
<TView ref={ref}>
<QRCode
text='world'
size={200}
scale={4}
errorCorrectLevel='M'
typeNumber={2}
/>
</TView>
<FlexView width='100%'>
<Button onClick={handleSaveCode}>保存本地</Button>
<Button>查看页⾯</Button>
</FlexView>
</FlexView>
<Mask state={loading}/>
</View>
);
};
export default GenerateQRCode;