Импорт Express при попытке подключить интерфейс (React) и фон (Node.js) - PullRequest
1 голос
/ 27 сентября 2019

Я действительно новичок в js и пытаюсь создать полноценное веб-приложение.Я построил большую часть внешнего кода React, и мой внутренний файл имеет соединение и запрос к БД.Я пытаюсь соединить оба этих файла вместе, но как только я пытаюсь импортировать «экспресс» в любой из файлов, происходит сбой.Без импорта экспресс работает нормально.Выдает мне эту ошибку в браузере, когда он запускается: "Ошибка типа: невозможно получить свойство 'prototype' с неопределенной или нулевой ссылкой" Index.js (при попытке импортировать Express здесь)

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import * as serviceWorker from './serviceWorker';

// import './index.css';
// var express = require('express')
// var app = express()
var Connection = require('tedious').Connection;
var Request = require('tedious').Request;
// const axios = require('axios')


ReactDOM.render(<App />, document.getElementById('root'));

// If you want your app to work offline and load faster, you can change
// unregister() to register() below. Note this comes with some pitfalls.
// Learn more about service workers: 
serviceWorker.unregister();

App.js (интерфейс)

import React from 'react';
import TextField from '@material-ui/core/TextField';
import Button from '@material-ui/core/Button';
import Box from '@material-ui/core/Box';
import { createMuiTheme } from '@material-ui/core/styles';
import { ThemeProvider } from '@material-ui/styles';
import { Typography } from '@material-ui/core';

// var express = require('express')
// var app = express()

//change the primary colours of the UI 
const theme = createMuiTheme({
  palette: {

    primary: {

      main: '#00a843',
      background: 'linear-gradient(45deg, #FE6B8B 30%, #FF8E53 90%)',
    },

    },
  }); 



export default class App extends React.Component
{
  constructor(props) {
    super(props);
    this.handleEnterClick = this.handleEnterClick.bind(this);
    this.handleSaveClick = this.handleSaveClick.bind(this);
    this.state = {showAll: false, inputEmail: "", successfullySaved: true, newList: ""};
  }

  async handleEnterClick() {
    //send the entered email to the server

//   var xhr = new XMLHttpRequest()
    // get a callback when the server responds
//   xhr.addEventListener('load', () => {
      // update the state of the component with the result here
//     console.log(xhr.responseText)
//   })
    // open the request with the verb and the url
//   xhr.open('PUT', '/api/controllers/AppController/enter')
    // send the request
//    xhr.send(JSON.stringify({ yourEmail: this.state.inputEmail }))
/*
    const response = await fetch('/api/controllers/AppController/enter', {
      method: 'PUT',
      body: JSON.stringify({ email: this.state.inputEmail }),
    })
    console.log(await response.json())
*/
    //update the UI to reflect the button being pressed
    this.setState({showAll: true});
  }

  handleSaveClick() {
    //save to the datbase
    var xhr = new XMLHttpRequest()
    // get a callback when the server responds
    xhr.addEventListener('load', () => {
      // update the state of the component with the result here
      console.log(xhr.responseText)
    })
    // open the request with the verb and the url
    xhr.open('PUT', '/api/controllers/AppController/save')
    // send the request
    xhr.send(JSON.stringify({ newList: this.state.newList }))


    //update the UI to reflect the save
    this.setState({showAll: false, inputEmail: "", successfullySaved: true, newList: ""});
    //add a successful save message
  }


  render () {
    return (
      <form display="flex" noValidate autoComplete="off">
      <ThemeProvider theme={theme}>
      <div align = 'center'>

        <TextField 
          id="tfInputEmail"
          value={this.state.inputEmail}
          onKeyPress={(ev) => {
            if (ev.key === 'Enter') {
              this.setState({showAll: true});
               ev.preventDefault();
            }
          }}

          onChange={e => this.setState({ inputEmail: e.target.value })}
          style={{ width: 600}}
          placeholder="first_last"

          autoComplete = "email" 
          InputLabelProps={{
            shrink: true,
            style: {fontSize: 17, fontFamily: "Helvetica"}
          }}
          inputProps={{
            style: {fontFamily: "Helvetica"}
          }}

          variant="outlined"
        />
        <br/>

        <Button id="btnEnter" variant="contained" color="primary"
        style={{ marginTop: 15, marginBottom: 35, width: 600, height: 35}} onClick={this.handleEnterClick}>
          Enter
        </Button>

        <PressedEnter show={this.state.showAll} click={this.handleSaveClick} list={this.state.newList}/>
      </div>
      </ThemeProvider>
    </form>
    );
  }

}

function PressedEnter(props)
{ 
  if(!props.show) {
    return null;
  }

  return (
    <div >

        <Box fontSize={18} fontFamily="Helvetica"  marginLeft="9px" 
          marginBottom="20px" marginTop="30px">
          Check spelling and formatting before clicking 'Update your list' below. There's no error checking at the moment.
        </Box>
        <div width="100%" horizontal layout > 
        {
          // REPLACE THE ABOVE DIV WITH A GRID LAYOUT FROM MATERIAL UI 
        }

          {// Vertical layout for the textbox and its label 
          }
          <div> 
            <Box fontSize={16} fontFamily="Helvetica" 
              marginBottom="10px" marginTop="20px">
              Add/change/delete emails and separate by semicolon (;) here:
            </Box>


            <TextField
              id="tfChangeList"

              multiline
              style={{ margin: 8, width: 446}}
              InputLabelProps={{
                shrink: true,
                style: {fontSize: 20, fontFamily: "Helvetica"}
              }}
              inputProps={{
                style: {height:300, fontFamily: "Helvetica"}
              }}
              variant="outlined"
            />
          </div>


          {// Vertical layout for the textbox and its label 
          }
          <div>
            <Box fontSize={16} fontFamily="Helvetica" 
                marginBottom="10px" marginTop="20px">
                View your current Pulse Check list here:
            </Box>

            <TextField
              disabled
              id="tfCurrentList"
              multiline 
              style={{ margin: 8, width: 446}}
              InputLabelProps={{
                shrink: true,
                style: {fontSize: 20, fontFamily: "Helvetica"}
              }}
              inputProps={{
                style: {height:300, fontFamily: "Helvetica"}
              }}
              variant="outlined"
            />
          </div>

        </div>
        <br/>
        <Button id="btnSave" variant="contained" color="primary" style={{ marginLeft: 8, marginBottom: 8, 
          marginTop: -8}} onClick={props.click}>
          Save your Updates!
        </Button>
    </div>
  );
}
  );
}





1 Ответ

0 голосов
/ 27 сентября 2019

Ваше полнофункциональное веб-приложение должно запускать как клиент, так и сервер по отдельности - т.е. запустить приложение Express на localhost: 3000 (серверная часть) и отправлять ему HTTP-запросы от вашего клиента (React), работающего на отдельном сервере веб-пакетов.(внешний интерфейс).

Поскольку приложение является "полным стеком", это не означает, что передний и задний интерфейсы объединены.Это отдельные.Надеюсь, это поможет.

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