序文Nodejs はサーバーサイド言語です。開発中、登録やログインなどでは、判断のためにフォームを通じてバックエンドにデータを送信する必要があります。では、サーバーサイド言語として、Nodejs はどのような方法を使用して、呼び出しフォームの POST リクエスト値を受け取ることができるのでしょうか? よく使われるのは以下の3つです。具体的な使い方を例とともに見ていきましょう。 バックエンドではExpressプラグインを使用しているため、簡単に読むにはExpressについてある程度の知識が必要です〜 1. まず、npmを初期化し、expressパッケージをダウンロードし、モジュールをインポートしてサービスオブジェクトを作成します。 //express モジュールをインポートします。const express = require("express"); // サーバー オブジェクトを作成します。const app = express(); フォーム フォーム 配信フォームのこの機能を使用すると、フォーム内の送信タイプのボタンをクリックして、フォーム データを送信できます。フォームはオブジェクト形式です。属性名はinputタグ内の名前値、属性値はinputタグの値となります。具体的な書き方は以下の例のようになります。 <form action="/todata" method="POST"> <テーブル> <tr> <td>名前</td> <td> <input type="text" name="user" id=""></td> </tr> <tr> <td>パスワード</td> <td> <input type="text" name="password" id=""></td> </tr> <tr> <button type="submit">送信</button> </tr> </テーブル> </フォーム> フォームの送信は POST リクエストであるため、バックエンドの Node.js コードは POST リクエスト データの応答ヘッダーを解析し、app.use(bodyParser.urlencoded({extended: false })) を使用してフロントエンドから渡されたデータを表現する必要があります。具体的なバックエンドコードは以下のとおりです。 定数 express = require("express"); express() は、定数です。 app.use(express.static("./")) var bodyParser = require('body-parser') // application/x-www-form-urlencoded レスポンス ヘッダーを解析します。app.use(bodyParser.urlencoded({ Extended: false })) app.post("/todata",(req,res)=>{ コンソールにログ出力します。 res.send("送信に成功しました") }) app.listen("80",()=>{ console.log("成功"); }) ターミナルからノードコードを実行して結果を確認します ajax リクエストの受け渡しバックエンドにリクエストを送信する場合、get リクエストと post リクエストがよく使用されます。同様に、フォーム データは ajax post リクエストを介してバックエンドに送信できます。上記の例に基づいて、このメソッドのフロントエンドコードは次のようになります。 $("#inp3").on("クリック",function(){ ユーザーを $("#inp1").val() とします。 パスワードを$("#inp2").val()とします。 $.ajax({ url:"todata", タイプ:"投稿", データ:{ ユーザー、 パスワード }, 成功:(データ)=>{ アラート(データ) } }) }) ここでは、2 つの入力の値を取得し、送信ボタンをバインドして Ajax リクエストを送信します。バックエンドに送信されたデータは、データ属性に保存されます。バックエンドも req.body を通じてこれを取得します。フォームにアクション値を書き込む必要はなく、フォーム内のボタンはデフォルトの動作を防止する必要があることに注意することが重要です (そうしないと、クリック時にリクエストが直接送信され、Ajax リクエストが失敗します)。または、入力タグ タイプをボタン タイプとして使用します。 フォームのシリアル化この送信方法は、フォーム送信の一般的な方法です。リクエストは ajax 経由で送信され、name 属性はバックエンドの属性名として直接送信することもできます。上記2つの方法を組み合わせたものと言えます。 $("#inp3").on("クリック",function(){ $.ajax({ url:"todata", タイプ:"投稿", データ:$("form").serialize(), 成功:(データ)=>{ アラート(データ) } }) }) name 属性の値を取得するには、$("form").serialize() メソッドを使用するだけです。 要約するこれで、Node.js でフォームデータを取得する方法についての記事は終了です。Node.js でフォームデータを取得する方法の詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: MySQL はデータベースを動的に更新します スクリプト例の説明
>>: PXEを使用してCentOS7.6を自動的にインストールする方法の詳細なチュートリアル
この記事では、WeChatアプレットのカスタムタブバーコンポーネントの具体的なコードを参考までに紹介...
問題の説明プロジェクトのログインページでは、7日間パスワードを記憶する必要がある機能があります。この...
DATE_ADD() 関数は、指定された時間間隔を日付に追加します。現在のテーブル内のすべてのデー...
効果: <!doctypehtml> <html> <ヘッド> ...
目次Linux - ファイル記述子、ファイルポインタ、インデックスノード1. Linux - ファイ...
序文この記事では、DBA がいないチームが参考にできるように、MySQL の一般的な使用に関するヒン...
序文このサービスは数か月前からMySQLに導入されています。私の仕事は基本的にターミナルで行われるた...
今日は、サイトの設定やウェブサイトのアップロードなど、FlashFXP の最も基本的な機能を紹介しま...
html <!DOCTYPE html> <html lang="ja&...
この記事では、カルーセルアニメーションを実現するためのVueの具体的なコードを例として紹介します。具...
Docker でシェル コマンドを実行するには、コマンドの前に sh -c を追加する必要があります...
通常、国喪の日、大地震の日、清明節には、ウェブサイト全体を灰色にして、故人への哀悼の意を表します。そ...
設定手順Linux システム: CentOS-7.0 MySQL バージョン: 5.7.21 Lin...
目次序文for文の無限ループを修正while文の無限ループを修正要約する序文Js デッド ループはど...
NULL 値によると、MySQL の NULL 値は単にデータがないことを意味します。NULL 値は...