質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Next.js

Next.jsは、Reactを用いたサーバサイドレンダリングなどを行う軽量なフレームワークです。Zeit社が開発しており、nextコマンドでプロジェクトを作成することにより、開発環境整備が整った環境が即時に作成できます。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

0回答

1103閲覧

next.js apiサーバで仮想DBを作り操作(追加や削除、更新)したい

Mten

総合スコア0

Next.js

Next.jsは、Reactを用いたサーバサイドレンダリングなどを行う軽量なフレームワークです。Zeit社が開発しており、nextコマンドでプロジェクトを作成することにより、開発環境整備が整った環境が即時に作成できます。

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2020/10/24 19:35

前提・実現したいこと

・apiサーバで仮想DBを作り操作(追加や削除、更新)したいです。

【階層】各ファイルの主な役割と質問内容

pages | |__api | | | |__todos.js (仮想DB:DB:todos = [{ id: 1, task: "aaa" }, { id: 2, task: "bbb" }, { id: 3, task: "ccc" }]) | |__todo | | | |__[todo].js (index.jsから受け取った{ id: 1, task: "aaa" }を表示。todosの{ id: 1, task: "aaa" }を操作。)※質問箇所 | |__index.js(todos.jsからtodosを取得。[todo].jsに{ id: 1, task: "aaa" }を渡す)※質問箇所

【質問内容】
①index.js
[todo].jsに{ id: 1, task: "aaa" }を渡したいです。

②[todo].js
todos.jsの{ id: 1, task: "aaa" }を更新したいです。
また、todos.jsのtodosを操作(削除、編集)したい

api/todos.js

javascript

1const todos = [{ id: 1, task: "aaa" }, { id: 2, task: "bbb" }, { id: 3, task: "ccc" }] 2 3export default function handler(req, res) { 4 // Get data from your database 5 res.status(200).json(todos) 6}

index.js

javascript

1import useSwr from 'swr' 2import Link from 'next/link' 3 4const fetcher = (url) => fetch(url).then((res) => res.json()) 5 6export default function Index() { 7 //todos.jsの配列(todos)を取得 8 const { data, error } = useSwr('/api/todos', fetcher) 9 10 if (error) return <div>Failed to load users</div> 11 if (!data) return <div>Loading...</div> 12 13 return ( 14 <ul> 15 {data.map((todo) => ( 16 //質問①[todo.js]にtodo:[id:0, task: "aaa"]を渡したい。todo.idであれば可能 17 <li key={todo.id}> 18 <Link href="/todo/[todo]" as={`/todo/${todo}`}> 19 <a>{`todo ${todo.id}`}</a> 20 </Link> 21 </li > 22 )) 23 } 24 </ul > 25 ) 26}

todo/[todo].js

javascript

1import { useRouter } from 'next/router' 2 3//質問③ todo/todos.jsのtodosの中身を追加、削除、更新する方法がしりたい 4 5export default function Todo() { 6 const router = useRouter() 7 //質問①todo:[id:0, task: "aaa"]を格納したいができない。 8 const { todo } = router.query 9 10 return ( 11 <> 12 <p>Post: {todo.id}</p> 13 <p>Post: {todo.task}</p> 14 </> 15 ) 16}

補足情報

next.jsのAPIroutesを参考に作成しようとしています。
apiの中身を操作する方法を色々と調べましたが、取得する方法は出てきたものの
追加、編集、削除する方法は出てきませんでした。

ご教授をお願いしたいです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問