Эй, кто-нибудь может сказать мне, почему я не рендеринг данных из API - PullRequest
0 голосов
/ 24 сентября 2019

я новичок в реакции, поэтому, пожалуйста, дайте мне решение для следующей проблемы

я создаю API, где пользователь может добавить изображение и выбрать радио BTN и отправлять данные в API получить данные об изображении, но в случае, если условиеОшибка отображения axios в cosole, т.е. axios не определена, так как я не могу отобразить данные из API, поэтому любой подскажет, где неправильный метод

import React, { Component } from 'react';
import axios from 'axios'

class Image extends Component {
    constructor(props) {
        super(props);
        this.state = { file: '', imagePreviewUrl: '' , change: [],  path:"false"};
    }

    handleSubmit(e) {
        e.preventDefault();
        // TODO: do something with -> this.state.file
        const byteCode = this.state.imagePreviewUrl
        var byteCode = this.state.imagePreviewUrl.substring(0, 30, e.target.value.indexOf(''));
        // substring used for remove "data:image/png;base64," from img src tag on line no 56 to pass base64 value to api
        debugger;

        var byteCode = this.state.imagePreviewUrl.substring((e.target.value).indexOf(',') + 23);
        console.log('base64 byte code substring data', byteCode);
        const valueRadio = this.state.selectedOption

        console.log(valueRadio)
        if (valueRadio == "celeb") {
            let url = "http://192.168.4.138/MediaAnalysisImage_Amazon/api/IdentifyCelebrity/IdentifyCelebrity"
            console.log(url);
            const data = { "isFilePath":this.state.path, "fileByte": byteCode}


            console.log(data)

            const response = axios.post(url, data)
                .then(response => {
                this.setState({
                    change: response.data
                });
            })
        }


    }
    celebData() {

        return (this.state.change).map((celebrity) => {
            const filebyte = celebrity.fileByte
            return (
                <div>
                    <p>{filebyte}</p>
                </div>
                )
        })
    }
    radioChange=(e)=> {
        this.setState({
            selectedOption: e.target.value

        });

    }
    handleImageChange(e) {
        e.preventDefault();

        let reader = new FileReader();
        let file = e.target.files[0];


        reader.onloadend = () => {
            this.setState({
                file: file,
                imagePreviewUrl: reader.result


            });

        }

        reader.readAsDataURL(file)

    }

    render() {
        let { imagePreviewUrl } = this.state;

        let $imagePreview = null;
        if (imagePreviewUrl) {
            $imagePreview = (<img src={imagePreviewUrl}   width="20%" />);
            console.log(imagePreviewUrl)
        } else {
            $imagePreview = (<span className="previewText">Please select an Image for Preview</span>);
        }

        return (
            <div className="previewComponent">
                <form onSubmit={(e) => this.handleSubmit(e)}>
                    <div class="form-check">
                        <label class="form-check-label">
                            <input type="radio" class="form-check-input" name="optradio" value="face" onChange={this.radioChange}/>Face
                         </label>
                    </div>
                    <div class="form-check">
                        <label class="form-check-label">
                            <input type="radio" class="form-check-input" name="optradio" value="celeb" onChange={this.radioChange} />Celeb
                         </label>
                    </div>
                    <div class="form-check">
                        <label class="form-check-label">
                            <input type="radio" class="form-check-input" name="optradio" value="text" onChange={this.radioChange} />Text
                         </label>
                    </div>
                    <div class="form-group">
                    <input className="fileInput"
                        type="file"
                            onChange={(e) => this.handleImageChange(e)} />
                        </div>
                    <button className="submitButton"
                        type="submit"
                        onClick={(e) => this.handleSubmit(e)}>Upload Image</button>
                </form>
                <div className="row">
                <div className="col-md-6">
                    <h2>Input Image</h2>
                    {$imagePreview}                
                </div>
                <div className="col-md-6">
                        <h2>Output Image</h2>

                    </div>
                </div>
                <div>
                    {this.celebData()}
                    <h4>Description :-</h4>
                </div>

        </div>
        )
    }
}
export default Image;

ниже приведен код package.json

{
  "name": "my-app",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "@material-ui/core": "^4.4.2",
    "antd": "^3.23.3",
    "axios": "^0.19.0",
    "bootstrap": "^4.3.1",
    "react": "^16.9.0",
    "react-bootstrap": "^1.0.0-beta.12",
    "react-dom": "^16.9.0",
    "react-js-pagination": "^3.0.2",
    "react-paginate": "^6.3.0",
    "react-router": "^5.0.1",
    "react-router-dom": "^5.0.1",
    "react-scripts": "3.1.1",
    "reactstrap": "^8.0.1"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject"
  },
  "eslintConfig": {
    "extends": "react-app"
  },
  "browserslist": {
    "production": [
      ">0.2%",
      "not dead",
      "not op_mini all"
    ],
    "development": [
      "last 1 chrome version",
      "last 1 firefox version",
      "last 1 safari version"
    ]
  }
}

и отображение оси не определено Ошибка в консоли Изображение ошибки Axios

1 Ответ

1 голос
/ 24 сентября 2019

Сначала вы можете установить этот пакет,

npm i axios --save

, а затем снова запустить приложение.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...