Node.js, MongoDB, Sassでサクッと! Sails.js アプリケーション開発のススメ

2024-07-27

Node.js、MongoDB、Sass を用いた Sails.js スケルトン作成ガイド

前提知識

  • コマンドライン ツールの基本的な知識
  • Sass の基本的な知識
  • MongoDB の基本的な知識
  • Node.js の基本的な知識

手順

  1. プロジェクトのセットアップ

    1. 新しいディレクトリを作成し、そのディレクトリをプロジェクトのルートディレクトリにします。
    2. コマンドを実行して、Sails.js プロジェクトを初期化します。
npm init sails my-sails-app
  1. プロジェクトディレクトリに移動します。
cd my-sails-app
module.exports = {

  // ...

  datastores: {
    default: {
      adapter: 'sails-mongo',
      url: 'mongodb://localhost:27017/my-sails-app'
    }
  }

  // ...

};
{
  "scripts": {
    "develop": "sails lift",
    "watch": "node-sass assets/styles/*.scss assets/styles.css -o assets/styles.css",
    "start": "npm run watch && sails lift"
  }
}
module.exports = {

  tableName: 'users',

  attributes: {
    name: {
      type: 'string',
      required: true
    },
    email: {
      type: 'email',
      unique: true,
      required: true
    },
    password: {
      type: 'string',
      required: true
    }
  }

};

5. コントローラーの作成

  1. api/controllers ディレクトリにコントローラーファイルを作成します。
  2. コントローラーアクションを定義します。
module.exports = {

  create: function (req, res) {
    User.create({
      name: req.param('name'),
      email: req.param('email'),
      password: req.param('password')
    })
      .then(function (user) {
        res.json(user);
      })
      .catch(function (err) {
        res.status(500).json(err);
      });
  }

};
<!DOCTYPE html>
<html lang="ja">
<head>
  <meta charset="UTF-8">
  <title>My Sails App</title>
  <link rel="stylesheet" href="/styles.css">
</head>
<body>
  <h1>ユーザー登録</h1>

  <form action="/user" method="post">
    <label for="name">名前:</label>
    <input type="text" id="name" name="name" required>

    <label for="email">メールアドレス:</label>
    <input type="email" id="email" name="email" required>

    <label for="password">パスワード:</label>
    <input type="password" id="password" name="password" required>

    <button type="submit">登録</button>
  </form>
</body>
</html>
npm run start
npm test



package.json

{
  "name": "my-sails-app",
  "version": "1.0.0",
  "description": "My Sails.js app",
  "main": "app.js",
  "scripts": {
    "develop": "sails lift",
    "watch": "node-sass assets/styles/*.scss assets/styles.css -o assets/styles.css",
    "start": "npm run watch && sails lift",
    "test": "mocha test/api/**/*.spec.js"
  },
  "dependencies": {
    "sails": "^1.5.0",
    "sails-mongo": "^0.16.0",
    "node-sass": "^4.14.1"
  },
  "devDependencies": {
    "chai": "^4.3.4",
    "mocha": "^8.2.2"
  }
}

config/local.js

module.exports = {

  // ...

  datastores: {
    default: {
      adapter: 'sails-mongo',
      url: 'mongodb://localhost:27017/my-sails-app'
    }
  }

  // ...

};

assets/styles/main.scss

body {
  font-family: sans-serif;
}

api/models/User.js

module.exports = {

  tableName: 'users',

  attributes: {
    name: {
      type: 'string',
      required: true
    },
    email: {
      type: 'email',
      unique: true,
      required: true
    },
    password: {
      type: 'string',
      required: true
    }
  }

};

api/controllers/UserController.js

module.exports = {

  create: function (req, res) {
    User.create({
      name: req.param('name'),
      email: req.param('email'),
      password: req.param('password')
    })
      .then(function (user) {
        res.json(user);
      })
      .catch(function (err) {
        res.status(500).json(err);
      });
  }

};

views/user/create.ejs

<!DOCTYPE html>
<html lang="ja">
<head>
  <meta charset="UTF-8">
  <title>ユーザー登録</title>
  <link rel="stylesheet" href="/styles.css">
</head>
<body>
  <h1>ユーザー登録</h1>

  <form action="/user" method="post">
    <label for="name">名前:</label>
    <input type="text" id="name" name="name" required>

    <label for="email">メールアドレス:</label>
    <input type="email" id="email" name="email" required>

    <label for="password">パスワード:</label>
    <input type="password" id="password" name="password" required>

    <button type="submit">登録</button>
  </form>
</body>
</html>

test/api/UserController.spec.js

const { expect } = require('chai');
const request = require('supertest')('http://localhost:1337');

describe('UserController', function () {

  describe('create action', function () {

    it('should create a new user', function (done) {
      request
        .post('/user')
        .send({
          name: 'John Doe',
          email: '[email protected]',
          password: 'password123'
        })
        .expect(200)
        .end(function (err, res) {
          if (err) return done(err);
          expect(res.body).to.have.property('id');
          expect(res.body).to.have.property('name');
          expect(res.body).to.have



  • ゼロから始める
    すべての設定を自分で行うこともできます。これは、より多くの制御と柔軟性を提供しますが、より多くの時間と労力が必要です。
  • テスト
    Mocha と Chai 以外にも、Jest や Cucumber などのテストフレームワークを使用することもできます。
  • 認証と認可
    アプリケーションに認証と認可が必要な場合は、Passport.js などのライブラリを使用できます。
  • フロントエンドフレームワーク
    Sassに加えて、React、Vue.js、またはAngular などのフロントエンドフレームワークを使用することもできます。

最適な方法は、プロジェクトの要件と好みによって異なります。 上記のオプションを検討し、ニーズに合ったオプションを選択してください。

以下に、追加のリソースをいくつか紹介します。


node.js mongodb sass



Node.js入門ガイド

Node. jsは、サーバーサイドのJavaScript実行環境です。つまり、JavaScriptを使ってウェブサーバーやネットワークアプリケーションを開発することができます。Node. js公式サイトからインストーラーをダウンロードします。...


Node.jsのマルチコア活用

Node. jsは、イベント駆動型の非同期I/Oモデルを採用しているため、一般的にシングルスレッドで動作します。これは、CPUの処理能力を最大限に活用するために、ブロックする操作(例えば、ファイルI/Oやネットワーク通信)を非同期的に処理するからです。...


Node.js ファイル書き込み解説

Node. js は、JavaScript をサーバーサイドで実行するためのプラットフォームです。ファイルシステムへのアクセスも可能で、その中でもファイルにデータを書き込む機能は非常に重要です。const fs = require('fs');...


Node.jsでディレクトリ内のファイル一覧を取得する

Node. jsでは、fsモジュールを使用してディレクトリ内のファイル一覧を取得することができます。readdirメソッドは、指定されたディレクトリ内のファイル名とサブディレクトリ名を同期的にまたは非同期的に取得します。同期的な使用注意lstatメソッドはシンボリックリンクのターゲットファイルの情報を取得します。実際のファイルの情報を取得するには、statメソッドを使用します。...


Node.js スタックトレース出力方法

Node. jsでは、エラーが発生した場合にそのエラーのスタックトレースを出力することができます。スタックトレースは、エラーが発生した場所やその原因を特定する上で非常に役立ちます。最も一般的な方法は、エラーオブジェクトの stack プロパティを使用することです。これは、エラーが発生した場所やその呼び出し履歴を文字列として返します。...



SQL SQL SQL SQL Amazon で見る



Node.jsテンプレートエンジンについて

JavaScriptでプログラミングする際、テンプレートエンジンを使用することで、HTMLファイルや他のテキストベースのファイルに動的なコンテンツを埋め込むことができます。Node. jsには、様々なテンプレートエンジンが利用可能です。代表的なテンプレートエンジンには、EJS、Handlebars、Pug(Jade)などがあります。これらのエンジンは、それぞれ異なる構文や機能を持っていますが、基本的には、テンプレートファイルにHTMLの構造を定義し、JavaScriptのコードを使用して動的なデータを埋め込むことができます。


Node.jsでjQueryを使う?

一般的に、jQueryをNode. jsで直接使用することは推奨されません。Node. jsはサーバーサイドでのJavaScript実行を想定しており、ブラウザ環境向けのjQueryの機能は直接利用できないからです。詳細な解説Node. js サーバーサイドでJavaScriptを実行するためのプラットフォームです。ブラウザ環境とは異なり、DOMやブラウザのAPIは直接利用できません。


Node.js の基礎解説

Node. jsは、JavaScriptをサーバーサイドで実行するためのプラットフォームです。つまり、従来ブラウザ上でしか実行できなかったJavaScriptを、サーバー上で実行できるようにする環境を提供します。Node. js JavaScriptを実行するための環境であり、サーバー上で動作します。


Node.js デバッグ入門

Node. js アプリケーションのデバッグは、JavaScript コードのエラーや問題を特定し、解決するためのプロセスです。以下に、一般的なデバッグ手法を日本語で説明します。これを活用して、コードの実行フローを追跡し、問題が発生している箇所を特定します。


Node.js ファイル自動リロード

Node. jsでファイルを自動リロードする方法について、日本語で説明します。最も一般的な方法は、Node. jsのモジュールを使用することです。代表的なモジュールは以下の通りです。supervisor nodemonと同様に、ファイルの変更を検知してプロセスを再起動します。