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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Socket.IO

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

HTML

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

Q&A

解決済

1回答

384閲覧

htmlからSocket.ioを使ってフォームを送りたいです

mote

総合スコア128

Socket.IO

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

HTML

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

0グッド

0クリップ

投稿2018/08/29 10:02

dot_installを見ながら、クライアントとサーバー間のやり取りをしてくて、コードを書いたのですが、
なにやらサーバーは立っていて、htmlファイルをlocalhostで読み込み、
formに文章を書いても、サーバーに送られてきていません。
なぜでしょうか?
そして、htmlファイルでjqueryを使っているのですが、その理由も知りたいです

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 29コード

html

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

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

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

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

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

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

guest

回答1

0

ベストアンサー

いくつか気になった点があるので修正してみてください。

1 この行のダブルクオーテーションが全角になっているので、半角にしてください。
<script src=”/socket.io/socket.io.js”></script>
<script src="/socket.io/socket.io.js"></script>

2 htmlタグで属性値を指定するときは、半角スペースは入れないようにしてください。
<form name ="myid">
<form name="myid">

3 jQueryを使っているのであれば、このような感じでセレクタを指定してください。

js

1$('form[name="myid"]').submit(function(){ 2 socket.emit("emit_data",$('input[name="msg"]').val()); 3});

4 scriptタグ内をこのように書き換えて見てください。無名関数というものです。

js

1(function(){ 2 var socket = io.connect(); 3 $('form[name="myid"]').submit(function(){ 4 socket.emit("emit_data",$('input[name="msg"]').val()); 5 }); 6})()

気になった点を列挙しただけなので、抜け、漏れ等あるかもしれません。
もし、ブラウザのコンソールにエラーメッセージなどが出力されていれば、それも質問に追記してください。

htmlファイルでjqueryを使っているのですが、その理由も知りたいです

そもそもjQueryとは何か、ご存知でしょうか?
jQueryが何かは調べればいくらでも情報が出てきます。
「このプログラムでjQueryを使うメリットは何か?」という意味の質問であれば、タイトルとは全く別の質問ですので、新しく質問を投稿してください。

投稿2018/08/29 12:39

編集2018/08/30 02:44
sublimer

総合スコア403

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

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

mote

2018/08/29 15:25

ご回答ありがとうございます。「subkimer」様の言う通りコードを書き直してみましたが、サーバーに文章が送られていないようです。コンソール上に受け取った文章が出ません。エラーなどは無いです。
sublimer

2018/08/30 02:44

回答に追記を行いました。私の方ではこれで動作しました。
mote

2018/08/30 03:22

ありがとうございます。 無名関数の呼び出しを行なっていなかっただけでした!!
sublimer

2018/08/30 03:24

解決されたようで良かったです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問