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

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

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

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

Socket.IO

Socket.IOはNode.js上で動くライブラリであり、すべてのブラウザとモバイルデバイスでリアルタイムのアプリを作動させる事を目的としています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

0回答

1702閲覧

クライアント側からサーバー側にSocket.ioを使ってデータ送信

mote

総合スコア128

Node.js

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

Socket.IO

Socket.IOはNode.js上で動くライブラリであり、すべてのブラウザとモバイルデバイスでリアルタイムのアプリを作動させる事を目的としています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

1クリップ

投稿2018/08/29 15:45

htmlからサーバーサイドにデータを送る際に、自分の書いた下のコードだと、コンソール上にdataが書かれません。
何がいけないのでしょうか?(socket.ioが機能していないのかも...)
ちなみにドットインストールを参考にしてコードを書きました。

js

1var app = require("http").createServer(handler), 2 io = require("socket.io").listen(app) , 3 fs = require("fs") ; 4//listenでサーバー組み立てに紐つけた。 5 6app.listen(3000) ; 7console.log("server start!"); 8 9function handler(req,res){ 10 fs.readFile(__dirname+"/index.html",function(err,data){ 11 if(err){ 12 res.writeHead(500); 13 return res.end("Error"); 14 } 15 16 res.writeHead(200); 17 res.write(data); 18 res.end(); 19 20}) 21} 22//クライアントからのemitを待ち受ける 23io.sockets.on("connection",function(socket){ 24 socket.on("emit_data",function(data){ 25 console.log(data); 26 }); 27}); 28

html

1 2<!DOCTYPE html> 3<html lang="ja"> 4 <head> 5 <meta charset="utf-8"> 6 <title>socket.io</title> 7 </head> 8 <body> 9 <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"> 10 </script> 11 <script src="/socket.io/socket.io.js"></script> 12 13 <form name="myid"> 14 <input type="text" name="msg"> 15 <input type="submit" value="送信"> 16 <script> 17 function(){ 18 var socket = io.connect(); 19 $('form[name="myid"]').submit(function(){ 20 socket.emit("emit_data",$('input[name="msg"]').val()); 21}); 22}; 23 </script> 24 </body> 25</html> 26

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問