RefrenceError:在本机反应中找不到变量

时间:2020-07-11 02:38:48

标签: reactjs react-native react-native-android react-native-camera react-native-video

我试图访问我在RNCamera Roll应用程序上创建的自定义文件夹中的所有文件,以使用它创建图库。在我的代码中,我相信我指定了变量“ videos”,但仍收到参考错误:“找不到可变视频”,我该怎么解决,如何才能消除该错误。 ...这是我的代码...

我在this.state中添加了构造函数,但仍然收到相同的错误

constructor() {
    super();
    this.state = {
        modalVisible: false,
        videos: [],
        index: null
    }
  }


    getPhotos = () => {
        CameraRoll.getPhotos({
            first: 20,
            groupTypes: 'Album',
            groupName: 'Custom VideoFolder',
            assetType: 'Videos'
        })
        .then(r => this.setState({ videos: r.edges}))
        .then((statResult) => {
        let videos = []
        var allowedExtensions = /(\.avi|\.mp4|\.mov|\.wmv|\.avi)$/i;
        statResult.forEach(item => {
        if (item.isFile() && !allowedExtensions.exec(item.originalFilepath)) {
        videos.push(item)
        }
        });
        console.log(videos)
        })
    }

    toggleModal = () => {
      this.setState({ modalVisible: !this.state.modalVisible})
  }


  share = () => {
    const vocvideo = this.state.videos[this.state.index].node.video.uri
    RNFetchBlob.fs.readFile(vocvideo, 'uri')
    .then((data) => {
      let shareOptions = {
        title: "React Native Share Example",
        message: "Check out this video!",
        url: `data:video/mp4;uri,${data}`,
        subject: "Check out this video!"
      };

      Share.open(shareOptions)
        .then((res) => console.log('res:', res))
        .catch(err => console.log('err', err))
    })
  }

      render() {
        console.log('state :', this.state)
        return (
          <View style={styles.container}>
            <Button
              title='View videos'
              onPress={() => { this.toggleModal(); this.getPhotos() }}
            />
            <Modal
              animationType={"slide"}
              transparent={false}
              visible={this.state.modalVisible}
              onRequestClose={() => console.log('closed')}
            >
              <View style={styles.modalContainer}>
                <Button
                  title='Close'
                  onPress={this.toggleModal}
                />
                <ScrollView
                  contentContainerStyle={styles.scrollView}>
                  {
                    this.state.videos.map((p, i) => {
                      const isSelected = i === this.state.index;
                      const divide = isSelected && this.share === true ? 1 : 3;
                      return (
                        <Video
                          style={{opacity: i === this.state.index ? 0.5 : 1, width: width/divide, height: width/divide}}
                          key={i}
                          underlayColor='transparent'
                          onPress={() => this.setIndex(i)}
                          source={{uri: video}}
                        />
                        
                      )
                    })
                  }
                </ScrollView>

0 个答案:

没有答案