首頁 web前端 前端問答 nodejs實作漂流瓶

nodejs實作漂流瓶

May 13, 2023 pm 10:39 PM

Node.js實現漂流瓶

漂流瓶是一種極富浪漫情調的傳統玩意兒,它可以隨波逐流,飄向遠方。在數位化的時代裡,我們可以透過科技手段來模擬這種玩具。本文將介紹如何使用Node.js來實作一個簡單的漂流瓶應用。

第一步:建立基礎環境

首先,我們需要確保電腦上安裝了Node.js。安裝完成後,在命令列中輸入以下命令來偵測Node.js是否安裝成功:

node -v
登入後複製

如果成功安裝,輸出版本號即可。

接著,我們需要安裝一些必要的依賴函式庫,包括Express框架和MongoDB資料庫。在命令列中使用以下命令進行安裝:

npm install express mongodb --save
登入後複製

這裡使用了npm命令來安裝依賴庫,其中--save參數表示將依賴庫的名稱和版本號記錄在項目的package.json檔案中,方便團隊協作和程式碼維護。

第二步:實作後台邏輯

接下來,我們需要寫一些後台邏輯,包括路由和資料操作等。在專案的根目錄下新建一個app.js文件,在裡面輸入以下內容:

const express = require('express');
const mongodb = require('mongodb').MongoClient;

const app = express();
const port = process.env.PORT || 3000;
const dbUrl = 'mongodb://localhost:27017/bottle';

app.get('/', function(req, res) {
  res.send('Hello, world!');
});

app.listen(port, function() {
  console.log(`Server is listening on port ${port}`);
});
登入後複製

這段程式碼實現了一個最基礎的Express應用,監聽在3000連接埠上,同時連接到名為bottle的MongoDB資料庫。也定義了一個根路由/,回傳Hello, world!

接下來,我們需要實作三個路由:

  1. /throw :用來投放漂流瓶。
  2. /pick :用來尋找漂流瓶。
  3. /delete/:id :用於刪除漂流瓶。

先來看看如何實作第一個路由。在app.js檔案中加入以下程式碼:

app.get('/throw', function(req, res) {
  const user = req.query.user;
  const content = req.query.content;
  const bottle = {user: user, content: content};
  mongodb.connect(dbUrl, function(err, client) {
    if (err) {
      return console.log('Failed to connect to database');
    }
    const db = client.db('bottle');
    db.collection('bottles').insertOne(bottle, function(err, result) {
      if (err) {
        return console.log('Failed to insert bottle');
      }
      res.send('Throw bottle success');
      client.close();
    });
  });
});
登入後複製

這段程式碼用於投放漂流瓶,首先取得query參數中的使用者名稱和內容,然後拼裝成一個JSON物件。接著連接到MongoDB資料庫,並在bottles集合中插入該物件。如果插入成功,返回Throw bottle success

接下來,我們需要實作第二個路由。在app.js檔案中加入以下程式碼:

app.get('/pick', function(req, res) {
  const user = req.query.user;
  mongodb.connect(dbUrl, function(err, client) {
    if (err) {
      return console.log('Failed to connect to database');
    }
    const db = client.db('bottle');
    db.collection('bottles').findOne({user: user}, function(err, result) {
      if (err) {
        return console.log('Failed to find bottle');
      }
      if (!result) {
        return res.send('No bottle found');
      }
      const bottle = {user: result.user, content: result.content};
      db.collection('bottles').deleteOne({_id: result._id}, function(err, result) {
        if (err) {
          return console.log('Failed to delete bottle');
        }
        res.send(bottle);
        client.close();
      });
    });
  });
});
登入後複製

這段程式碼用於尋找漂流瓶。首先取得query參數中的使用者名,然後連接到MongoDB資料庫,在bottles集合中尋找使用者名稱相符的漂流瓶。如果找到了一個漂流瓶,將它從資料庫中刪除,並將結果傳回給客戶端。

最後,我們需要實作第三個路由。在app.js檔案中加入以下程式碼:

app.get('/delete/:id', function(req, res) {
  const id = req.params.id;
  mongodb.connect(dbUrl, function(err, client) {
    if (err) {
      return console.log('Failed to connect to database');
    }
    const db = client.db('bottle');
    db.collection('bottles').deleteOne({_id: mongodb.ObjectID(id)}, function(err, result) {
      if (err) {
        return console.log('Failed to delete bottle');
      }
      res.send('Delete bottle success');
      client.close();
    });
  });
});
登入後複製

這段程式碼用於刪除漂流瓶。首先取得路由參數中的漂流瓶ID,然後連接到MongoDB資料庫,在bottles集合中刪除該漂流瓶。如果刪除成功,返回Delete bottle success

第三個步驟:實作前端互動

現在,我們已經實作了一個完整的後台邏輯。接下來,我們需要實作一些前端互動。在專案的根目錄下新建一個public資料夾,並在裡面建立一個index.html文件,然後輸入以下程式碼:

<!DOCTYPE html>
<html>
<head>
  <title>Drifting Bottle</title>
  <meta charset="utf-8">
</head>
<body>
  <form id="throwForm">
    <input type="text" name="user" placeholder="Your name"><br>
    <textarea name="content" placeholder="Message"></textarea><br>
    <input type="submit" value="Throw">
  </form>
  <hr>
  <form id="pickForm">
    <input type="text" name="user" placeholder="Your name"><br>
    <input type="submit" value="Pick">
  </form>
  <hr>
  <ul id="bottleList"></ul>
  <script src="https://code.jquery.com/jquery-3.6.0.slim.min.js"></script>
  <script>
    $(function() {
      $('#throwForm').submit(function(event) {
        event.preventDefault();
        const form = $(this);
        $.get('/throw', form.serialize(), function(data) {
          alert(data);
        });
      });
      $('#pickForm').submit(function(event) {
        event.preventDefault();
        const form = $(this);
        $.get('/pick', form.serialize(), function(data) {
          if (typeof(data) === 'string') {
            alert(data);
          } else {
            $('#bottleList').append(`<li>${data.user}: ${data.content}</li>`);
          }
        });
      });
      $('#bottleList').on('click', 'li', function() {
        if (confirm('Are you sure to delete this bottle?')) {
          const id = $(this).attr('data-id');
          $.get(`/delete/${id}`, function(data) {
            alert(data);
            $(this).remove();
          }.bind(this));
        }
      });
    });
  </script>
</body>
</html>
登入後複製

這段程式碼實現了一個簡單的使用者介面,包括兩個表單和一個清單。其中,表單用於提交漂流瓶和尋找漂流瓶,清單用於顯示尋找到的漂流瓶。

接下來,在app.js檔案中加入以下程式碼,將靜態檔案目錄設定為public

app.use(express.static('public'));
登入後複製

最後,在指令行中輸入以下指令啟動應用:

node app.js
登入後複製

存取http://localhost:3000即可使用漂流瓶應用程式。

總結

本文介紹如何使用Node.js來實作一個漂流瓶應用。透過實現後台邏輯和前端交互,我們建立了一個基本上可用的漂流瓶系統。當然,這只是一個非常簡單的漂流瓶應用,還有很多需要完善和優化的地方,例如資料校驗、異常處理、安全性等等。但這應用程式足以展示Node.js在網路應用程式中的強大能力和優雅程式設計方式,希望本文能對想要學習Node.js的讀者有所幫助。

以上是nodejs實作漂流瓶的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

什麼是使用效果?您如何使用它執行副作用? 什麼是使用效果?您如何使用它執行副作用? Mar 19, 2025 pm 03:58 PM

什麼是使用效果?您如何使用它執行副作用?

解釋懶惰加載的概念。 解釋懶惰加載的概念。 Mar 13, 2025 pm 07:47 PM

解釋懶惰加載的概念。

JavaScript中的高階功能是什麼?如何使用它們來編寫更簡潔和可重複使用的代碼? JavaScript中的高階功能是什麼?如何使用它們來編寫更簡潔和可重複使用的代碼? Mar 18, 2025 pm 01:44 PM

JavaScript中的高階功能是什麼?如何使用它們來編寫更簡潔和可重複使用的代碼?

咖哩如何在JavaScript中起作用,其好處是什麼? 咖哩如何在JavaScript中起作用,其好處是什麼? Mar 18, 2025 pm 01:45 PM

咖哩如何在JavaScript中起作用,其好處是什麼?

什麼是Usecontext?您如何使用它在組件之間共享狀態? 什麼是Usecontext?您如何使用它在組件之間共享狀態? Mar 19, 2025 pm 03:59 PM

什麼是Usecontext?您如何使用它在組件之間共享狀態?

反應和解算法如何起作用? 反應和解算法如何起作用? Mar 18, 2025 pm 01:58 PM

反應和解算法如何起作用?

您如何防止事件處理程序中的默認行為? 您如何防止事件處理程序中的默認行為? Mar 19, 2025 pm 04:10 PM

您如何防止事件處理程序中的默認行為?

受控和不受控制的組件的優點和缺點是什麼? 受控和不受控制的組件的優點和缺點是什麼? Mar 19, 2025 pm 04:16 PM

受控和不受控制的組件的優點和缺點是什麼?

See all articles