我为分配编写了简单的代码。我推荐文档和几个YouTube视频教程系列。我的反应代码是正确的我在运行代码时没有遇到任何错误。但这些react-boostrap元素无法渲染。此代码仅返回html输出。请看一下这段代码并帮我解决这个问题。
import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import registerServiceWorker from './registerServiceWorker';
import { BrowserRouter as Router, Route } from 'react-router-dom';
import Login from './components/Login';
import Test from './text';
ReactDOM.render(
<Router>
<div>
<div>
<App/>
</div>
</div>
</Router>, document.getElementById('root'));
registerServiceWorker();
&#13;
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<meta name="theme-color" content="#000000">
<link rel="manifest" href="%PUBLIC_URL%/manifest.json">
<link rel="shortcut icon" href="%PUBLIC_URL%/favicon.ico">
<!-- Latest compiled and minified CSS -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
<!-- Optional theme -->
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous">
<title>React App</title>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>
<noscript>
You need to enable JavaScript to run this app.
</noscript>
<div id="root"></div>
</body>
</html>
&#13;
这些是index.html&amp; index.js页面。我认为这些足以发现问题。我会发布主管以及更多信息。
import React, { Component } from 'react';
import { Switch, Route } from 'react-router-dom'
import Logo from '../images/logo.png';
import Dashboard from './Dashboard';
import AdminList from './AdminList';
import ClientList from './ClientList';
import ServiceList from './ServiceList';
import AdminView from './AdminView';
import ClientView from './ClientView';
import ServiceView from './ServiceView';
import AdminNew from './AdminNew';
import ClientNew from './ClientNew';
import ServiceNew from './ServiceNew';
import Category from './Category';
import CategoryNew from './CategoryNew';
import Login from './Login';
import App from '../App';
const Main = () => (
<main>
<Switch>
<Route exact path='/' component={Dashboard} />
<Route exact path='/login' component={Login}/>
<Route path='/Category'
render={({ match: { url } }) => (
<div>
<Route exact path={`${url}/`} component={Category} />
<Route path={`${url}/new`} component={CategoryNew} />
</div>
)} />
<Route path='/Client'
render={({ match: { url } }) => (
<div>
<Route exact path={`${url}/`} component={ClientList} />
<Route path={`${url}/new`} component={ClientNew} />
<Route path={`${url}/view`} component={ClientView} />
</div>
)} />
<Route path='/Service'
render={({ match: { url } }) => (
<div>
<Route exact path={`${url}/`} component={ServiceList} />
<Route path={`${url}/new`} component={ServiceNew} />
<Route path={`${url}/view`} component={ServiceView} />
</div>
)} />
<Route path='/Admin'
render={({ match: { url } }) => (
<div>
<Route exact path={`${url}/`} component={AdminList} />
<Route path={`${url}/new`} component={AdminNew} />
<Route path={`${url}/view`} component={AdminView} />
</div>
)} />
</Switch>
</main>
)
export default Main;
&#13;
Main.js
import React, { Component } from 'react';
import axios from 'axios';
class ServiceNew extends Component {
constructor(){
super();
this.state={
Name:'',
NIC:'',
Email:'',
Password:'',
Contact:'',
District:'',
Category:'',
}
this.handleNameChange=this.handleNameChange.bind(this)
this.handleNICChange=this.handleNICChange.bind(this)
this.handleEmailChange=this.handleEmailChange.bind(this)
this.handlePwdChange=this.handlePwdChange.bind(this)
this.handlePhoneChange=this.handlePhoneChange.bind(this)
this.handleDistrictChange=this.handleDistrictChange.bind(this)
this.handleCategoryChange=this.handleCategoryChange.bind(this)
this.handleClick=this.handleClick.bind(this)
}
handleNameChange(e){
this.setState({
Name:e.target.value
})
console.log(this.state.Name)
}
handleNICChange(e){
this.setState({
NIC:e.target.value
})
console.log(this.state.NIC)
}
handleEmailChange(e){
this.setState({
Email:e.target.value
})
console.log(this.state.Email)
}
handlePwdChange(e){
this.setState({
Password:e.target.value
})
console.log(this.state.Password)
}
handlePhoneChange(e){
this.setState({
Contact:e.target.value
})
console.log(this.state.Contact)
}
handleDistrictChange(e){
this.setState({
District:e.target.value
})
console.log(this.state.District)
}
handleCategoryChange(e){
this.setState({
Category:e.target.value
})
console.log(this.state.Category)
}
handleClick = event =>{
event.preventDefault();
axios.post('http://localhost:4000/api/serviceproviders-insert',{
name:this.state.Name,
_id:this.state.NIC,
email:this.state.Email,
password:this.state.Password,
contact:this.state.Contact,
district:this.state.District,
category:this.state.Category,
})
.then(res =>{
alert("Successfully Registered");
console.log(res);
console.log(res.data)
this.setState={
Name:'',
NIC:'',
Email:'',
Password:'',
Contact:'',
District:'',
Category:'',
}
})
.catch(err=>{
console.log(err)
})
}
render() {
return (
<div>
<div>
<div class="well">
<a href="#" class="list-group-item list-group-item-danger"><h4><b>Add New</b></h4></a>
</div>
<form>
<div class="form-group">
<label for="name">Name:</label>
<input type="name" class="form-control" value={this.state.Name} id="name" placeholder="Enter name" name="name" onChange={this.handleNameChange}/>
</div>
<div class="form-group">
<label for="nic">NIC:</label>
<input type="nic" class="form-control" value={this.state.NIC} id="nic" placeholder="Enter NIC" name="nic" onChange={this.handleNICChange}/>
</div>
<div class="form-group">
<label for="email">Email:</label>
<input type="email" class="form-control" value={this.state.Email} id="email" placeholder="Enter email" name="email"onChange={this.handleEmailChange} />
</div>
<div class="form-group">
<label for="pwd">Password:</label>
<input type="password" class="form-control"value={this.state.Password} id="pwd" placeholder="Enter password" name="pwd" onChange={this.handlePwdChange} />
</div>
<div class="form-group">
<label for="phone">Contact No:</label>
<input type="phone" class="form-control" value={this.state.Contact} id="phone" placeholder="Enter contact number" name="phone" onChange={this.handlePhoneChange} />
</div>
<div class="form-group">
<label for="dis">District:</label>
<input type="dis" class="form-control" value={this.state.District} id="dis" placeholder="Enter district" name="dis" onChange={this.handleDistrictChange} />
</div>
<div class="form-group">
<label for="cat">Working Category:</label>
<input type="cat" class="form-control" value={this.state.Category} id="cat" placeholder="Enter working category" name="cat" onChange={this.handleCategoryChange}/>
</div>
<button type="button" onClick={this.handleClick} class="btn btn-primary">Add New</button>
</form>
</div>
</div>
);
}
}
export default ServiceNew;
&#13;
ServiceNew.js
这件事是我朋友写的。他告诉我这些代码完全在他的电脑上运行,没有任何问题。
答案 0 :(得分:0)
您必须在React中使用className
而不是class
。
<div className="form-group">
...
</div>