> 웹 프론트엔드 > HTML 튜토리얼 > HTML 5 서버에서 보낸 이벤트

HTML 5 서버에서 보낸 이벤트

黄舟
풀어 주다: 2016-12-27 14:43:10
원래의
1432명이 탐색했습니다.

Server-Sent 이벤트 - 단방향 메시징

Server-Sent 이벤트는 서버에서 자동으로 업데이트를 받는 웹페이지를 의미합니다.

이전에도 웹페이지에서 업데이트가 있는지 물어봐야 했던 경우에도 가능했습니다. 서버를 통해 이벤트를 보내면 업데이트가 자동으로 도착할 수 있습니다.

예: Facebook/Twitter 업데이트, 평가 업데이트, 새 블로그 게시물, 이벤트 결과 등

브라우저 지원

서버에서 보낸 이벤트는 Internet Explorer를 제외한 모든 주요 브라우저에서 지원됩니다.

서버에서 보낸 이벤트 알림 수신

EventSource 개체는 서버에서 보낸 이벤트 알림을 받는 데 사용됩니다.

인스턴스

var source=new EventSource("demo_sse.php"); source.onmessage=function(event) { document.getElementById("result").innerHTML+=event.data + "<br />"; };
로그인 후 복사

예제 설명 :

새 EventSource 객체를 생성한 후 업데이트를 보낼 페이지의 URL(이 경우 "demo_sse.php")을 지정합니다.

업데이트가 수신될 때마다 onmessage 이벤트가 발생합니다

onmessage 이벤트가 발생하면 수신된 데이터를 ID가 "result"인 요소에 푸시합니다.

서버 전송 이벤트 지원 감지

위에서 TIY 예에서는 서버에서 보낸 이벤트에 대한 브라우저 지원을 감지하는 추가 코드 조각을 작성합니다.

if(typeof(EventSource)!=="undefined") { // Yes! Server-sent events support! // Some code..... } else { // Sorry! No server-sent events support.. }
로그인 후 복사

서버 측 코드 예

위 예가 작동하려면 또한 데이터 업데이트 서버(예: PHP 및 ASP)를 보낼 수 있어야 합니다.

서버측 이벤트 스트리밍의 구문은 매우 간단합니다. "Content-Type" 헤더를 "text/event-stream"으로 설정합니다. 이제 이벤트 스트림 전송을 시작할 수 있습니다.

PHP 코드(demo_sse.php):

<?php header(&#39;Content-Type: text/event-stream&#39;); header(&#39;Cache-Control: no-cache&#39;); $time = date(&#39;r&#39;); echo "data: The server time is: {$time}\n\n"; flush(); ?>
로그인 후 복사

ASP 코드(VB)(demo_sse.asp):

<% Response.ContentType="text/event-stream" Response.Expires=-1 Response.Write("data: " & now()) Response.Flush() %>
로그인 후 복사

코드 설명:

헤더 "Content-Type"을 "text/event-stream"으로 설정

페이지가 캐시되지 않도록 지정

전송 날짜 출력(항상 "data: "로 시작)

웹 페이지의 출력 데이터 새로 고침

EventSource 객체

위의 예에서는 onmessage 이벤트를 사용하여 메시지를 가져옵니다. 그러나 다른 이벤트도 사용할 수 있습니다.

Event

Description

onopen 서버에 대한 연결이 열릴 때

onmessage 메시지 수신 시

onerror 오류 발생 시

위 내용은 HTML 5 서버에서 보내는 이벤트 내용입니다. PHP 중국어 웹사이트(www.php.cn)를 주목하세요!


관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿