- 前端 (React + JavaScript)rjdxjy.com
React组件 (TodoList.js)
jsx
import React, { useState } from ‘react’;
function TodoList() {
const [todos, setTodos] = useState([]);
const [newTodo, setNewTodo] = useState(‘’);
const handleSubmit = (event) => {
event.preventDefault();
if (newTodo.trim() !== ‘’) {
setTodos([…todos, { id: Date.now(), text: newTodo, completed: false }]);
setNewTodo(‘’);
}
};
return (
<input
type=“text”
value={newTodo}
onChange={(e) => setNewTodo(e.target.value)}
placeholder=“Add a new todo”
/>
Add Todo
{todos.map((todo) => (
- {todo.text}
))}
);
}
export default TodoList;
2. 后端 (Node.js + Express)
服务器端代码 (server.js)
javascript
const express = require(‘express’);
const bodyParser = require(‘body-parser’);
const app = express();
const PORT = 3001;
app.use(bodyParser.json());
let todos = [];
app.get(‘/todos’, (req, res) => {
res.json(todos);
});
app.post(‘/todos’, (req, res) => {
const newTodo = {
id: Date.now(),
text: req.body.text,
completed: false
};
todos.push(newTodo);
res.status(201).json(newTodo);
});
app.listen(PORT, () => {
console.log(Server running on port ${PORT}
);
});
3. 数据库 (MongoDB 示例)
如果你决定使用MongoDB作为数据库,你需要使用Mongoose(一个ODM库)来管理你的数据模型。
MongoDB 模型 (Todo.js)
javascript
const mongoose = require(‘mongoose’);
const TodoSchema = new mongoose.Schema({
text: String,
completed: Boolean,
createdAt: { type: Date, default: Date.now }
});
const Todo = mongoose.model(‘Todo’, TodoSchema);
module.exports = Todo;
然后,在你的Express应用中,你需要连接到MongoDB并更新你的路由以使用Mongoose模型。
- 跨平台移动App (Flutter)
虽然Flutter主要关注于UI,但你也可以用它来调用后端API。
Flutter 示例 (简单界面)
dart
import ‘package:flutter/material.dart’;
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: Text(‘Todo List’),
),
body: Center(
child: Text(‘Todo List will go here’),
),
),
);
}
}
Flutter与后端服务的交互通常会通过HTTP请求(如使用dio或http库)进行。
结论
这里只是每个部分的非常基础的入门示例。在实际开发中,你会需要处理更多的边缘情况、错误处理、用户认证、数据验证等。此外,构建一个完整的App还涉及到状态管理(如Redux在React中)、路由管理(如React Router或Flutter的Navigator)以及可能的测试(单元测试、集成测试等)。创建一个完整的App涉及到前端(用户界面)、后端(数据处理)以及可能的数据库交互。由于篇幅限制,我将用几种流行的编程语言和技术栈简要概述如何开始构建一个简单的App。这里我们将以一个简单的待办事项列表App为例。
- 前端 (React + JavaScript)
React组件 (TodoList.js)
jsx
import React, { useState } from ‘react’;
function TodoList() {
const [todos, setTodos] = useState([]);
const [newTodo, setNewTodo] = useState(‘’);
const handleSubmit = (event) => {
event.preventDefault();
if (newTodo.trim() !== ‘’) {
setTodos([…todos, { id: Date.now(), text: newTodo, completed: false }]);
setNewTodo(‘’);
}
};
return (
<input
type=“text”
value={newTodo}
onChange={(e) => setNewTodo(e.target.value)}
placeholder=“Add a new todo”
/>
Add Todo
{todos.map((todo) => (
- {todo.text}
))}
);
}
export default TodoList;
2. 后端 (Node.js + Express)
服务器端代码 (server.js)
javascript
const express = require(‘express’);
const bodyParser = require(‘body-parser’);
const app = express();
const PORT = 3001;
app.use(bodyParser.json());
let todos = [];
app.get(‘/todos’, (req, res) => {
res.json(todos);
});
app.post(‘/todos’, (req, res) => {
const newTodo = {
id: Date.now(),
text: req.body.text,
completed: false
};
todos.push(newTodo);
res.status(201).json(newTodo);
});
app.listen(PORT, () => {
console.log(Server running on port ${PORT}
);
});
3. 数据库 (MongoDB 示例)
如果你决定使用MongoDB作为数据库,你需要使用Mongoose(一个ODM库)来管理你的数据模型。
MongoDB 模型 (Todo.js)
javascript
const mongoose = require(‘mongoose’);
const TodoSchema = new mongoose.Schema({
text: String,
completed: Boolean,
createdAt: { type: Date, default: Date.now }
});
const Todo = mongoose.model(‘Todo’, TodoSchema);
module.exports = Todo;
然后,在你的Express应用中,你需要连接到MongoDB并更新你的路由以使用Mongoose模型。
- 跨平台移动App (Flutter)
虽然Flutter主要关注于UI,但你也可以用它来调用后端API。
Flutter 示例 (简单界面)
dart
import ‘package:flutter/material.dart’;
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: Text(‘Todo List’),
),
body: Center(
child: Text(‘Todo List will go here’),
),
),
);
}
}
Flutter与后端服务的交互通常会通过HTTP请求(如使用dio或http库)进行。
结论
这里只是每个部分的非常基础的入门示例。在实际开发中,你会需要处理更多的边缘情况、错误处理、用户认证、数据验证等。此外,构建一个完整的App还涉及到状态管理(如Redux在React中)、路由管理(如React Router或Flutter的Navigator)以及可能的测试(单元测试、集成测试等)。