POST JSON jako obiekt

Odpowiedz Nowy wątek
2019-02-15 15:06
0

Witam,
mam problem z wysłaniem JSONA jako obiektu. Nie pobiera mi danych z inputa tylko wysła nulla. Próbowałem już na wiele sposobów i żaden z nich nie przynosi rezultatu. Zostawiłem teraz pustego JSON.stringify. Czy ktoś mógłby mi pomóc?

class Create extends Component {        

      constructor() {
        super();
        this.state = {
          ProductId: '',
          FactoryId: '',
          Name: '',
          Description: '',
          Category: '',
          Availability: ''
        };
      }

      onChange = (e) => {
        const state = this.state
        state[e.target.name] = e.target.value ;
        this.setState(state);
      }

      post = () => {
          fetch('/api/Products',
              {
                  method: 'post',
                  headers: {
                      'Accept': 'application/json',
                      'Content-Type': 'application/json'
                  },
                  body: JSON.stringify() 
              });
      };        

      render() {
        const { ProductId, FactoryId, Name, Description, Category, Availability } = this.state;
        return (
          <div class="container">
            <div class="panel panel-default">
              <div class="panel-heading">
                <h3 class="panel-title">
                  ADD PRODUCT
                </h3>
              </div>
              <div class="panel-body">
                <h4><Link to="/fetch"><span class="glyphicon glyphicon-th-list" aria-hidden="true"></span> Products List</Link></h4>
                        <form onSubmit={this.post} name="form">
                  <div class="form-group">
                  <label for="isbn">FactoryId:</label>
                  <input type="text" class="form-control" name="FactoryId" value={FactoryId} onChange={this.onChange} placeholder="FactoryId" required/>
                  </div>                 
                  <button type="submit" class="btn btn-default">Submit</button>
                </form>
              </div>
            </div>
          </div>
        );
      }
    }

Pozostało 580 znaków

2019-02-15 15:27
0

Powinieneś wołać JSON.stringify(parametrKtoryChceszZamienicNaJsona), nie samo JSON.stringify() (https://developer.mozilla.org[...]Global_Objects/JSON/stringify).


edytowany 1x, ostatnio: Patryk27, 2019-02-15 15:27

Pozostało 580 znaków

2019-02-15 15:35
0

No tak, tylko że jak ustawie np. JSON.stringify({FactoryId:''})
To wysyła do bazy null, logiczne. Potrzebuje zrobić zeby wartości wpisane w inpucie zostały wysłane.

edytowany 1x, ostatnio: Nakanoshinbashi, 2019-02-15 15:36

Pozostało 580 znaków

2019-02-15 15:42
0

Em... JSON.stringify(this.state)?


Pozostało 580 znaków

2019-02-15 15:50
0

Próbowałem naprawdę wiele. Tak też nie działa.

Pokaż jak próbowałeś. - Patryk27 2019-02-15 15:52

Pozostało 580 znaków

Odpowiedz
Liczba odpowiedzi na stronę

1 użytkowników online, w tym zalogowanych: 0, gości: 1, botów: 0