{"id":36068,"date":"2025-05-07T15:52:00","date_gmt":"2025-05-07T07:52:00","guid":{"rendered":"https:\/\/www.wsisp.com\/helps\/36068.html"},"modified":"2025-05-07T15:52:00","modified_gmt":"2025-05-07T07:52:00","slug":"%e7%94%a8vue3%e6%98%be%e7%a4%bawebsocket%e7%9a%84%e7%8a%b6%e6%80%81","status":"publish","type":"post","link":"https:\/\/www.wsisp.com\/helps\/36068.html","title":{"rendered":"\u7528vue3\u663e\u793awebsocket\u7684\u72b6\u6001"},"content":{"rendered":"<p>\u5728\u4e0a\u6b21vue3\u9879\u76ee\u4e0a\u589e\u52a0\u4e00\u4e2a\u6807\u7b7e&#xff0c;\u663e\u793a\u5f53\u524d\u7684\u8fde\u63a5\u72b6\u6001&#xff0c;\u4e24\u4e2a\u6309\u94ae:\u91cd\u65b0\u8fde\u63a5 \u548c \u65ad\u5f00\u8fde\u63a5<\/p>\n<h4>\u4fee\u6539App.vue<\/h4>\n<p><span class=\"token operator\">&lt;<\/span>template<span class=\"token operator\">&gt;<\/span><br \/>\n  <span class=\"token operator\">&lt;<\/span>header<span class=\"token operator\">&gt;<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span>title<span class=\"token operator\">&gt;<\/span>ws\u72b6\u6001\u6d4b\u8bd5<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>title<span class=\"token operator\">&gt;<\/span><br \/>\n  <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>header<span class=\"token operator\">&gt;<\/span><\/p>\n<p>  <span class=\"token operator\">&lt;<\/span>main<span class=\"token operator\">&gt;<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span>WsStatus <span class=\"token operator\">\/<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n  <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>main<span class=\"token operator\">&gt;<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>template<span class=\"token operator\">&gt;<\/span><\/p>\n<p><span class=\"token operator\">&lt;<\/span>script setup lang<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;ts&#034;<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n<span class=\"token keyword\">import<\/span> WsStatus <span class=\"token keyword\">from<\/span> <span class=\"token string\">&#039;.\/components\/WsStatus.vue&#039;<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>script<span class=\"token operator\">&gt;<\/span><\/p>\n<p><span class=\"token operator\">&lt;<\/span>style scoped<span class=\"token operator\">&gt;<\/span><br \/>\nheader <span class=\"token punctuation\">{<\/span><br \/>\n  line<span class=\"token operator\">&#8211;<\/span>height<span class=\"token operator\">:<\/span> <span class=\"token number\">1.5<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token punctuation\">.<\/span>logo <span class=\"token punctuation\">{<\/span><br \/>\n  <span class=\"token literal-property property\">display<\/span><span class=\"token operator\">:<\/span> block<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token literal-property property\">margin<\/span><span class=\"token operator\">:<\/span> <span class=\"token number\">0<\/span> auto 2rem<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p>&#064;<span class=\"token function\">media<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token parameter\">min<span class=\"token operator\">&#8211;<\/span>width<span class=\"token operator\">:<\/span> 1024px<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n  header <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">display<\/span><span class=\"token operator\">:<\/span> flex<span class=\"token punctuation\">;<\/span><br \/>\n    place<span class=\"token operator\">&#8211;<\/span>items<span class=\"token operator\">:<\/span> center<span class=\"token punctuation\">;<\/span><br \/>\n    padding<span class=\"token operator\">&#8211;<\/span>right<span class=\"token operator\">:<\/span> <span class=\"token function\">calc<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">var<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&#8212;<\/span>section<span class=\"token operator\">&#8211;<\/span>gap<span class=\"token punctuation\">)<\/span> <span class=\"token operator\">\/<\/span> <span class=\"token number\">2<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><\/p>\n<p>  <span class=\"token punctuation\">.<\/span>logo <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">margin<\/span><span class=\"token operator\">:<\/span> <span class=\"token number\">0<\/span> 2rem <span class=\"token number\">0<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><\/p>\n<p>  header <span class=\"token punctuation\">.<\/span>wrapper <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token literal-property property\">display<\/span><span class=\"token operator\">:<\/span> flex<span class=\"token punctuation\">;<\/span><br \/>\n    place<span class=\"token operator\">&#8211;<\/span>items<span class=\"token operator\">:<\/span> flex<span class=\"token operator\">&#8211;<\/span>start<span class=\"token punctuation\">;<\/span><br \/>\n    flex<span class=\"token operator\">&#8211;<\/span>wrap<span class=\"token operator\">:<\/span> wrap<span class=\"token punctuation\">;<\/span><br \/>\n  <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>style<span class=\"token operator\">&gt;<\/span><\/p>\n<h4>WsStatus.vue<\/h4>\n<p>\u521b\u5efa\u4e00\u4e2a\u7ec4\u4ef6WsStatus.vue<\/p>\n<p><span class=\"token operator\">&lt;<\/span>template<span class=\"token operator\">&gt;<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span>div class<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;WsStatus&#034;<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span>h1<span class=\"token operator\">&gt;<\/span>WebSocket \u6d4b\u8bd5<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>h1<span class=\"token operator\">&gt;<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span>div class<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;status&#034;<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n            \u8fde\u63a5\u72b6\u6001<span class=\"token operator\">:<\/span> <span class=\"token operator\">&lt;<\/span>span <span class=\"token operator\">:<\/span>class<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;statusClass&#034;<\/span><span class=\"token operator\">&gt;<\/span><span class=\"token punctuation\">{<\/span><span class=\"token punctuation\">{<\/span> connectionStatus <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">}<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>span<span class=\"token operator\">&gt;<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>div<span class=\"token operator\">&gt;<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span>button &#064;click<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;reconnect&#034;<\/span> <span class=\"token operator\">:<\/span>disabled<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;isConnecting&#034;<\/span><span class=\"token operator\">&gt;<\/span><br \/>\n            <span class=\"token punctuation\">{<\/span><span class=\"token punctuation\">{<\/span> isConnecting <span class=\"token operator\">?<\/span> <span class=\"token char\">&#039;\u8fde\u63a5\u4e2d&#8230;&#039;<\/span> <span class=\"token operator\">:<\/span> <span class=\"token char\">&#039;\u91cd\u65b0\u8fde\u63a5&#039;<\/span> <span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">}<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>button<span class=\"token operator\">&gt;<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span>button &#064;click<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;closeConnect&#034;<\/span> <span class=\"token operator\">:<\/span>disabled<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;connectStatus&#034;<\/span><span class=\"token operator\">&gt;<\/span>\u65ad\u5f00\u8fde\u63a5<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>button<span class=\"token operator\">&gt;<\/span><br \/>\n        <span class=\"token operator\">&lt;<\/span>canvas<span class=\"token operator\">&gt;<\/span><span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>canvas<span class=\"token operator\">&gt;<\/span><br \/>\n    <span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>div<span class=\"token operator\">&gt;<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>template<span class=\"token operator\">&gt;<\/span><\/p>\n<p><span class=\"token operator\">&lt;<\/span>script setup lang<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;ts&#034;<\/span> name<span class=\"token operator\">&#061;<\/span><span class=\"token string\">&#034;WsStatus&#034;<\/span><span class=\"token operator\">&gt;<\/span><br \/>\nimport <span class=\"token punctuation\">{<\/span> ref<span class=\"token punctuation\">,<\/span> onMounted<span class=\"token punctuation\">,<\/span> onUnmounted <span class=\"token punctuation\">}<\/span> from <span class=\"token char\">&#039;vue&#039;<\/span><\/p>\n<p><span class=\"token keyword\">const<\/span> ws <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">ref<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\n<span class=\"token keyword\">const<\/span> imageUrl <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">ref<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\n<span class=\"token keyword\">const<\/span> connectionStatus <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">ref<\/span><span class=\"token punctuation\">(<\/span><span class=\"token char\">&#039;\u672a\u8fde\u63a5&#039;<\/span><span class=\"token punctuation\">)<\/span><br \/>\n<span class=\"token keyword\">const<\/span> isConnecting <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">ref<\/span><span class=\"token punctuation\">(<\/span>false<span class=\"token punctuation\">)<\/span><br \/>\n<span class=\"token keyword\">const<\/span> connectStatus <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">ref<\/span><span class=\"token punctuation\">(<\/span>false<span class=\"token punctuation\">)<\/span><br \/>\n<span class=\"token keyword\">const<\/span> statusClass <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">ref<\/span><span class=\"token punctuation\">(<\/span><span class=\"token char\">&#039;disconnected&#039;<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<p>function <span class=\"token function\">get_appropriate_ws_url<\/span><span class=\"token punctuation\">(<\/span>extra_url<span class=\"token operator\">:<\/span> string<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    var pcol<span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token comment\">\/\/ \u83b7\u5f97\u9875\u9762\u4e0a\u7684url<\/span><br \/>\n    var u <span class=\"token operator\">&#061;<\/span> document<span class=\"token punctuation\">.<\/span>URL<span class=\"token punctuation\">;<\/span><\/p>\n<p>    <span class=\"token comment\">\/*<br \/>\n     * We open the websocket encrypted if this page came on an<br \/>\n     * https:\/\/ url itself, otherwise unencrypted<br \/>\n     *\/<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/ \u53bb\u6389http:\/\/\u6216\u8005https:\/\/<\/span><br \/>\n    <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>u<span class=\"token punctuation\">.<\/span><span class=\"token function\">substring<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">5<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&#061;<\/span><span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;https&#034;<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        pcol <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;wss:\/\/&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        u <span class=\"token operator\">&#061;<\/span> u<span class=\"token punctuation\">.<\/span><span class=\"token function\">substr<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">8<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span> <span class=\"token keyword\">else<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        pcol <span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;ws:\/\/&#034;<\/span><span class=\"token punctuation\">;<\/span><br \/>\n        <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>u<span class=\"token punctuation\">.<\/span><span class=\"token function\">substring<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token number\">4<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;&#061;<\/span><span class=\"token operator\">&#061;<\/span> <span class=\"token string\">&#034;http&#034;<\/span><span class=\"token punctuation\">)<\/span><br \/>\n            u <span class=\"token operator\">&#061;<\/span> u<span class=\"token punctuation\">.<\/span><span class=\"token function\">substr<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">7<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    <span class=\"token comment\">\/* &#043; &#034;\/xxx&#034; bit is for IE10 workaround *\/<\/span><\/p>\n<p>    <span class=\"token comment\">\/\/\u56de\u6765\u7684url\u5c31\u57ce\u4e86ws:\/\/\u5730\u5740\u6216\u8005wss:\/\/\u5730\u5740<\/span><br \/>\n    <span class=\"token keyword\">return<\/span> pcol <span class=\"token operator\">&#043;<\/span> u<span class=\"token punctuation\">.<\/span><span class=\"token function\">split<\/span><span class=\"token punctuation\">(<\/span><span class=\"token char\">&#039;\/&#039;<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">[<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">]<\/span> <span class=\"token operator\">&#043;<\/span> <span class=\"token string\">&#034;\/&#034;<\/span> <span class=\"token operator\">&#043;<\/span> extra_url<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ WebSocket\u914d\u7f6e&#xff08;\u4fee\u6539\u4e3a\u4f60\u7684\u670d\u52a1\u5668\u5730\u5740&#xff09;<\/span><br \/>\n<span class=\"token keyword\">const<\/span> wsUrl <span class=\"token operator\">&#061;<\/span> <span class=\"token function\">get_appropriate_ws_url<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">&#034;&#034;<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<p><span class=\"token keyword\">const<\/span> connectWebSocket <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;<\/span><span class=\"token operator\">&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>isConnecting<span class=\"token punctuation\">.<\/span>value<span class=\"token punctuation\">)<\/span> <span class=\"token keyword\">return<\/span><\/p>\n<p>    isConnecting<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> true<br \/>\n    connectionStatus<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> <span class=\"token char\">&#039;\u8fde\u63a5\u4e2d&#8230;&#039;<\/span><br \/>\n    statusClass<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> <span class=\"token char\">&#039;connecting&#039;<\/span><\/p>\n<p>    ws<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> new <span class=\"token function\">WebSocket<\/span><span class=\"token punctuation\">(<\/span>wsUrl<span class=\"token punctuation\">)<\/span><\/p>\n<p>    ws<span class=\"token punctuation\">.<\/span>value<span class=\"token punctuation\">.<\/span>onopen <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;<\/span><span class=\"token operator\">&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        connectionStatus<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> <span class=\"token char\">&#039;\u5df2\u8fde\u63a5&#039;<\/span><br \/>\n        statusClass<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> <span class=\"token char\">&#039;connected&#039;<\/span><br \/>\n        isConnecting<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> false<br \/>\n        connectStatus<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> false<br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    ws<span class=\"token punctuation\">.<\/span>value<span class=\"token punctuation\">.<\/span>onmessage <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span>event<span class=\"token operator\">:<\/span> any<span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;<\/span><span class=\"token operator\">&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        console<span class=\"token punctuation\">.<\/span><span class=\"token function\">log<\/span><span class=\"token punctuation\">(<\/span><span class=\"token char\">&#039;\u6536\u5230\u6570\u636e&#039;<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<p>    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    ws<span class=\"token punctuation\">.<\/span>value<span class=\"token punctuation\">.<\/span>onerror <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span>error<span class=\"token operator\">:<\/span> any<span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;<\/span><span class=\"token operator\">&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        console<span class=\"token punctuation\">.<\/span><span class=\"token function\">error<\/span><span class=\"token punctuation\">(<\/span><span class=\"token char\">&#039;WebSocket\u9519\u8bef:&#039;<\/span><span class=\"token punctuation\">,<\/span> error<span class=\"token punctuation\">)<\/span><br \/>\n        connectionStatus<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> <span class=\"token char\">&#039;\u8fde\u63a5\u9519\u8bef&#039;<\/span><br \/>\n        statusClass<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> <span class=\"token char\">&#039;error&#039;<\/span><br \/>\n        isConnecting<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> false<br \/>\n    <span class=\"token punctuation\">}<\/span><\/p>\n<p>    ws<span class=\"token punctuation\">.<\/span>value<span class=\"token punctuation\">.<\/span>onclose <span class=\"token operator\">&#061;<\/span> <span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;<\/span><span class=\"token operator\">&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        connectionStatus<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> <span class=\"token char\">&#039;\u8fde\u63a5\u5df2\u5173\u95ed&#039;<\/span><br \/>\n        statusClass<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> <span class=\"token char\">&#039;disconnected&#039;<\/span><br \/>\n        isConnecting<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> false<br \/>\n        connectStatus<span class=\"token punctuation\">.<\/span>value <span class=\"token operator\">&#061;<\/span> true<br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u7ec4\u4ef6\u6302\u8f7d\u65f6\u81ea\u52a8\u8fde\u63a5<\/span><br \/>\n<span class=\"token function\">onMounted<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;<\/span><span class=\"token operator\">&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token function\">connectWebSocket<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<p><span class=\"token comment\">\/\/ \u7ec4\u4ef6\u5378\u8f7d\u65f6\u5173\u95ed\u8fde\u63a5<\/span><br \/>\n<span class=\"token function\">onUnmounted<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token operator\">&#061;<\/span><span class=\"token operator\">&gt;<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>ws<span class=\"token punctuation\">.<\/span>value<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        ws<span class=\"token punctuation\">.<\/span>value<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">)<\/span><\/p>\n<p>function <span class=\"token function\">reconnect<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>ws<span class=\"token punctuation\">.<\/span>value<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        ws<span class=\"token punctuation\">.<\/span>value<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n    <span class=\"token function\">connectWebSocket<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p>function <span class=\"token function\">closeConnect<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n    <span class=\"token keyword\">if<\/span> <span class=\"token punctuation\">(<\/span>ws<span class=\"token punctuation\">.<\/span>value<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><br \/>\n        ws<span class=\"token punctuation\">.<\/span>value<span class=\"token punctuation\">.<\/span><span class=\"token function\">close<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><br \/>\n    <span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>script<span class=\"token operator\">&gt;<\/span><\/p>\n<p><span class=\"token operator\">&lt;<\/span>style scoped<span class=\"token operator\">&gt;<\/span><br \/>\n<span class=\"token punctuation\">.<\/span>websocket<span class=\"token operator\">&#8211;<\/span>page <span class=\"token punctuation\">{<\/span><br \/>\n    padding<span class=\"token operator\">:<\/span> <span class=\"token number\">20<\/span>px<span class=\"token punctuation\">;<\/span><br \/>\n    max<span class=\"token operator\">&#8211;<\/span>width<span class=\"token operator\">:<\/span> <span class=\"token number\">800<\/span>px<span class=\"token punctuation\">;<\/span><br \/>\n    margin<span class=\"token operator\">:<\/span> <span class=\"token number\">0<\/span> <span class=\"token keyword\">auto<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token punctuation\">.<\/span>status <span class=\"token punctuation\">{<\/span><br \/>\n    margin<span class=\"token operator\">:<\/span> <span class=\"token number\">20<\/span>px <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    font<span class=\"token operator\">&#8211;<\/span>size<span class=\"token operator\">:<\/span> <span class=\"token number\">18<\/span>px<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token punctuation\">.<\/span>status span <span class=\"token punctuation\">{<\/span><br \/>\n    font<span class=\"token operator\">&#8211;<\/span>weight<span class=\"token operator\">:<\/span> bold<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token punctuation\">.<\/span>connected <span class=\"token punctuation\">{<\/span><br \/>\n    color<span class=\"token operator\">:<\/span> #<span class=\"token number\">4<\/span>CAF50<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token punctuation\">.<\/span>connecting <span class=\"token punctuation\">{<\/span><br \/>\n    color<span class=\"token operator\">:<\/span> #FFC107<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token punctuation\">.<\/span>disconnected <span class=\"token punctuation\">{<\/span><br \/>\n    color<span class=\"token operator\">:<\/span> #F44336<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token punctuation\">.<\/span>error <span class=\"token punctuation\">{<\/span><br \/>\n    color<span class=\"token operator\">:<\/span> #F44336<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p>button <span class=\"token punctuation\">{<\/span><br \/>\n    padding<span class=\"token operator\">:<\/span> <span class=\"token number\">10<\/span>px <span class=\"token number\">20<\/span>px<span class=\"token punctuation\">;<\/span><br \/>\n    background<span class=\"token operator\">&#8211;<\/span>color<span class=\"token operator\">:<\/span> #<span class=\"token number\">2196F<\/span><span class=\"token number\">3<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    color<span class=\"token operator\">:<\/span> white<span class=\"token punctuation\">;<\/span><br \/>\n    border<span class=\"token operator\">:<\/span> none<span class=\"token punctuation\">;<\/span><br \/>\n    border<span class=\"token operator\">&#8211;<\/span>radius<span class=\"token operator\">:<\/span> <span class=\"token number\">4<\/span>px<span class=\"token punctuation\">;<\/span><br \/>\n    cursor<span class=\"token operator\">:<\/span> pointer<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p>button<span class=\"token operator\">:<\/span>disabled <span class=\"token punctuation\">{<\/span><br \/>\n    background<span class=\"token operator\">&#8211;<\/span>color<span class=\"token operator\">:<\/span> #BBDEFB<span class=\"token punctuation\">;<\/span><br \/>\n    cursor<span class=\"token operator\">:<\/span> not<span class=\"token operator\">&#8211;<\/span>allowed<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token punctuation\">.<\/span>messages <span class=\"token punctuation\">{<\/span><br \/>\n    margin<span class=\"token operator\">&#8211;<\/span>top<span class=\"token operator\">:<\/span> <span class=\"token number\">30<\/span>px<span class=\"token punctuation\">;<\/span><br \/>\n    border<span class=\"token operator\">&#8211;<\/span>top<span class=\"token operator\">:<\/span> <span class=\"token number\">1<\/span>px solid #eee<span class=\"token punctuation\">;<\/span><br \/>\n    padding<span class=\"token operator\">&#8211;<\/span>top<span class=\"token operator\">:<\/span> <span class=\"token number\">20<\/span>px<span class=\"token punctuation\">;<\/span><br \/>\n    background<span class=\"token operator\">&#8211;<\/span>size<span class=\"token operator\">:<\/span> <span class=\"token number\">100<\/span><span class=\"token operator\">%<\/span> <span class=\"token number\">100<\/span><span class=\"token operator\">%<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p>ul <span class=\"token punctuation\">{<\/span><br \/>\n    list<span class=\"token operator\">&#8211;<\/span>style<span class=\"token operator\">&#8211;<\/span>type<span class=\"token operator\">:<\/span> none<span class=\"token punctuation\">;<\/span><br \/>\n    padding<span class=\"token operator\">:<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    max<span class=\"token operator\">&#8211;<\/span>height<span class=\"token operator\">:<\/span> <span class=\"token number\">300<\/span>px<span class=\"token punctuation\">;<\/span><br \/>\n    overflow<span class=\"token operator\">&#8211;<\/span>y<span class=\"token operator\">:<\/span> <span class=\"token keyword\">auto<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    border<span class=\"token operator\">:<\/span> <span class=\"token number\">1<\/span>px solid #ddd<span class=\"token punctuation\">;<\/span><br \/>\n    padding<span class=\"token operator\">:<\/span> <span class=\"token number\">10<\/span>px<span class=\"token punctuation\">;<\/span><br \/>\n    border<span class=\"token operator\">&#8211;<\/span>radius<span class=\"token operator\">:<\/span> <span class=\"token number\">4<\/span>px<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p>li <span class=\"token punctuation\">{<\/span><br \/>\n    padding<span class=\"token operator\">:<\/span> <span class=\"token number\">5<\/span>px <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    border<span class=\"token operator\">&#8211;<\/span>bottom<span class=\"token operator\">:<\/span> <span class=\"token number\">1<\/span>px solid #eee<span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token punctuation\">.<\/span>live<span class=\"token operator\">&#8211;<\/span>image <span class=\"token punctuation\">{<\/span><br \/>\n    position<span class=\"token operator\">:<\/span> fixed<span class=\"token punctuation\">;<\/span><br \/>\n    top<span class=\"token operator\">:<\/span> <span class=\"token number\">50<\/span><span class=\"token operator\">%<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    left<span class=\"token operator\">:<\/span> <span class=\"token number\">50<\/span><span class=\"token operator\">%<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    width<span class=\"token operator\">:<\/span> <span class=\"token number\">100<\/span>vw<span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token comment\">\/* \u6839\u636e\u9700\u8981\u8bbe\u7f6e\u5bbd\u5ea6 *\/<\/span><br \/>\n    height<span class=\"token operator\">:<\/span> <span class=\"token number\">100<\/span>vw<span class=\"token punctuation\">;<\/span><\/p>\n<p>    object<span class=\"token operator\">&#8211;<\/span>fit<span class=\"token operator\">:<\/span> cover<span class=\"token punctuation\">;<\/span><br \/>\n    transform<span class=\"token operator\">:<\/span> <span class=\"token function\">translate<\/span><span class=\"token punctuation\">(<\/span><span class=\"token operator\">&#8211;<\/span><span class=\"token number\">50<\/span><span class=\"token operator\">%<\/span><span class=\"token punctuation\">,<\/span> <span class=\"token operator\">&#8211;<\/span><span class=\"token number\">50<\/span><span class=\"token operator\">%<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token macro property\"><span class=\"token directive-hash\">#<\/span><span class=\"token directive keyword\">cam<\/span><span class=\"token expression\">Image<span class=\"token punctuation\">,<\/span><\/span><\/span><br \/>\n<span class=\"token macro property\"><span class=\"token directive-hash\">#<\/span><span class=\"token directive keyword\">canvas<\/span> <span class=\"token expression\"><span class=\"token punctuation\">{<\/span><\/span><\/span><br \/>\n    position<span class=\"token operator\">:<\/span> fixed<span class=\"token punctuation\">;<\/span><br \/>\n    left<span class=\"token operator\">:<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    top<span class=\"token operator\">:<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    width<span class=\"token operator\">:<\/span> <span class=\"token number\">100<\/span><span class=\"token operator\">%<\/span><span class=\"token punctuation\">;<\/span><br \/>\n    <span class=\"token comment\">\/* height: 100%; *\/<\/span><br \/>\n    z<span class=\"token operator\">&#8211;<\/span>index<span class=\"token operator\">:<\/span> <span class=\"token operator\">&#8211;<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">;<\/span><br \/>\n<span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/* \u7ad6\u5c4f *\/<\/span><br \/>\n&#064;media screen <span class=\"token function\">and<\/span> <span class=\"token punctuation\">(<\/span>orientation<span class=\"token operator\">:<\/span> portrait<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><span class=\"token punctuation\">}<\/span><\/p>\n<p><span class=\"token comment\">\/* \u6a2a\u5c4f *\/<\/span><br \/>\n&#064;media screen <span class=\"token function\">and<\/span> <span class=\"token punctuation\">(<\/span>orientation<span class=\"token operator\">:<\/span> landscape<span class=\"token punctuation\">)<\/span> <span class=\"token punctuation\">{<\/span><span class=\"token punctuation\">}<\/span><br \/>\n<span class=\"token operator\">&lt;<\/span><span class=\"token operator\">\/<\/span>style<span class=\"token operator\">&gt;<\/span><\/p>\n<h4>\u7f16\u8bd1\u6253\u5305\u4e0a\u4f20\u90e8\u7f72<\/h4>\n<p>$ <span class=\"token function\">npm<\/span> run build<br \/>\n$ <span class=\"token function\">scp<\/span> <span class=\"token parameter variable\">-r<\/span> .\/dist\/* root&#064;192.168.9.163:\/oem\/usr\/www<\/p>\n<h4>\u6d4b\u8bd5<\/h4>\n<p>\u5728rv1106\u6444\u50cf\u5934\u6253\u5f00\u8fd0\u884cws\u670d\u52a1\u5668<\/p>\n<p><span class=\"token comment\"># \/oem\/usr\/bin\/ws_cam<\/span><\/p>\n<p>\u6d4f\u89c8\u5668\u8bbf\u95ee http:\/\/192.168.9.163:7681\/ \u770b\u5230\u76f8\u5e94\u9875\u9762&#xff0c;\u6309\u6309\u952e\u4f1a\u6709\u76f8\u5e94\u7684\u53d8\u6362\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb842\u6b21\u3002\u5728\u4e0a\u6b21vue3\u9879\u76ee\u4e0a\u589e\u52a0\u4e00\u4e2a\u6807\u7b7e\uff0c\u663e\u793a\u5f53\u524d\u7684\u8fde\u63a5\u72b6\u6001\uff0c\u4e24\u4e2a\u6309\u94ae:\u91cd\u65b0\u8fde\u63a5 \u548c \u65ad\u5f00\u8fde\u63a5\u3002_\u5982\u4f55\u67e5\u770bvue3\u9879\u76ee\u4e2d\u662f\u5426\u652f\u6301websocket<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[58,947,87,78],"topic":[],"class_list":["post-36068","post","type-post","status-publish","format-standard","hentry","category-server","tag-linux","tag-websocket","tag-87","tag-78"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u7528vue3\u663e\u793awebsocket\u7684\u72b6\u6001 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.wsisp.com\/helps\/36068.html\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u7528vue3\u663e\u793awebsocket\u7684\u72b6\u6001 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"og:description\" content=\"\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb842\u6b21\u3002\u5728\u4e0a\u6b21vue3\u9879\u76ee\u4e0a\u589e\u52a0\u4e00\u4e2a\u6807\u7b7e\uff0c\u663e\u793a\u5f53\u524d\u7684\u8fde\u63a5\u72b6\u6001\uff0c\u4e24\u4e2a\u6309\u94ae:\u91cd\u65b0\u8fde\u63a5 \u548c \u65ad\u5f00\u8fde\u63a5\u3002_\u5982\u4f55\u67e5\u770bvue3\u9879\u76ee\u4e2d\u662f\u5426\u652f\u6301websocket\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.wsisp.com\/helps\/36068.html\" \/>\n<meta property=\"og:site_name\" content=\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"article:published_time\" content=\"2025-05-07T07:52:00+00:00\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/36068.html\",\"url\":\"https:\/\/www.wsisp.com\/helps\/36068.html\",\"name\":\"\u7528vue3\u663e\u793awebsocket\u7684\u72b6\u6001 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"isPartOf\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\"},\"datePublished\":\"2025-05-07T07:52:00+00:00\",\"dateModified\":\"2025-05-07T07:52:00+00:00\",\"author\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/36068.html#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.wsisp.com\/helps\/36068.html\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/36068.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.wsisp.com\/helps\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u7528vue3\u663e\u793awebsocket\u7684\u72b6\u6001\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\",\"url\":\"https:\/\/www.wsisp.com\/helps\/\",\"name\":\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"description\":\"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\",\"name\":\"admin\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"contentUrl\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"caption\":\"admin\"},\"sameAs\":[\"http:\/\/wp.wsisp.com\"],\"url\":\"https:\/\/www.wsisp.com\/helps\/author\/admin\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u7528vue3\u663e\u793awebsocket\u7684\u72b6\u6001 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.wsisp.com\/helps\/36068.html","og_locale":"zh_CN","og_type":"article","og_title":"\u7528vue3\u663e\u793awebsocket\u7684\u72b6\u6001 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","og_description":"\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb842\u6b21\u3002\u5728\u4e0a\u6b21vue3\u9879\u76ee\u4e0a\u589e\u52a0\u4e00\u4e2a\u6807\u7b7e\uff0c\u663e\u793a\u5f53\u524d\u7684\u8fde\u63a5\u72b6\u6001\uff0c\u4e24\u4e2a\u6309\u94ae:\u91cd\u65b0\u8fde\u63a5 \u548c \u65ad\u5f00\u8fde\u63a5\u3002_\u5982\u4f55\u67e5\u770bvue3\u9879\u76ee\u4e2d\u662f\u5426\u652f\u6301websocket","og_url":"https:\/\/www.wsisp.com\/helps\/36068.html","og_site_name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","article_published_time":"2025-05-07T07:52:00+00:00","author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"admin","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"3 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.wsisp.com\/helps\/36068.html","url":"https:\/\/www.wsisp.com\/helps\/36068.html","name":"\u7528vue3\u663e\u793awebsocket\u7684\u72b6\u6001 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","isPartOf":{"@id":"https:\/\/www.wsisp.com\/helps\/#website"},"datePublished":"2025-05-07T07:52:00+00:00","dateModified":"2025-05-07T07:52:00+00:00","author":{"@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41"},"breadcrumb":{"@id":"https:\/\/www.wsisp.com\/helps\/36068.html#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.wsisp.com\/helps\/36068.html"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.wsisp.com\/helps\/36068.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.wsisp.com\/helps"},{"@type":"ListItem","position":2,"name":"\u7528vue3\u663e\u793awebsocket\u7684\u72b6\u6001"}]},{"@type":"WebSite","@id":"https:\/\/www.wsisp.com\/helps\/#website","url":"https:\/\/www.wsisp.com\/helps\/","name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","description":"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41","name":"admin","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/","url":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","contentUrl":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","caption":"admin"},"sameAs":["http:\/\/wp.wsisp.com"],"url":"https:\/\/www.wsisp.com\/helps\/author\/admin"}]}},"_links":{"self":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/36068","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/comments?post=36068"}],"version-history":[{"count":0,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/36068\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media?parent=36068"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/categories?post=36068"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/tags?post=36068"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/topic?post=36068"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}