Is that still the case? If it is, the reasoning there is that browsers can’t accept connections from other browsers due to browser standards. Isn’t that exactly what WebRTC solves though using a webserver to negotiate the direct connection? Is it possible to use the webserver to negotiate handshakes between browsers using WebRTC to allow an HTML5 game in a browser to host a game?
This reasoning is definitely the correct one. It is not possible to connect from web browsers directly out to other web browsers or to TCP/UDP based web servers, because this would allow web sites to use connected clients as web servers, and implement e.g. BitTorrent nodes behind user’s backs with ease, not that it’s impossible now, but considerably harder. The reason is not for example due to incompatible standards.
There are two ways to approach this:
Projects like WebSockify allow one to set up a WebSockets based server that routes communication over to a TCP server. This can allow an in-browser WebSockets client to connect out to servers.
WebRTC has a P2P matching mechanism with STUN and TURN server architecture to enable two browsers to do P2P data channels connection. This is somewhat involved but currently the only way that two browsers can do a “real” P2P communication without intermediaries.