react-native 上传图片小结

2021-02-08  本文已影响0人  朱传武

安装第三方库:

react-native-image-picker

获取图片方法:

export const selectPicture = (coptions) =>
  new Promise((resolve) => {
    const options = {
      title: 'Select Image',
      quality: 0.1,
      maxWidth: 600,
      maxHeight: 600,
      durationLimit: 10,
      storageOptions: {
        skipBackup: true,
        path: 'images',
      },
    };
    ImagePicker.showImagePicker(coptions ? coptions : options, (response) => {
      console.log('Response = ', response);
      if (response.didCancel) {
        failToast('User cancelled image picker');
        console.log();
      } else if (response.error) {
        failToast('ImagePicker Error: ' + response.error);
        console.log('ImagePicker Error: ', response.error);
      } else if (response.customButton) {
        console.log('User tapped custom button: ', response.customButton);
      } else {
        const source = response;
        resolve(source);
      }
    });
  });

dva里面直接调用获取图片对象:

*selectImage({ payload: {} }, { call, put, select }) {
      const source = yield call(selectPicture);
      loadingToast();
      yield put({ type: 'setImages', payload: source });
      const { data } = yield call(pictureUpload, source);

      yield put({ type: 'setFileRes', payload: data });
      hideToast();
    },

上传:

export async function pictureUpload(imageSource) {
  const formDataParam = {
    uri: imageSource.uri,
    type: 'image/jpeg',
    name: 'photo.jpg',
  };
  return postForm(
    '/api/upload/headimg',
    { file: formDataParam },
    {
      hiddenLoading: true,
    }
  );
}

注意,file参数应该是个对象包含 uri、type、name

上一篇 下一篇

猜你喜欢

热点阅读