react-native - 可能未处理的 Promise Rejection (id:0) TypeError: undefined is not an object (evalating 'ImagePicker.Permissions.askAsync)
问题描述
我正在使用 React-Native 和 Expo 构建一个 iOS 应用程序。我已经弄清楚如何访问用户的照片库,但无法从他们的设备请求权限。相反,它只是在不询问的情况下访问相机胶卷,这在 iOS 中显然是不允许的。下面是我的一些代码:
import React, {useState, useEffect, useRef} from 'react';
import * as ImagePicker from 'expo-image-picker';
import Permissions, {usePermissions} from 'expo-permissions';
import Constants from 'expo-constants'
//useEffect 函数是在检查异步函数是否已被接受时运行的函数
const Screen = ({navigation}) => {
const [ imagePicker1, setImagePicker1 ] = useState(null);
useEffect(() => {
const permission_get1 = async ()=> {
if (Platform.OS !== 'web'){
let { status } = await ImagePicker.Permissions.askAsync(Permissions.MEDIA_LIBRARY);
if (status !== 'granted'){
console.log('No permission given')
alert('Camera roll required for to upload photo from your library');
return;
}
/*if (status === 'granted'){
console.log('Permission granted')*/
let imagePicker1 = await ImagePicker.getMediaLibraryAsync()
setImagePicker1(imagePicker1)
console.log('It worked')
}
};
permission_get1();
}, []);
解决方案
我最终使用它来工作:我相信前面的示例使用了一种折旧的方法。
import * as ImagePicker from 'expo-image-picker'
const pickImage = async ()=>{
const { granted } = await Permissions.askAsync(Permissions.CAMERA_ROLL)
if(granted){
console.log('access granted')
let data = await ImagePicker.launchImageLibraryAsync({
mediaTypes:ImagePicker.MediaTypeOptions.Images,
allowsEditing: true,
aspect:[1,1],
quality:0.5,
})
console.log(data)
if (!data.cancelled){
setImage(data.uri);
}
}else{
Alert.alert('Permissions required to access camera roll.')
}
}
推荐阅读
- php - 如何使用 php 脚本将百万行插入 MySQL 数据库?
- list - 右手边也被分配
- ruby-on-rails - 使用回形针将图像上传到目录 - Ruby on rails
- python - 捕获 QApplication 中引发的异常
- java - 尝试通过 Odata 服务连接时 ErpConfigContext 和 ODataQueryBuilder 抛出错误
- pandas - 我希望 train_test_split 主要在一个特定的数字范围内进行训练
- python - 有没有一种并行的方法来比较两个大的整数列表?
- javascript - JavaScript 中的堆栈帧和执行上下文是否相同?
- routes - 角度 7 参数
- node.js - 如何在一台服务器上使用多个数据库连接到 AtlasDB 上的数据库中的集合