1
0
mirror of https://github.com/ZSCNetSupportDept/website.git synced 2025-10-29 01:15:04 +08:00
Files
website/assets/js/070c39de.b352f8d2.js
2025-08-13 08:12:37 +08:00

1 line
73 KiB
JavaScript

"use strict";(self.webpackChunkdeveloper_zsc=self.webpackChunkdeveloper_zsc||[]).push([[1806],{15072:(e,s,n)=>{n.r(s),n.d(s,{assets:()=>h,contentTitle:()=>d,default:()=>j,frontMatter:()=>c,metadata:()=>i,toc:()=>a});var i=n(64263),l=n(74848),r=n(28453);const c={},d="Web\u7684\u5386\u53f23\ufe0f\u20e3-Web\u5e94\u7528",h={authorsImageUrls:[]},a=[{value:"AJAX\u4e0e\u524d\u540e\u7aef\u5206\u79bb",id:"ajax\u4e0e\u524d\u540e\u7aef\u5206\u79bb",level:2},{value:"JavaScript",id:"javascript",level:3},{value:"AJAX",id:"ajax",level:3},{value:"\u4e00\u4e2aAJAX\u62a5\u540d\u7cfb\u7edf\u7684\u4f8b\u5b50",id:"\u4e00\u4e2aajax\u62a5\u540d\u7cfb\u7edf\u7684\u4f8b\u5b50",level:3},{value:"API\u9a71\u52a8\u4e0e\u524d\u540e\u7aef\u5206\u79bb",id:"api\u9a71\u52a8\u4e0e\u524d\u540e\u7aef\u5206\u79bb",level:3},{value:"REST API",id:"rest-api",level:4},{value:"\u5355\u9875\u5e94\u7528(SPA)",id:"\u5355\u9875\u5e94\u7528spa",level:2},{value:"\u6846\u67b6",id:"\u6846\u67b6",level:3},{value:"UI\u7ec4\u4ef6",id:"ui\u7ec4\u4ef6",level:3},{value:"\u865a\u62dfDOM",id:"\u865a\u62dfdom",level:3},{value:"\u72b6\u6001\u7ba1\u7406",id:"\u72b6\u6001\u7ba1\u7406",level:3},{value:"\u524d\u7aef\u8def\u7531\u548c\u9996\u5c4f\u4f18\u5316",id:"\u524d\u7aef\u8def\u7531\u548c\u9996\u5c4f\u4f18\u5316",level:3},{value:"\u6784\u5efa\u7cfb\u7edf",id:"\u6784\u5efa\u7cfb\u7edf",level:3},{value:"JavaScript\u5168\u6808",id:"javascript\u5168\u6808",level:2},{value:"Node.js",id:"nodejs",level:3},{value:"Web\u5f00\u53d1\u4e4b\u5916",id:"web\u5f00\u53d1\u4e4b\u5916",level:3},{value:"\u6700\u65b0\u6280\u672f",id:"\u6700\u65b0\u6280\u672f",level:2},{value:"WebSocket",id:"websocket",level:3},{value:"WebAssembly",id:"webassembly",level:3},{value:"\u603b\u7ed3\u4e0e\u8d44\u6e90",id:"\u603b\u7ed3\u4e0e\u8d44\u6e90",level:2},{value:"\u7f16\u5e74\u53f2",id:"\u7f16\u5e74\u53f2",level:3},{value:"\u8d44\u6e90",id:"\u8d44\u6e90",level:3}];function p(e){const s={a:"a",admonition:"admonition",blockquote:"blockquote",code:"code",em:"em",h2:"h2",h3:"h3",h4:"h4",hr:"hr",img:"img",li:"li",ol:"ol",p:"p",pre:"pre",strong:"strong",ul:"ul",...(0,r.R)(),...e.components},{Details:i}=s;return i||function(e,s){throw new Error("Expected "+(s?"component":"object")+" `"+e+"` to be defined: you likely forgot to import, pass, or provide it.")}("Details",!0),(0,l.jsxs)(l.Fragment,{children:[(0,l.jsx)(s.p,{children:"\u968f\u7740\u6280\u672f\u7684\u4e0d\u65ad\u53d1\u5c55\uff0c\u5c24\u5176\u662f\u79fb\u52a8\u8bbe\u5907\u7684\u666e\u53ca\u548c\u79fb\u52a8\u4e92\u8054\u7f51\u7684\u53d1\u5c55\uff0c\u4f7f\u5f97\u52a8\u6001\u7f51\u9875\u5bf9\u4e8e\u65e5\u76ca\u590d\u6742\u7684\u9700\u6c42\u529b\u4e0d\u4ece\u5fc3\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u5177\u4f53\u5730\u6765\u8bf4\uff0c\u4e1a\u754c\u5f00\u59cb\u9700\u6c42Web\u7684\u201c\u5e94\u7528\u5316\u201d\uff0c\u4e5f\u5c31\u662f\u8981\u628a\u7f51\u9875\u53d8\u6210\u4e00\u4e2a\u5e94\u7528\u7a0b\u5e8f\uff1a\u5728\u4ee5\u524d\uff0c\u6211\u4eec\u4ecb\u7ecd\u7684\u52a8\u6001\u7f51\u9875\u6280\u672f\u53ef\u4ee5\u5f88\u597d\u5730\u652f\u6301\u535a\u5ba2\uff0c\u8bba\u575b\uff0c\u65b0\u95fb\u7f51\u7ad9\uff0c\u4f01\u4e1a\u5b98\u7f51\u7b49\uff1b\u800c\u73b0\u5728\uff0c\u6211\u4eec\u9700\u8981\u5728\u6d4f\u89c8\u5668\u4e0a\u5199\u6587\u4ef6(\u817e\u8baf\u6587\u6863)\uff0c\u804a\u5929(Discord),\u76f4\u64ad\uff0c\u70b9\u5916\u5356,\u73a9\u6e38\u620f(\u5b9e\u9645\u4e0a\uff0c\u5f88\u591a\u624b\u673aAPP\u90fd\u662f\u6d4f\u89c8\u5668\u5957\u58f3\uff0c\u672c\u8d28\u4e0a\u5c31\u662f\u5411\u4f60\u5c55\u793a\u4e00\u4e2a\u7f51\u9875\uff1b\u5305\u62ec\u5fae\u4fe1\u5c0f\u7a0b\u5e8f\uff0c\u4e5f\u662f\u4e00\u4e2a\u53ea\u53ef\u4ee5\u4f7f\u7528\u5fae\u4fe1\u5185\u7f6e\u6d4f\u89c8\u5668\u6253\u5f00\u7684\u7f51\u7ad9)"}),"\n",(0,l.jsx)(s.p,{children:"\u90a3\u4e9b\u5f00\u53d1APP\u7684\u7a0b\u5e8f\u5458\u4e5f\u5f88\u4e50\u610f\u628a\u81ea\u5df1\u7684\u9879\u76ee\u642c\u5230\u6d4f\u89c8\u5668\u91cc\uff0c\u56e0\u4e3a\u7528HTML+CSS\u5199GUI\u975e\u5e38\u65b9\u4fbf\uff0c\u800c\u4e14Web\ud83d\ude07\u5177\u6709\u8de8\u5e73\u53f0\u7684\u7279\u6027\uff1a\u4f60\u9700\u8981\u4ed8\u51fa\u5f88\u591a\u52aa\u529b\u624d\u80fd\u786e\u4fdd\u4e00\u4e2a\u4f20\u7edfAPP\u80fd\u5728\u624b\u673a\uff0c\u7535\u8111\uff0cMacOS,Windows,Linux\u4e0a\u8fd0\u884c\uff0c\u4f46\u662f\u4f60\u5199\u7f51\u9875\u53ea\u9700\u8981\u5f88\u8f7b\u677e\u5730\u5199\uff0c\u4e0d\u7528\u8003\u8651\u517c\u5bb9\uff0c\u6d4f\u89c8\u5668\u4f1a\u786e\u4fdd\u4f60\u7684\u7f51\u9875\u5728\u8fd9\u4e9b\u5e73\u53f0\u4e0a\u90fd\u80fd\u8fd0\u884c\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u5305\u62ec\u6211\u4eec\u7684\u62a5\u4fee\u7cfb\u7edf\uff0c\u4e5f\u7b97\u662f\u4e00\u4e2aWeb\u5e94\u7528\u3002Web\u5e94\u7528\u76f8\u6bd4\u4f20\u7edf\u7684\u9ad8\u7ea7\u52a8\u6001\u7f51\u9875\u6709\u5982\u4e0b\u7279\u5f81\uff1a"}),"\n",(0,l.jsxs)(s.ul,{children:["\n",(0,l.jsx)(s.li,{children:"\u9875\u9762\u5c11\uff1a\u52a8\u6001\u7f51\u9875\u53ef\u80fd\u8981\u6709\u6210\u5343\u4e0a\u767e\u4e2a\u9875\u9762\uff0c\u6240\u4ee5\u5fc5\u987b\u4f7f\u7528\u6a21\u677f\u52a8\u6001\u751f\u6210\u3002\u800c\u5e94\u7528\u7a0b\u5e8f\u53ef\u80fd\u53ea\u6709\u51e0\u4e2a\u6216\u8005\u51e0\u5341\u4e2a\u754c\u9762\u3002"}),"\n",(0,l.jsx)(s.li,{children:"\u9ad8\u4ea4\u4e92\uff1a\u52a8\u6001\u7f51\u9875\u7684\u4e3b\u8981\u76ee\u7684\u662f\u4f9b\u4eba\u89c2\u770b\uff0c\u7528\u6237\u7684\u4ea4\u4e92\uff08\u4f8b\u5982\u70b9\u51fb\u94fe\u63a5\uff0c\u6309\u94ae\u7b49\uff09\u6bd4\u8f83\u5c11\u4e14\u7b80\u5355\u3002\u800cWeb\u5e94\u7528\u4e2d\uff0c\u7528\u6237\u7684\u4ea4\u4e92\u975e\u5e38\u9891\u7e41\u4e14\u590d\u6742\u3002\u524d\u540e\u7aef\u901a\u4fe1\u66f4\u52a0\u9891\u7e41\u3002"}),"\n",(0,l.jsx)(s.li,{children:"\u90e8\u5206\u66f4\u65b0\uff1a\u52a8\u6001\u7f51\u9875\u5728\u4e0d\u540c\u9875\u9762\u4e4b\u95f4\u4e5f\u6709\u4e0d\u53d8\u7684\u5185\u5bb9\uff0c\u6bd4\u5982\u9875\u5934\u9875\u811a\u4e4b\u7c7b\u7684\uff0c\u4f46\u662f\u8fd9\u4e9b\u5185\u5bb9\u53ea\u5360\u7f51\u9875\u7684\u5c11\u90e8\u5206\uff1b\u5728\u5e94\u7528\u7a0b\u5e8f\u4e2d\uff0c\u9875\u9762\u7684\u7edd\u5927\u90e8\u5206\u5143\u7d20\u90fd\u6ca1\u6709\u600e\u4e48\u53d8\u5316\uff0c\u53ea\u6709\u5c11\u90e8\u5206\u6570\u636e\u4f1a\u53d1\u751f\u53d8\u5316\uff0c\u8fd9\u65f6\u5019\uff0c\u6bcf\u66f4\u65b0\u4e00\u6b21\u6570\u636e\u5c31\u8bf7\u6c42\u4e00\u6b21\u65b0\u9875\u9762\u5c31\u5341\u5206\u6d6a\u8d39\u4e86\u3002"}),"\n"]}),"\n",(0,l.jsx)(s.p,{children:"Web\u5e94\u7528\u7a0b\u5e8f\u7684\u8fd9\u4e9b\u9700\u6c42\u90fd\u662f\u6211\u4eec\u4e4b\u524d\u4ecb\u7ecd\u7684\u52a8\u6001\u7f51\u9875\u6280\u672f\u6240\u4e0d\u597d\u6ee1\u8db3\u7684\uff0c\u4e8e\u662fWeb\u5f00\u53d1\u8fdb\u5165\u4e86\u4e00\u4e2a\u65b0\u65f6\u671f\uff1a"}),"\n",(0,l.jsx)(s.h2,{id:"ajax\u4e0e\u524d\u540e\u7aef\u5206\u79bb",children:"AJAX\u4e0e\u524d\u540e\u7aef\u5206\u79bb"}),"\n",(0,l.jsx)(s.h3,{id:"javascript",children:"JavaScript"}),"\n",(0,l.jsx)(s.p,{children:"\u4e4b\u524d\u6211\u4eec\u4e00\u76f4\u5728\u4ecb\u7ecd\u670d\u52a1\u5668\u7684\u6280\u672f\uff0c\u800c\u4e00\u76f4\u5ffd\u7565\u4e86\u6d4f\u89c8\u5668\u7684\u53d1\u5c55\u3002\u5b9e\u9645\u4e0a\uff0c\u6d4f\u89c8\u5668\u4e5f\u6162\u6162\u53d8\u5f97\u590d\u6742\uff0c\u4e5f\u5728\u6162\u6162\u8fdb\u884c\u6280\u672f\u6f14\u8fdb\u3002"}),"\n",(0,l.jsxs)(s.p,{children:['\u57281995\u5e74\uff0c\u4e5f\u5c31\u662f\u5dee\u4e0d\u591a\u540e\u7aef\u5904\u4e8eSSI\u548cCGI\u7684\u65f6\u4ee3\uff0c\u7f51\u666f\u516c\u53f8\u7684\u5458\u5de5\u53d1\u660e\u4e86\u4e00\u79cd\u7f16\u7a0b\u8bed\u8a00\uff0c\u53eb\u505a"JavaScript",\u8fd9\u662f\u5bf9\u5f53\u65f6\u65b0\u5174\u7684Java Applet\u7684\u56de\u5e94\u3002Java Applet\u53ef\u4ee5\u8ba9\u4f60\u5728\u6d4f\u89c8\u5668\u8fd0\u884cJava\u4ee3\u7801\uff0c\u548c\u5b83\u540c\u4e00\u751f\u6001\u4f4d\u7684\u4e00\u4e2a\u6280\u672f\u5927\u5bb6\u5e94\u8be5\u5f88\u719f\u6089',":Flash","\uff0c\u4e0d\u8fc7\u5b83\u4eec\u540e\u6765\u90fd\u88ab\u6dd8\u6c70\u4e86\u3002"]}),"\n",(0,l.jsx)(s.p,{children:"JavaScript\u4f5c\u4e3aJava Applet\u7684\u7ade\u4e89\u8005\uff0c\u662f\u4e13\u95e8\u8bbe\u8ba1\u51fa\u6765\u5728\u6d4f\u89c8\u5668\u5185\u8fd0\u884c\u7684\u811a\u672c\u8bed\u8a00\u3002\u8fde\u540d\u5b57\u90fd\u662f\u5728\u8e6dJava\u7684\u70ed\u5ea6:)\u7f51\u666f\u6d4f\u89c8\u5668(\u4e5f\u5c31\u662f\u706b\u72d0\u6d4f\u89c8\u5668\u7684\u524d\u8eab)\u4e3aJavaScript\u63d0\u4f9b\u4e86\u4e00\u4e2a\u5f3a\u5927\u7684\u80fd\u529b\uff1a\u52a8\u6001\u5730\u6539\u53d8\u5f53\u524d\u9875\u9762HTML\u548cCSS\u7684\u5185\u5bb9\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u53e6\u5916\uff0c\u6d4f\u89c8\u5668\u8fd8\u4e3aJavaScript\u63d0\u4f9b\u4e86\u53d1\u8d77HTTP\u8bf7\u6c42\u7684\u63a5\u53e3\uff0c\u4e0d\u53ea\u662fGET\u8bf7\u6c42\u3002\u8fd9\u672c\u662f\u975e\u5e38\u5f3a\u5927\u7684\u529f\u80fd\uff0c\u4e0d\u8fc7\uff0c\u7531\u4e8eJavaScript\u65e9\u671f\u8bed\u6cd5\u6df7\u4e71\uff0c\u518d\u52a0\u4e0a\u5f53\u65f6\u4eba\u4eec\u5bf9\u4e8e\u524d\u7aef\u80fd\u529b\u9700\u6c42\u5e76\u4e0d\u662f\u592a\u5927\uff0c\u6240\u4ee5\u76f4\u52302010\u5e74\u5de6\u53f3\uff0c\u524d\u7aef\u548cJavaScript\u624d\u88ab\u91cd\u89c6\u8d77\u6765\u3002\u4e5f\u5c31\u662f\u6211\u4eec\u63a5\u4e0b\u6765\u7684\u5185\u5bb9\uff1a"}),"\n",(0,l.jsx)(s.h3,{id:"ajax",children:"AJAX"}),"\n",(0,l.jsx)(s.p,{children:"\u4f20\u7edf\u7684\u52a8\u6001\u7f51\u9875\u6709\u4e00\u4e2a\u4e0d\u7075\u6d3b\u7684\u7279\u6027\uff1a\u6bcf\u6b21\u53ea\u80fd\u8fd4\u56de\u4e00\u4e2a\u5b8c\u6574\u7684\u9875\u9762\u3002\u4e5f\u5c31\u662f\u8bf4\uff0c\u8981\u4e48\u4e0d\u66f4\u65b0\u7f51\u9875\uff0c\u8981\u4e48\u5c31\u5168\u90e8\u66f4\u65b0\uff0c\u6ca1\u529e\u6cd5\u66f4\u65b0\u73b0\u6709\u7f51\u9875\u7684\u4e00\u90e8\u5206\u3002"}),"\n",(0,l.jsx)(s.p,{children:'\u6bd4\u5982\u6211\u4eec\u6709\u4e00\u4e2a\u5728\u6587\u7ae0\u4e0b\u9762\u8bc4\u8bba\u7684\u529f\u80fd\uff1a\u7528\u6237\u9700\u8981\u5728\u6587\u672c\u6846\u91cc\u8f93\u5165\u8bc4\u8bba\uff0c\u7136\u540e\u70b9\u51fb"\u53d1\u5e03\u8bc4\u8bba"\u7684\u6309\u94ae\u3002\u5982\u679c\u521b\u5efa\u6210\u529f\uff0c\u90a3\u4e48\u6211\u4eec\u5e94\u8be5\u8ba9\u7528\u6237\u770b\u5230"\u8bc4\u8bba\u6210\u529f"\u7684\u63d0\u793a\u5e76\u4e14\u5728\u8bc4\u8bba\u533a\u663e\u793a\u7528\u6237\u6700\u65b0\u8bc4\u8bba\u7684\u5185\u5bb9\uff1b\u5982\u679c\u5931\u8d25\u4e5f\u8981\u63d0\u793a\u6709\u5173\u7684\u4fe1\u606f\u3002'}),"\n",(0,l.jsx)(s.p,{children:"\u4f20\u7edf\u7684\u52a8\u6001\u7f51\u9875\u53ea\u80fd\u8fd9\u4e48\u505a\uff1a\u8fd4\u56de\u4e00\u4e2a\u5b8c\u6574\u7684\u7f51\u9875\uff0c\u8fd9\u4e2a\u7f51\u9875\u548c\u7528\u6237\u4e4b\u524d\u7684\u7f51\u9875\u7684\u5927\u90e8\u5206\u5185\u5bb9\u6ca1\u6709\u533a\u522b\uff0c\u53ea\u662f\u591a\u4e86\u63d0\u793a\u7684\u4fe1\u606f\u548c\u65b0\u7684\u8bc4\u8bba\u3002\u4f46\u5b9e\u9645\u4e0a\uff0c\u9875\u9762\u7684\u6709\u6548\u4fe1\u606f\u53ea\u6709\u90a3\u4e00\u90e8\u5206\u3002\u8fd9\u6781\u5927\u5730\u6d6a\u8d39\u4e86\u7f51\u7edc\u5e26\u5bbd\u548c\u670d\u52a1\u5668\u6027\u80fd(\u56e0\u4e3a\u8981\u91cd\u65b0\u6e32\u67d3)\u3002"}),"\n",(0,l.jsx)(s.p,{children:'AJAX(Asynchronous JavaScript and XML)\u5c31\u662f\u89e3\u51b3\u8fd9\u4e00\u75db\u70b9\u7684\u6280\u672f\uff0c\u65e2\u7136JavaScript\u53ef\u4ee5\u52a8\u6001\u5730\u4fee\u6539\u9875\u9762\u5185\u5bb9\uff0c\u53d1\u9001HTTP\u8bf7\u6c42\uff0c\u90a3\u4e48\u5c31\u76f4\u63a5\u8ba9JavaScript\u7a0b\u5e8f\u53d1\u9001\u5e26\u6709\u8bc4\u8bba\u5185\u5bb9\u7684POST\u8bf7\u6c42\u5230\u670d\u52a1\u5668\uff0c\u7136\u540e\u670d\u52a1\u5668\u8fd4\u56de\u7eaf\u6570\u636e(\u901a\u5e38\u4f7f\u7528JSON\u6216XML\u7684\u683c\u5f0f\uff0c\u628a\u6570\u636e\u7528\u683c\u5f0f\u5305\u88c5\u8d77\u6765\u6709\u4e00\u4e2a\u672f\u8bed\uff0c\u53eb\u505a"\u5e8f\u5217\u5316")\u800c\u4e0d\u662fHTML\uff0c\u9001\u7ed9JavaScript\u7a0b\u5e8f\u800c\u4e0d\u662f\u6d4f\u89c8\u5668\uff0cJavaScript\u6839\u636e\u8fd4\u56de\u7684\u64cd\u4f5cHTML\u6216CSS\uff0c\u5b9e\u73b0\u7f51\u9875\u90e8\u5206\u66f4\u65b0\u7684\u6548\u679c\u3002'}),"\n",(0,l.jsx)(s.p,{children:'AJAX\u7684\u6838\u5fc3\u5728\u4e8e"\u5f02\u6b65"\uff0c\u6d4f\u89c8\u5668\u53d1\u9001\u8bf7\u6c42\u540e\uff0c\u4e0d\u4f1a\u7b49\u5f85\u540e\u7aef\u8fd4\u56de\u6570\u636e\uff0c\u800c\u662f\u5141\u8bb8\u7528\u6237\u7ee7\u7eed\u6d4f\u89c8\u3002\u5373\u662f\u6307\u5728\u53d1\u8bc4\u8bba\u65f6\uff0c\u9875\u9762\u4e0d\u4f1a\u6574\u4e2a\u5237\u65b0\u4e00\u4e0b\u7684\u7279\u6027\u3002'}),"\n",(0,l.jsx)(s.h3,{id:"\u4e00\u4e2aajax\u62a5\u540d\u7cfb\u7edf\u7684\u4f8b\u5b50",children:"\u4e00\u4e2aAJAX\u62a5\u540d\u7cfb\u7edf\u7684\u4f8b\u5b50"}),"\n",(0,l.jsx)(s.p,{children:"\u4e0b\u9762\u4e3e\u4e00\u4e2a\u4f8b\u5b50\uff0c\u6765\u8be6\u7ec6\u8bf4\u660eAJAX\u7684\u5de5\u4f5c\u539f\u7406\uff1a\u7528\u6237\u9700\u8981\u901a\u8fc7\u4e00\u4e2a\u7f51\u9875\u8fdb\u884c\u67d0\u9879\u6d3b\u52a8\u7684\u62a5\u540d\uff0c\u586b\u5199\u4e2a\u4eba\u4fe1\u606f\uff0c\u7136\u540e\u70b9\u51fb\u7f51\u9875\u4e0a\u7684\u63d0\u4ea4\u6309\u94ae\uff0c\u670d\u52a1\u7aef\u4f1a\u8fd4\u56de\u62a5\u540d\u7684\u7ed3\u679c\uff0c\u6210\u529f\u8fd8\u662f\u5931\u8d25\uff0c\u4e0e\u4f20\u7edf\u7684\u65b9\u6cd5\u4e0d\u540c\uff0c\u670d\u52a1\u5668\u8fd4\u56de\u4fe1\u606f\u65f6\u4e0d\u662f\u91cd\u65b0\u8fd4\u56de\u4e00\u4e2aHTML,\u800c\u662f\u8ba9\u6d4f\u89c8\u5668\u76f4\u63a5\u5728\u539f\u6709\u7684\u754c\u9762\u4e0a\uff08\u6bd4\u5982\u63d0\u4ea4\u6309\u94ae\u7684\u4e0b\u9762\uff09\u663e\u793a\u62a5\u540d\u7684\u72b6\u6001\u3002"}),"\n",(0,l.jsxs)(s.p,{children:["\u7528\u6237\u901a\u8fc7\u6d4f\u89c8\u5668\u8f93\u5165\u5730\u5740\uff0c\u4f7f\u7528",(0,l.jsx)(s.code,{children:"GET"}),"\u65b9\u6cd5\u53d1\u8d77\u5bf9",(0,l.jsx)(s.code,{children:"http://example.org/submit"}),"\u7684\u8bf7\u6c42\uff0c\u670d\u52a1\u5668\u7a0b\u5e8f\u83b7\u5f97\u8bf7\u6c42\u540e\uff0c\u5728\u8def\u7531\u8868\u4e2d\u67e5\u5f97",(0,l.jsx)(s.code,{children:"/submit"}),"\u8fd9\u4e2a\u8def\u5f84\u5339\u914d\u9759\u6001\u6587\u4ef6",(0,l.jsx)(s.code,{children:"/static/submit.html"}),"\uff0c\u4e8e\u662f\u5c06\u6587\u4ef6\u53d1\u9001\u7ed9\u6d4f\u89c8\u5668\uff1b"]}),"\n",(0,l.jsxs)(s.p,{children:["\u6d4f\u89c8\u5668\u5f97\u5230\u6587\u4ef6\u540e\u5f00\u59cb\u89e3\u6790\u6e32\u67d3\u8fd9\u4e2a\u6587\u4ef6\uff0c\u53d1\u73b0\u8fd9\u4e2ahtml\u5728\u5934\u90e8\u53c8\u8981\u6c42\u6d4f\u89c8\u5668\u5411\u670d\u52a1\u5668\u83b7\u53d6",(0,l.jsx)(s.code,{children:"submit.js"}),"\u6587\u4ef6\u548c",(0,l.jsx)(s.code,{children:"submit.css"}),"\u6587\u4ef6\uff0c\u4e8e\u662f\u6d4f\u89c8\u5668\u4e0d\u9700\u8981\u7528\u6237\u5904\u7406\u81ea\u5df1\u53c8\u53d1\u9001\u4e86\u4e24\u6761",(0,l.jsx)(s.code,{children:"GET"}),"\u7684HTTP Request,\u5728\u6587\u4ef6\u8fd4\u56de\u540e\uff0c\u6d4f\u89c8\u5668\u81ea\u52a8\u6267\u884c\u8fd4\u56de\u7684\u811a\u672c\u5e76\u5e94\u7528CSS\u6837\u5f0f\u3002\u811a\u672c\u7684\u5185\u5bb9\u662f\u76d1\u542chtml\u6587\u4ef6\u4e2d\u63d0\u4ea4\u6309\u94ae\u7684\u201c\u70b9\u51fb\u201d\u4e8b\u4ef6\uff0c\u5f53\u6309\u94ae\u88ab\u70b9\u51fb\u65f6\uff0c\u6267\u884c\u63d0\u4ea4\u62a5\u540d\u8868\u51fd\u6570\u3002"]}),"\n",(0,l.jsx)(s.p,{children:"\u8fd4\u56de\u7684html\u6587\u4ef6\u5305\u62ec\u4e86\u63d0\u793a\u6846\uff0c\u8981\u6c42\u7528\u6237\u8f93\u5165\u59d3\u540d\uff0c\u624b\u673a\uff0c\u7a7a\u95f2\u65f6\u95f4\u7b49\u4fe1\u606f\uff0c\u5728\u8fd9\u4e9b\u8f93\u5165\u680f\u7684\u6700\u4e0b\u9762\u6709\u4e00\u4e2a\u63d0\u4ea4\u6309\u94ae\uff0c\u5f53\u70b9\u51fb\u8fd9\u4e2a\u6309\u94ae\u65f6\uff0c\u811a\u672c\u4e2d\u7684\u6307\u5b9a\u51fd\u6570\u5c31\u4f1a\u88ab\u6fc0\u6d3b\uff0c\u8fd9\u4e2a\u51fd\u6570\u5c06\u8bfb\u53d6\u7528\u6237\u4ece\u4e0a\u9762\u8f93\u5165\u8fdb\u6765\u7684\u5185\u5bb9\uff0c\u505a\u4e00\u4e9b\u7b80\u5355\u7684\u8ba4\u8bc1\uff08\u6bd4\u5982\u8bf4\u624b\u673a\u53f7\u7684\u683c\u5f0f\u7b49\uff09\uff0c\u5982\u679c\u68c0\u9a8c\u5931\u8d25\u5219\u8ba9\u7528\u6237\u91cd\u65b0\u586b\u5199\u4fe1\u606f\u3002"}),"\n",(0,l.jsxs)(s.p,{children:["\u5982\u679c\u68c0\u9a8c\u6210\u529f\uff0c\u5219\u5c06\u8fd9\u4e9b\u4fe1\u606f\u7ec4\u7ec7\u6210\u4e00\u4e2aJSON\u6587\u4ef6\uff08\u867d\u7136AJAX\u4e2d\u7684X\u5c31\u662fXML\uff0c\u4f46\u662f\u73b0\u5728\u5176\u5b9e\u6700\u5e38\u7528JSON\uff09\uff0c\u5411\u670d\u52a1\u5668\u53d1\u9001\u4e00\u4e2a",(0,l.jsx)(s.code,{children:"POST"}),"\u8bf7\u6c42\uff0c\u5730\u5740\u662f",(0,l.jsx)(s.code,{children:"http://example.org/api/submit"}),",\u5728\u8bf7\u6c42\u4f53\u4e2d\u5305\u542b\u521a\u624d\u7684JSON\u6587\u4ef6\u3002"]}),"\n",(0,l.jsxs)(s.p,{children:["\u670d\u52a1\u5668\u5728\u63a5\u6536\u8fd9\u4e2a\u8bf7\u6c42\u540e\uff0c\u5728\u8def\u7531\u6a21\u5757\u4e2d\u67e5\u5f97\u8fd9\u4e2aURL\u5339\u914d",(0,l.jsx)(s.code,{children:"HandleTicket()"}),"\u51fd\u6570\uff0c\u4e8e\u662f\u8fd9\u4e2a\u8bf7\u6c42\u7684\u4e0a\u4e0b\u6587\u5168\u90e8\u8f6c\u4ea4\u7ed9",(0,l.jsx)(s.code,{children:"HandleTicket()"}),"\u8fd9\u4e2a\u51fd\u6570\uff0c\u51fd\u6570\u4f1a\u521b\u5efa\u4e00\u4e2a",(0,l.jsx)(s.code,{children:"Ticket"}),"\u7c7b\u7684\u5b9e\u4f8b\uff0c\u5c06\u6570\u636e\u505a\u540e\u7aef\u68c0\u9a8c\u540e\u8d4b\u7ed9\u5b9e\u4f8b\u7684\u6210\u5458\uff0c\u5982\u679c\u68c0\u9a8c\u6210\u529f\u5219\u8c03\u7528\u65b9\u6cd5",(0,l.jsx)(s.code,{children:"Ticket.Create()"}),"\u5f55\u5165\u6570\u636e\u5e93\uff0c\u5e76\u5411\u5ba2\u6237\u7aef(\u5728\u8fd9\u91cc\u6307JavaScript\u811a\u672c\uff0c\u800c\u4e0d\u662f\u7528\u6237)\u53d1\u9001\u56de\u5e94\u6210\u529f\u7684\u72b6\u6001\u7801(200)\uff1b"]}),"\n",(0,l.jsx)(s.p,{children:"\u68c0\u9a8c\u7684\u5185\u5bb9\u9664\u4e86\u5197\u4f59\u68c0\u67e5\u683c\u5f0f\u662f\u5426\u5408\u6cd5\u4e4b\u5916\uff0c\u8fd8\u8981\u6267\u884c\u4e1a\u52a1\u903b\u8f91\u65b9\u9762\u7684\u68c0\u67e5\uff1a"}),"\n",(0,l.jsxs)(s.ul,{children:["\n",(0,l.jsx)(s.li,{children:"\u4e00\u4e2a\u4eba\u53ea\u51c6\u62a5\u540d\u4e00\u6b21\uff0c\u6240\u4ee5\u5982\u679c\u6570\u636e\u5e93\u4e2d\u5b58\u5728\u201c\u59d3\u540d\u201d\u5b57\u6bb5\u76f8\u540c\u7684\u8bb0\u5f55\u7684\u8bdd\uff0c\u68c0\u9a8c\u5219\u4e0d\u901a\u8fc7(\u8fd9\u4e2a\u53ea\u662f\u4e2a\u4f8b\u5b50\uff0c\u6240\u4ee5\u4e0d\u8003\u8651\u91cd\u540d\u7684\u60c5\u51b5)"}),"\n",(0,l.jsx)(s.li,{children:"\u5982\u679c\u6211\u4eec\u6d3b\u52a8\u7684\u65f6\u95f4\u7684\u8303\u56f4\u6ca1\u6709\u5305\u542b\u5728\u7a7a\u95f2\u65f6\u95f4\u7684\u8303\u56f4\u5185\uff0c\u68c0\u9a8c\u5219\u4e0d\u901a\u8fc7\uff0c\u56e0\u4e3a\u7528\u6237\u7684\u65f6\u95f4\u548c\u6211\u4eec\u6d3b\u52a8\u7684\u65f6\u95f4\u51b2\u7a81"}),"\n",(0,l.jsx)(s.li,{children:"\u5982\u679c\u6570\u636e\u5e93\u4e2d\u7684\u8bb0\u5f55(\u8868\u793a\u62a5\u540d\u6210\u529f\u7684\u7528\u6237)\u5927\u4e8e\u6216\u7b49\u4e8e\u6211\u4eec\u8bbe\u5b9a\u7684\u6570\u5b57\u7684\u8bdd\uff0c\u68c0\u9a8c\u5219\u4e0d\u901a\u8fc7\uff0c\u56e0\u4e3a\u4eba\u591f\u4e86"}),"\n"]}),"\n",(0,l.jsx)(s.p,{children:"\u5982\u679c\u68c0\u9a8c\u6ca1\u6709\u6210\u529f\uff0c\u5219\u56de\u5e94\u5931\u8d25\u7684\u6d88\u606f\uff0c\u9664\u4e86\u4f9d\u636e\u5931\u8d25\u7684\u7c7b\u578b\u8bbe\u7f6e\u5bf9\u5e94\u7684\u9519\u8bef\u7801\u5916\uff0c\u8fd8\u8981\u8fd4\u56de\u4e00\u4e2aJSON\u6587\u4ef6\u6765\u7b80\u8ff0\u9519\u8bef\u4fe1\u606f\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u62a5\u540d\u6210\u529f\u7684\u6d88\u606f\u7684\u793a\u4f8b\uff1a"}),"\n",(0,l.jsx)(s.pre,{children:(0,l.jsx)(s.code,{className:"language-JSON",metastring:'title="StatusCode:201 Created"',children:'\n\n\n{\n "status":"success",\n "submit":{\n "name":"\u5c0f\u660e",\n "freeAt":"2023-11-25_15:00~19:00",\n "phone":12345678900\n },\n "createdAt":"2023-11-23_9:23:22"\n "message":"\u606d\u559c\uff01\u4f60\u5df2\u6210\u529f\u62a5\u540d\u6211\u4eec\u7684\u6d3b\u52a8"\n}\n\n'})}),"\n",(0,l.jsx)(s.p,{children:"\u62a5\u540d\u5931\u8d25\u7684\u6d88\u606f\u7684\u793a\u4f8b\uff1a"}),"\n",(0,l.jsx)(s.pre,{children:(0,l.jsx)(s.code,{className:"language-JSON",metastring:'title="StatusCode:400 Bad Request"',children:'\n{\n "status":"fail",\n "submit":{\n "name":"\u5c0f\u660e",\n "freeAt":"2023-11-25_9:00~15:00",\n "phone":12345678900\n },\n "createdAt":"2023-11-23_9:23:22"\n "message":"\u62b1\u6b49\uff0c\u4f60\u7684\u7a7a\u95f2\u65f6\u95f4\u4e0e\u6211\u4eec\u7684\u6d3b\u52a8\u65f6\u95f4\u6709\u51b2\u7a81"\n}\n\n'})}),"\n",(0,l.jsx)(s.p,{children:"\u5728JavaScript\u811a\u672c\u63a5\u6536\u5230\u56de\u5e94\u540e\uff0c\u6839\u636e\u8fd4\u56de\u7684\u5185\u5bb9\uff0c\u64cd\u4f5chtml\u6587\u4ef6\u7684\u5185\u5bb9\uff0c\u5728\u63d0\u4ea4\u6309\u94ae\u7684\u4e0b\u9762\u4e00\u884c\u63d2\u5165\u4e00\u4e2a\u6587\u672c\u5757\uff1a"}),"\n",(0,l.jsx)(s.p,{children:"\u62a5\u540d\u6210\u529f\u65f6\uff1a"}),"\n",(0,l.jsx)(s.pre,{children:(0,l.jsx)(s.code,{className:"language-HTML",children:'\n<div class="json_responses">\n <p class="json:message">\u606d\u559c\uff01\u4f60\u5df2\u6210\u529f\u62a5\u540d\u6211\u4eec\u7684\u6d3b\u52a8</p>\n <p>\u8bf7\u68c0\u67e5\u4f60\u7684\u4fe1\u606f\uff1a</p>\n <p class="json:submit.name">\u59d3\u540d\uff1a\u5c0f\u660e</p>\n <p class="json:submit.freeAt">\u7a7a\u95f2\u65f6\u95f4\uff1a2023-11-25 15:00\u81f319:00</p>\n <p class="json:submit.phone">\u624b\u673a\u53f7\uff1a12345678900</p>\n <p class="json:createdAt">\u670d\u52a1\u7aef\u63d0\u4ea4\u521b\u5efa\u65f6\u95f4\uff1a2023-11-23 9:23:22</p>\n</div>\n\n'})}),"\n",(0,l.jsx)(s.p,{children:"\u62a5\u540d\u5931\u8d25\u65f6\uff1a"}),"\n",(0,l.jsx)(s.pre,{children:(0,l.jsx)(s.code,{className:"language-HTML",children:'\n<div class="json_responses">\n <p class="json:message">\u62a5\u540d\u5931\u8d25\uff01\u62b1\u6b49\uff0c\u4f60\u7684\u7a7a\u95f2\u65f6\u95f4\u4e0e\u6211\u4eec\u7684\u6d3b\u52a8\u65f6\u95f4\u6709\u51b2\u7a81</p>\n <p>\u8bf7\u68c0\u67e5\u4f60\u7684\u4fe1\u606f\uff1a</p>\n <p class="json:submit.name">\u59d3\u540d\uff1a\u5c0f\u660e</p>\n <p class="json:submit.freeAt">\u7a7a\u95f2\u65f6\u95f4\uff1a2023-11-25 9:00\u81f315:00</p>\n <p class="json:submit.phone">\u624b\u673a\u53f7\uff1a12345678900</p>\n <p class="json:createdAt">\u670d\u52a1\u7aef\u63d0\u4ea4\u521b\u5efa\u65f6\u95f4\uff1a2023-11-23 9:23:22</p>\n</div>\n\n'})}),"\n",(0,l.jsx)(s.p,{children:"\u4f7f\u7528AJAX\u6280\u672f\uff0c\u7528\u6237\u4f1a\u53d1\u73b0\uff0c\u5728\u5199\u5b8c\u4fe1\u606f\u70b9\u51fb\u63d0\u4ea4\u6309\u94ae\u540e\uff0c\u9875\u9762\u6ca1\u6709\u53d8\u5316\uff0c\u8fc7\u4e861\u79d2\uff0c\u6309\u94ae\u4e0b\u9762\u51fa\u73b0\u4e86\u63d0\u793a\u4fe1\u606f\u3002\u8fd9\u7ed9\u7528\u6237\u7684\u4f53\u9a8c\u975e\u5e38\u50cf\u4f20\u7edf\u7684\u684c\u9762APP\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u5982\u679c\u4e0d\u4f7f\u7528AJAX\u6280\u672f\uff0c\u90a3\u4e48\u7528\u6237\u4f1a\u53d1\u73b0\u5728\u6309\u4e0b\u6309\u94ae\u540e\uff0c\u7f51\u9875\u4f1a\u767d\u5c4f\u5237\u65b0\u4e00\u6bb5\u65f6\u95f4\uff0c\u8fc7\u4e86\u51e0\u79d2\uff0c\u8fd4\u56de\u4e86\u4e00\u4e2a\u65b0\u9875\u9762\uff0c\u63d0\u793a\u4e86\u62a5\u540d\u72b6\u6001\u4fe1\u606f\u3002\u8fd9\u6837\u7684\u5e94\u7528\u867d\u7136\u4e0d\u662f\u4e0d\u80fd\u7528\uff0c\u4f46\u662f\u7528\u6237\u4f53\u9a8c\u603b\u662f\u4e0d\u5982AJAX\u6765\u7684\u65e0\u7f1d\uff0c\u81ea\u7136\u3002\u6027\u80fd\u4e5f\u4e0d\u597d\u3002"}),"\n",(0,l.jsx)(s.h3,{id:"api\u9a71\u52a8\u4e0e\u524d\u540e\u7aef\u5206\u79bb",children:"API\u9a71\u52a8\u4e0e\u524d\u540e\u7aef\u5206\u79bb"}),"\n",(0,l.jsx)(s.p,{children:"\u5728\u4e0a\u9762\u90a3\u4e2a\u4f8b\u5b50\u91cc\uff0c\u670d\u52a1\u5668\u5e76\u6ca1\u6709\u8fd4\u56deHTML\uff0c\u800c\u662f\u8fd4\u56de\u7eaf\u6570\u636e\uff0c\u4ea4\u7ed9\u524d\u7aef\u6e32\u67d3\u3002\u65e2\u7136\u6d4f\u89c8\u5668\u81ea\u5df1\u5c31\u80fd\u6839\u636e\u6570\u636e\u6e32\u67d3HTML\uff0c\u90a3\u4e48\u540e\u7aef\u4e5f\u5c31\u6ca1\u5fc5\u8981\u8fd4\u56de\u6210\u54c1HTML\u4e86\u3002"}),"\n",(0,l.jsxs)(s.p,{children:['\u53ef\u4ee5\u53d1\u73b0\uff0c\u8fd9\u5b9e\u9645\u4e0a\u5c31\u662f\u628aMVC\u67b6\u6784\u4e2d\u7684"Views"\u90e8\u5206\u63a8\u7ed9\u4e86\u524d\u7aef\uff0c\u540e\u7aef\u53ea\u9700\u8981\u901a\u8fc7HTTP\u4f20\u9012\u6570\u636e\u7ed9\u524d\u7aefJavaScript,\u524d\u7aefJavaScript\u518d\u6e32\u67d3\u6210HTML\u3002\u540e\u7aef\u8fd4\u56de\u7eaf\u6570\u636e\uff0c\u7531\u524d\u7aef\u6e32\u67d3\u7684\u6a21\u5f0f\u79f0\u4e4b\u4e3a',(0,l.jsx)(s.strong,{children:"\u524d\u540e\u7aef\u5206\u79bb"}),"\uff1b"]}),"\n",(0,l.jsxs)(s.p,{children:['\u800c\u8fd9\u6837\u8fd4\u56de\u6570\u636e\u7684URL\u4e5f\u4e0d\u80fd\u79f0\u4e4b\u4e3a"\u7f51\u9875"\u4e86\uff0c\u56e0\u4e3a\u5b83\u4ece\u7ed9\u4eba\u770b\u53d8\u6210\u4e86\u7ed9JavaScript\u7a0b\u5e8f\u770b\uff0c\u8fd9\u6837\u7684URL\u5b9e\u9645\u4e0a\u53d8\u6210\u4e86\u524d\u7aef\u7a0b\u5e8f\u548c\u540e\u7aef\u7a0b\u5e8f\u8fd9\u4e24\u4e2a\u7a0b\u5e8f\u4e4b\u95f4\u4ea4\u4e92\u7684\u63a5\u53e3\uff0c\u6240\u4ee5\u8fd9\u79cdURL\u6211\u4eec\u79f0\u4e4b\u4e3a',(0,l.jsx)(s.strong,{children:"HTTP API"}),'\uff0c\u4e00\u4e2a\u4e3b\u8981\u662fAPI\u800c\u4e0d\u662fHTML\u7f51\u9875\u7684\u7f51\u7ad9\uff0c\u6211\u4eec\u79f0\u4e4b\u4e3a"API\u9a71\u52a8"\u7684\u7f51\u7ad9\u3002']}),"\n",(0,l.jsx)(s.h4,{id:"rest-api",children:"REST API"}),"\n",(0,l.jsxs)(s.p,{children:["\u4e0d\u77e5\u9053\u4f60\u8fd8\u8bb0\u5f97\u524d\u9762\u8bf4\u7684\u201c\u865a\u62df\u8def\u7531\u201d\u5417\uff1f\u8fd9\u88ab\u5e7f\u6cdb\u5730\u8fd0\u7528\u5728\u5982\u4eca\u7684API\u8bbe\u8ba1\u4e0b\uff0c\u6bd4\u5982\u8bf4\u6211\u8981\u83b7\u53d6\u67d0\u7bc7\u6587\u7ae0\u4e0b\u9762\u7684\u5168\u90e8\u8bc4\u8bba\uff0c\u8bc4\u8bba\u83b7\u53d6API\u53ef\u80fd\u662f\u8fd9\u6837\u7684\uff1a",(0,l.jsx)(s.code,{children:"GET http://example.org/api/getComments?article_id=123123"}),"\u3002"]}),"\n",(0,l.jsxs)(s.p,{children:["\u8fd9\u79cd\u8bbe\u8ba1\u6a21\u5f0f\u628a\u4e00\u4e2aURL\u770b\u4f5c\u4e00\u4e2a\u4e1a\u52a1\u7a97\u53e3\uff0c\u7a97\u53e3\u7684\u4f5c\u7528\u662f\u529e\u7406\u4e00\u4e2a\u4e1a\u52a1\uff0c\u5728\u8fd9\u4e2a\u4f8b\u5b50\u91cc",(0,l.jsx)(s.code,{children:"getComments"}),"\u529e\u7406\u7684\u4e1a\u52a1\u5c31\u662f\u201c\u83b7\u53d6\u8bc4\u8bba\u533a\u201d\uff0c\u975e\u5e38\u7684\u76f4\u89c2\u3002"]}),"\n",(0,l.jsx)(s.p,{children:"\u8fd9\u79cd\u9762\u5411\u4e1a\u52a1\u7684API\u8bbe\u8ba1\u5bf9\u4e8e\u5c0f\u89c4\u6a21\u9879\u76ee\u975e\u5e38\u65b9\u4fbf\uff0c\u5982\u679c\u4f60\u7684API\u63a5\u53e3\u53ea\u6709\u51e0\u5341\u4e2a\u7684\u8bdd\u90a3\u4f7f\u7528\u8fd9\u79cd\u8bbe\u8ba1\u4e5f\u65e0\u59a8\uff0c\u4e0d\u8fc7\u5982\u679c\u4f60\u7684\u4e1a\u52a1\u591a\u8d77\u6765\u7684\u7684\u8bdd\uff0c\u8fd9\u79cd\u8bbe\u8ba1\u662f\u975e\u5e38\u96be\u4ee5\u7ba1\u7406\u7684\u3002"}),"\n",(0,l.jsxs)(s.p,{children:["\u73b0\u4ee3\u7684API\u8bbe\u8ba1\u91c7\u7528\u9762\u5411\u8d44\u6e90\u7684\u8bbe\u8ba1\u6a21\u5f0f\uff0c\u628a\u4e00\u4e2aURL\u770b\u4f5c\u4e00\u4e2a\u8d44\u6e90\uff0c\u4f8b\u5982\u6211\u4eec\u91cd\u5199\u4e0a\u9762\u7684\u83b7\u53d6\u8bc4\u8bbaAPI:",(0,l.jsx)(s.code,{children:"GET http://example.org/article/123123/comments"})]}),"\n",(0,l.jsxs)(s.p,{children:["\u6587\u7ae0\u7684\u8bc4\u8bba\u662f\u4e00\u9879\u8d44\u6e90\uff0c\u4e00\u4e2aURL\u5c31\u662f\u83b7\u53d6\u8fd9\u4e2a\u8d44\u6e90\uff0c\u6587\u7ae0\u672c\u8eab\u4e5f\u662f\u4e00\u9879\u8d44\u6e90\uff0c\u5982\u679c\u6211\u4eec\u8981\u67e5\u770b\u6587\u7ae0\u5185\u5bb9\u7684\u8bdd\uff0c\u6211\u4eec\u53ef\u4ee5\u8fd9\u6837\u5199\uff1a",(0,l.jsx)(s.code,{children:"GET http://example.org/article/123123"}),",\u5982\u679c\u6211\u4eec\u8981\u4e0a\u4f20\u8bc4\u8bba\u7684\u8bdd\uff0c\u53ef\u4ee5\u5199",(0,l.jsx)(s.code,{children:"POST http://example.org/article/123123/comments"}),"\uff0c\u5728\u8bf7\u6c42\u4f53\u91cc\u9762\u5e26\u4e0a\u8bc4\u8bba\u3002\u83b7\u53d6\u548c\u4e0a\u4f20\u8bc4\u8bba\uff0cURL\u662f\u4e00\u6837\u7684\uff0c\u53ea\u662f\u65b9\u6cd5\u4e0d\u4e00\u6837\uff0c\u8fd9\u5c31\u5229\u7528\u4e86HTTP\u65b9\u6cd5\uff1a\u4f8b\u5982\uff0c\u8981\u5220\u9664\u8bc4\u8bba\u533a\u4e0b\u7684\u7b2c15\u6761\u8bc4\u8bba\u7684\u8bdd\uff0c\u53ef\u4ee5\u8fd9\u6837\u5199\uff1a",(0,l.jsx)(s.code,{children:"DELETE http://example.org/article/123123/comments/15"})]}),"\n",(0,l.jsxs)(s.p,{children:["\u5982\u679c\u6211\u4eec\u8981\u83b7\u53d6\u8bc4\u8bba\u533a\u4e0b\u67d0\u4e2a\u7528\u6237\u53d1\u8fc7\u7684\u5176\u4ed6\u8bc4\u8bba\u7684\u8bdd\uff0c\u6211\u4eec\u53ef\u4ee5\u8fd9\u4e48\u5199:",(0,l.jsx)(s.code,{children:"GET http://example.org/user/456456/comments"}),"\uff0c\u6838\u5fc3\u601d\u60f3\u662f\uff0c\u4e00\u4e2aURL\u662f\u4e00\u4e2a\u8d44\u6e90\uff0c\u65b9\u6cd5\u662f\u5bf9\u8d44\u6e90\u7684\u64cd\u4f5c\u3002"]}),"\n",(0,l.jsx)(s.p,{children:"\u4f60\u770b\uff0c\u8fd9\u6709\u70b9\u50cf\u4f20\u7edf\u7684\u6587\u4ef6\u7cfb\u7edf\u8def\u7531\uff0c\u4f46\u662f\u8fd9\u662f\u5b8c\u5168\u5728\u540e\u7aef\u7a0b\u5e8f\u91cc\u5b9e\u73b0\u7684\u865a\u62df\u7684\u201c\u6587\u4ef6\u8d44\u6e90\u7cfb\u7edf\u201d\uff0c\u5728URL\u540e\u5bf9\u5e94\u7684\u5e76\u4e0d\u662f\u6587\u4ef6\uff0c\u800c\u662f\u548c\u6570\u636e\u5e93\u6253\u4ea4\u9053\u7684Model\u677f\u5757\u51fd\u6570\u3002\u8fd9\u79cd\u65b9\u5f0f\uff0c\u5c31\u662f\u6240\u8c13\u7684REST\uff0c\u4ee5\u8fd9\u79cd\u65b9\u5f0f\u8bbe\u8ba1\u7684API,\u5c31\u53ebREST API\u3002"}),"\n",(0,l.jsx)(s.p,{children:"GitHub\u7684API\u8bbe\u8ba1\u53ef\u4ee5\u8bf4\u662fREST\u98ce\u683c\u7684\u5178\u8303\uff0c\u4f60\u53ef\u4ee5\u62bd\u7a7a\u770b\u770b\u3002"}),"\n",(0,l.jsx)(s.h2,{id:"\u5355\u9875\u5e94\u7528spa",children:"\u5355\u9875\u5e94\u7528(SPA)"}),"\n",(0,l.jsx)(s.p,{children:'API\u9a71\u52a8\u67b6\u6784\u53d1\u5c55\u5230\u6781\u81f4\u5c31\u662f\u6240\u8c13\u7684"\u5355\u9875\u5e94\u7528"\uff0c\u987e\u540d\u601d\u4e49\uff0c\u670d\u52a1\u5668\u53ea\u4f1a\u5728\u7528\u6237\u6253\u5f00\u7f51\u9875\u65f6\u52a0\u8f7d\u4e00\u6bb5html\u6587\u4ef6\u548c\u4e00\u4e9bJavaScript\u811a\u672c(\u4e5f\u5c31\u662f\u4e00\u4e2a\u9875\u9762)\uff0c\u540e\u9762\u7684\u5168\u90e8\u5185\u5bb9\u90fd\u662f\u901a\u8fc7JavaScript\u52a8\u6001\u66f4\u65b0\u7684\u3002JavaScript\u548c\u670d\u52a1\u5668\u7684\u540e\u7aef\u63a5\u53e3\u4ea4\u4e92\u4e3b\u8981\u5c31\u662f\u91c7\u7528AJAX\u3002\u73b0\u4ee3\u7f51\u7ad9\uff0c\u6216\u8005\u8bf4Web\u5e94\u7528\uff0c\u901a\u5e38\u6d41\u884c\u8fd9\u79cd\u5355\u9875\u5e94\u7528\u67b6\u6784\u3002'}),"\n",(0,l.jsx)(s.p,{children:"\u5355\u9875\u5e94\u7528\u7684\u574f\u5904\u5c31\u662f\u6253\u7834\u4e86\u4e3a\u9759\u6001\u7f51\u9875\u6587\u4ef6\u8bbe\u8ba1\u7684\u201c\u6536\u85cf\u201d\u529f\u80fd\u548c\u524d\u8fdb\u540e\u9000\uff0c\u4e5f\u4e0d\u5229\u4e8eSEO\u548c\u65e0\u969c\u788d\uff0c\u56e0\u4e3a\u7528\u6237\u5728\u7f51\u7ad9\u4e0a\u53ea\u6253\u5f00\u4e00\u4e2a\u7f51\u9875\uff0c\u7f51\u9875\u7684\u5185\u5bb9\u6839\u636e\u7528\u6237\u64cd\u4f5c\u7531\u6d4f\u89c8\u5668\u811a\u672c\u52a8\u6001\u66f4\u65b0\uff0c\u800c\u751f\u6210\u7684html\u4e5f\u5927\u591a\u6ca1\u6709\u505a\u8bed\u4e49\u5316\u4f18\u5316\uff0c\u96be\u4ee5\u88ab\u7406\u89e3\u548c\u89e3\u6790\u3002\u5f53\u7136\u8fd9\u4e9b\u95ee\u9898\u6709\u89e3\u51b3\u65b9\u6848\uff0c\u4e0b\u9762\u4f1a\u8bb2\u5230\u3002"}),"\n",(0,l.jsx)(s.p,{children:"SPA\u7684\u4f8b\u5b50\u5c31\u662f\u90ae\u7bb1\u5e94\u7528\uff08\u6bd4\u5982Gmail\uff09,\u901a\u8fc7\u6d4f\u89c8\u5668\u8bbf\u95ee\u4f60\u7684\u90ae\u7bb1\uff0c\u901a\u8fc7\u90ae\u7bb1\u7684\u4e3b\u9875\u9762\u70b9\u67d0\u4e2a\u90ae\u4ef6\uff0c\u4f60\u5e76\u6ca1\u6709\u8fdb\u5165\u4e00\u4e2a\u65b0\u7684\u9875\u9762\uff0c\u800c\u662f\u5728\u539f\u6709\u7684\u9875\u9762\u4e0a\uff0c\u5185\u5bb9\u53d8\u6210\u4e86\u90ae\u4ef6\u67e5\u770b\u7684\u754c\u9762\uff0c\u5982\u679c\u5728\u4e3b\u9875\u9762\u4e0a\u70b9\u51fb\u53d1\u4ef6\u7684\u8bdd\uff0c\u540c\u6837\u4e5f\u6ca1\u6709\u4e00\u4e2a\u53d1\u4ef6\u9875\u9762\uff0c\u800c\u662f\u76f4\u63a5\u5448\u73b0\u53d1\u4ef6\u7684UI\u3002"}),"\n",(0,l.jsx)(s.h3,{id:"\u6846\u67b6",children:"\u6846\u67b6"}),"\n",(0,l.jsxs)(s.p,{children:['\u4f5c\u4e3a"\u5e94\u7528"\uff0cSPA\u662f\u5f88\u590d\u6742\u7684\uff0c\u6211\u4eec\u5f00\u53d1\u684c\u9762\u5e94\u7528\u4e5f\u4e0d\u662f\u4ece\u5e95\u5c42\u4e00\u8def\u9020\u8f6e\u5b50\uff0c\u800c\u662f\u7528Qt,GTK\u8fd9\u79cd\u6846\u67b6\uff0c\u540c\u6837Web\u5e94\u7528\u4e5f\u6709\u6846\u67b6\uff0c\u5176\u4e2d\u6700\u4e3b\u8981\u7684\u4e24\u4e2a\u5c31\u662f',(0,l.jsx)(s.code,{children:"Vue.js"}),"\u548c",(0,l.jsx)(s.code,{children:"React.js"}),"\uff0c\u8fd9\u4e9b\u6846\u67b6\u63d0\u4f9b\u4e86Web\u5e94\u7528\u9700\u8981\u7684\u79cd\u79cd\u529f\u80fd\uff0c\u6211\u4eec\u4ecb\u7ecd\u5176\u4e2d\u4e3b\u8981\u7684\u51e0\u4e2a\u65b9\u9762\uff1a"]}),"\n",(0,l.jsx)(s.h3,{id:"ui\u7ec4\u4ef6",children:"UI\u7ec4\u4ef6"}),"\n",(0,l.jsx)(s.p,{children:'SPA\u6846\u67b6\u901a\u5e38\u628a\u6574\u4e2a\u9875\u9762\u7684UI\u5206\u6210\u8bb8\u591a\u7684"\u7ec4\u4ef6"\uff0c\u5f53\u9875\u9762\u53d8\u5f97\u590d\u6742\u65f6\uff0c\u624b\u52a8\u7ba1\u7406DOM\u4f1a\u53d8\u5f97\u975e\u5e38\u7e41\u7410\u4e14\u5bb9\u6613\u51fa\u9519\u3002\u7ec4\u4ef6\u5219\u62bd\u8c61\u4e86\u590d\u6742\u7684DOM\uff0c\u4f7f\u5176\u53d8\u6210\u6709\u7ec4\u7ec7\uff0c\u6613\u7ef4\u62a4\uff0c\u53ef\u590d\u7528\u7684\u4e00\u4e2a\u4e2a\u5355\u5143\u3002'}),"\n",(0,l.jsx)(s.p,{children:'\u66f4\u91cd\u8981\u7684\u662f\uff0c\u4e3b\u6d41\u6846\u67b6\u63d0\u4f9b\u4e86"\u58f0\u660e\u5f0fUI\u7f16\u7a0b"\u7684\u65b9\u6cd5\uff0c\u8fd9\u4f7f\u5f97\u4f60\u50cf\u662f\u5728\u5199UI\u7684\u914d\u7f6e\u6587\u4ef6\uff0c\u800c\u4e0d\u662f\u64cd\u7eb5\u8fd9\u4e9bUI\u7684\u7a0b\u5e8f\uff1b\u4f60\u544a\u8bc9\u6846\u67b6"\u505a\u4ec0\u4e48"\uff0c\u800c\u4e0d\u662f"\u600e\u4e48\u505a"\uff0c\u6846\u67b6\u4f1a\u81ea\u52a8\u89e3\u6790\u4f60\u7684\u58f0\u660e\uff0c\u968f\u7740\u6570\u636e\u7684\u53d8\u5316\u81ea\u52a8\u66f4\u65b0UI\u7ec4\u4ef6\uff0c\u4f60\u8981\u505a\u7684\u5c31\u662f\u544a\u8bc9\u6846\u67b6\u5728\u67d0\u79cd\u6570\u636e\u72b6\u6001\u4e0b\u54ea\u4e2a\u7ec4\u4ef6\u9700\u8981\u662f\u600e\u4e48\u6837\u7684\u3002\u7528\u884c\u8bdd\u8bb2\u8fd9\u53eb\u505a"\u6570\u636e\u9a71\u52a8\u89c6\u56fe"\u3002'}),"\n",(0,l.jsx)(s.p,{children:"\u8fd9\u6837\uff0c\u5c31\u53ef\u4ee5\u8ba9\u5f00\u53d1\u8005\u53ef\u4ee5\u50cf\u642d\u79ef\u6728\u4e00\u6837\u6784\u5efa\u7528\u6237\u754c\u9762\uff0c\u5e76\u4e14\u5f53\u6570\u636e\u53d8\u5316\u65f6\uff0c\u6846\u67b6\u4f1a\u81ea\u52a8\u66f4\u65b0\u754c\u9762\uff0c\u6781\u5927\u5730\u63d0\u9ad8\u4e86\u5f00\u53d1\u6548\u7387\u3002"}),"\n",(0,l.jsx)(s.h3,{id:"\u865a\u62dfdom",children:"\u865a\u62dfDOM"}),"\n",(0,l.jsx)(s.p,{children:"\u5c3d\u7ba1JavaScript\u53ef\u4ee5\u52a8\u6001\u4fee\u6539DOM\uff0c\u4f46\u9891\u7e41\u5730\u76f4\u63a5\u64cd\u4f5c\u771f\u5b9eDOM\u662f\u975e\u5e38\u8017\u8d39\u6027\u80fd\u7684\u3002\u6bcf\u6b21DOM\u64cd\u4f5c\u90fd\u9700\u8981\u6d4f\u89c8\u5668\u91cd\u65b0\u6e32\u67d3\u4e00\u904d\u5168\u90e8\u5185\u5bb9\u3002\u5728\u590d\u6742\u6216\u6570\u636e\u9891\u7e41\u53d8\u5316\u7684\u754c\u9762\u4e2d\uff0c\u8fd9\u4f1a\u5bfc\u81f4\u9875\u9762\u5361\u987f\uff0c\u7528\u6237\u4f53\u9a8c\u4e0b\u964d\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u4e3a\u4e86\u89e3\u51b3\u8fd9\u4e2a\u95ee\u9898\uff0c\u8bb8\u591aSPA\u6846\u67b6\u5f15\u5165\u4e86\u865a\u62dfDOM\u7684\u6982\u5ff5\u3002\u865a\u62dfDOM\u662f\u4e00\u4e2a\u7f13\u51b2\u533a\uff1a\u5f53\u6570\u636e\u53d1\u751f\u53d8\u5316\u65f6\uff0c\u6846\u67b6\u4e0d\u4f1a\u76f4\u63a5\u4fee\u6539\u771f\u5b9eDOM\uff0c\u800c\u662f\u5148\u5728\u5185\u5b58\u4e2d\u6784\u5efa\u4e00\u4e2a\u65b0\u7684\u865a\u62dfDOM\u6811\uff0c\u7b49\u5230\u79ef\u7d2f\u5230\u4e00\u5b9a\u7684\u6539\u52a8\uff0c\u518d\u4e00\u6b21\u6027\u5e94\u7528\u5168\u90e8\u7684DOM\u64cd\u4f5c\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u8fd9\u79cd\u673a\u5236\u7684\u76ee\u7684\u662f\u5c06\u771f\u5b9e\u7684DOM\u64cd\u4f5c\u6b21\u6570\u964d\u5230\u6700\u4f4e\u3002\u8fd9\u663e\u8457\u4f18\u5316\u4e86\u6e32\u67d3\u6027\u80fd\uff0c\u5c24\u5176\u662f\u5728\u6570\u636e\u9891\u7e41\u53d8\u5316\u7684\u590d\u6742\u754c\u9762\u4e2d\uff0c\u865a\u62dfDOM\u80fd\u591f\u63d0\u4f9b\u66f4\u597d\u7684\u6027\u80fd\u3002\u53e6\u5916\u865a\u62dfDOM\u4e5f\u6709\u5229\u4e8e\u7ba1\u7406\u72b6\u6001\uff0c\u589e\u52a0\u6e05\u6670\u5ea6\uff1a"}),"\n",(0,l.jsx)(s.h3,{id:"\u72b6\u6001\u7ba1\u7406",children:"\u72b6\u6001\u7ba1\u7406"}),"\n",(0,l.jsx)(s.p,{children:"\u57fa\u4e8eWeb\u524d\u7aef\u6280\u672f\u6808\u7684\u5355\u9875\u5e94\u7528\u548c\u4f20\u7edf\u684c\u9762\u5e94\u7528\u7a0b\u5e8f\u6709\u4e00\u4e2a\u5f88\u5927\u7684\u4e0d\u540c\uff1a\u6e32\u67d3Web\u5e94\u7528\u754c\u9762\u6240\u57fa\u4e8e\u7684\u6570\u636e\u6709\u7740\u5f02\u6b65\u83b7\u53d6\uff0c\u5206\u6563\u6765\u6e90\u7684\u7279\u70b9\u3002\u5728\u6d41\u884c\u7684REST\u98ce\u683c\u7684API\u8bbe\u8ba1\u4e0b\uff0c\u670d\u52a1\u5668\u4e0d\u8d1f\u8d23\u8bb0\u5f55\u72b6\u6001\uff0c\u6240\u4ee5\u6574\u7406\u6570\u636e\uff0c\u7ef4\u6301\u72b6\u6001\u7684\u91cd\u4efb\u5c31\u5168\u90e8\u4ea4\u7531\u524d\u7aef\u8d1f\u8d23\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u504f\u504f\u524d\u7aef\u6280\u672f\u6808\u53c8\u4e0d\u662f\u4e3a\u5f00\u53d1\u8fd9\u79cd\u590d\u6742\u5e94\u7528\u800c\u8bde\u751f\u7684\uff1aHTML\u6700\u521d\u5c31\u662f\u4e00\u4e2a\u6807\u8bb0\u683c\u5f0f\u7684\u7b80\u5355\u673a\u5236\uff0cJavaScript\u6700\u521d\u88ab\u7528\u6765\u5199\u7b80\u5355\u7684\u811a\u672c\uff0c\u4e3a\u4e86\u4fdd\u6301\u517c\u5bb9\u6027\uff0c\u73b0\u4ee3\u6846\u67b6\u5fc5\u987b\u5728\u8fd9\u79cd\u57fa\u7840\u4e0a\u5f00\u53d1\uff0c\u800c\u4e0d\u662f\u91cd\u6784\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u4f5c\u4e3a\u524d\u7aef\u5f00\u53d1\u6838\u5fc3\u7684DOM\u5bf9\u8c61\uff0c\u5176\u672c\u8eab\u5c31\u662f\u4e00\u4e2a\u5de8\u5927\u7684\u5168\u5c40\u72b6\u6001\uff0c\u6240\u4ee5\u524d\u7aef\u5f00\u53d1\u5929\u751f\u6ca1\u6709\u9009\u62e9\u50cf\u4f20\u7edf\u684c\u9762\u5f00\u53d1\u90a3\u6837\u628a\u72b6\u6001\u653e\u5728\u5404\u4e2a\u5bf9\u8c61\u4e2d\u8fdb\u884c\u64cd\u4f5c\uff0c\u800c\u662f\u7ef4\u62a4\u4e00\u4e2a\u5168\u5c40\u7684\u72b6\u6001\uff0c\u4efb\u4f55\u64cd\u4f5c\u90fd\u662f\u5bf9\u8fd9\u4e2a\u5168\u5c40\u7684\u5bf9\u8c61\u8fdb\u884c\u64cd\u4f5c\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u8fd9\u79cd\u4e0d\u826f\u7684\u8bbe\u8ba1\u98ce\u683c\uff0c\u52a0\u4e0aRESTful API\u548cHTTP\u534f\u8bae\u7684\u65e0\u72b6\u6001\u7279\u6027,\u5bfc\u81f4\u524d\u7aef\u6280\u672f\u6808\u5929\u751f\u4e0d\u9002\u5408\u5f00\u53d1\u590d\u6742\u7684\u5e94\u7528\u7a0b\u5e8f\uff1a\u5f53\u5e94\u7528\u903b\u8f91\u53d8\u5f97\u590d\u6742\u65f6\uff0c\u901a\u8fc7\u76f4\u63a5\u64cd\u4f5cDOM\u6765\u66f4\u65b0\u89c6\u56fe\uff0c\u5c31\u6781\u6613\u5bfc\u81f4\u4ee3\u7801\u6df7\u4e71\uff0c\u72b6\u6001\u96be\u4ee5\u8ffd\u8e2a\uff0c\u5f88\u5bb9\u6613\u628a\u4ee3\u7801\u5199\u6210\u4e00\u5768\u6d46\u7cca\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u6b63\u5982\u524d\u9762\u63d0\u5230\u7684\uff0c\u6211\u4eec\u53c8\u4e0d\u80fd\u91cd\u6784\u6d4f\u89c8\u5668\u7684\u5e95\u5c42\u6280\u672f\u6808\uff0c\u6240\u4ee5\u5fc5\u987b\u5728\u8fd9\u4e00\u5c4e\u5c71\u4e0a\u6784\u5efa\u6211\u4eec\u7684\u9879\u76ee\u3002\u7531\u4e8e\u5728SPA\u4e0b\u4e0d\u518d\u5237\u65b0\u9875\u9762\uff0c\u524d\u7aef\u9700\u8981\u81ea\u5df1\u7ef4\u62a4\u4e00\u4e2a\u4e0eUI\u4fdd\u6301\u540c\u6b65\u7684\u6570\u636e\u72b6\u6001\u3002\u8fd9\u5c31\u8981\u8003\u8651\u5982\u4f55\u89e3\u8026\u6a21\u5757\u548c\u6570\u636e\u4e00\u81f4\u6027\u7684\u95ee\u9898\u4e86\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u8fd9\u672c\u6765\u53ef\u4ee5\u901a\u8fc7OOP+\u8bbe\u8ba1\u6a21\u5f0f\u89e3\u51b3\uff0c\u4e0d\u8fc7\u6211\u4eec\u8bf4\u8fc7\uff0cDOM\u7684\u5b58\u5728\u4f7f\u5f97\u7a0b\u5e8f\u5458\u8981\u8fce\u5408\u8fd9\u4e00\u6a21\u5f0f\uff0c\u5c06\u72b6\u6001\u4ee5\u5168\u5c40\u7684\u65b9\u5f0f\u4fdd\u5b58\uff0c\u7531\u5f02\u6b65\u6570\u636e\u6765\u5f02\u6b65\u64cd\u4f5cDOM\u4e5f\u5bb9\u6613\u5f15\u8d77\u6570\u636e\u7ade\u4e89\u3002\u8fd9\u5c31\u6781\u5927\u9650\u5236\u4e86OOP\u7684\u53d1\u6325\uff0c\u90a3\u8fd8\u6709\u4ec0\u4e48\u529e\u6cd5\u5462\uff1f"}),"\n",(0,l.jsxs)(s.p,{children:["\u4e8e\u662f\u51fd\u6570\u5f0f\u7f16\u7a0b(FP)\u8fd9\u4e2a\u5b66\u9662\u6d3e\u7684\u8303\u5f0f\u5c31\u8fdb\u5165\u4e86\u524d\u7aef\u7a0b\u5e8f\u5458\u7684\u89c6\u91ce\u3002FP\u5bf9\u4e8e\u524d\u7aef\u7684\u8fd9\u4e00\u75db\u70b9\u63d0\u4f9b\u4e86\u6781\u4f73\u7684\u89e3\u51b3\u65b9\u6848\u3002\u73b0\u5728\u6211\u4eec\u4e0d\u4fee\u6539\u539f\u72b6\u6001\uff0c\u800c\u662f\u521b\u5efa\u4e00\u4e2a\u65b0\u7684\u72b6\u6001\u66ff\u4ee3\u539f\u72b6\u6001(\u4e0d\u53ef\u53d8\u6570\u636e)\uff1b\u6211\u4eec\u7684\u51fd\u6570\uff0c\u73b0\u5728\u9664\u4e86\u8f93\u51fa\u6570\u636e\u5916\u4e0d\u8fdb\u884c\u4efb\u4f55\u7c7b\u4f3c\u4e8e",(0,l.jsx)(s.code,{children:"console.log()"}),"\u7684\u5176\u5b83\u64cd\u4f5c(\u7eaf\u51fd\u6570)\u3002\u7b49\u7b49\u8bf8\u5982\u6b64\u7c7b\u7684\u7f16\u7a0b\u601d\u60f3\u57fa\u672c\u4e0a\u6210\u4e3a\u4e86\u73b0\u4ee3\u524d\u7aef\u5f00\u53d1\u7684\u57fa\u77f3\u3002\u4f7f\u5f97SPA\u66f4\u5bb9\u6613\u89c4\u8303\u5f00\u53d1\u548c\u8c03\u8bd5\u3002"]}),"\n",(0,l.jsx)(s.p,{children:"\u624b\u5199FP\u6846\u67b6\u81ea\u7136\u4e0d\u592a\u597d\uff0c\u672c\u7740\u4e0d\u91cd\u590d\u9020\u8f6e\u5b50\u7684\u7cbe\u795e\uff0c\u524d\u7aef\u63d0\u4f9b\u4e86\u8bb8\u591a\u8df5\u884c\u7740FP\u8303\u5f0f\u7684\u72b6\u6001\u7ba1\u7406\u5e93\uff0c\u5e2e\u52a9\u524d\u7aef\u7a0b\u5e8f\u5458\u8fdb\u884c\u590d\u6742\u7a0b\u5e8f\u7684\u72b6\u6001\u7ba1\u7406\uff1bVue\u548cReact\u7684\u72b6\u6001\u7ba1\u7406\u6846\u67b6\u5206\u522b\u53ebVuex/Pinia(\u5728Vue3)\u548cRedux\u3002\u72b6\u6001\u7ba1\u7406\u662f\u73b0\u4ee3Web\u5e94\u7528\u524d\u7aef\u5f00\u53d1\u7684\u91cd\u8981\u90e8\u5206\u3002"}),"\n",(0,l.jsx)(s.admonition,{type:"info",children:(0,l.jsx)(s.p,{children:"\u8fd9\u4e2a\u90e8\u5206\u7684\u5185\u5bb9\u53ef\u80fd\u6709\u70b9\u96be\u4ee5\u7406\u89e3\uff0c\u4e0d\u8fc7\u7406\u89e3\u8fd9\u4e00\u90e8\u5206\u5bf9\u4e8e\u6210\u4e3a\u4e00\u4e2a\u4f18\u79c0\u7684\u524d\u7aef\u7a0b\u5e8f\u5458\u662f\u975e\u5e38\u91cd\u8981\u7684\u3002\u4f60\u4e5f\u53ef\u4ee5\u5728\u8fd9\u4e4b\u540e\u4e86\u89e3\u5173\u4e8eFP\u8303\u5f0f\u7684\u4e3b\u8981\u601d\u60f3\uff0c\u8fd9\u5bf9\u5f00\u53d1\u73b0\u4ee3\u548c\u4f18\u79c0\u7684\u7a0b\u5e8f\u662f\u5f88\u91cd\u8981\u7684\uff0c\u56e0\u4e3aFP\u662f\u7f16\u7a0b\u754c\u7684\u4e0b\u4e00\u4e2a\u6280\u672f\u6f6e\u6d41\uff0c\u6bd4\u5982Rust\uff0c\u5176\u8bbe\u8ba1\u5c31\u5927\u91cf\u53c2\u8003\u4e86FP\u601d\u60f3\uff0c\u751a\u81f3Rust\u65e9\u671f\u5c31\u662f\u7528OCaml\u5f00\u53d1\u7684\ud83d\ude03"})}),"\n",(0,l.jsx)(s.h3,{id:"\u524d\u7aef\u8def\u7531\u548c\u9996\u5c4f\u4f18\u5316",children:"\u524d\u7aef\u8def\u7531\u548c\u9996\u5c4f\u4f18\u5316"}),"\n",(0,l.jsx)(s.p,{children:"\u524d\u9762\u63d0\u5230SPA\u6253\u7834\u4e86\u6d4f\u89c8\u5668UX\u548c\u641c\u7d22\u5f15\u64ce\u5bf9\u7f51\u7ad9\u7684\u68c0\u6d4b\uff0c\u8fd9\u4e9b\u6846\u67b6\u63d0\u4f9b\u4e86API\u6765\u6539\u53d8\u5730\u5740\u680f\u4e2d\u7684\u5185\u5bb9\uff0c\u5bf9\u4e8e\u4e0d\u540c\u7684\u9875\u9762\u53ef\u4ee5\u8bbe\u7f6e\u4e0d\u540c\u7684URL\uff0c\u6765\u4f7f\u5f97\u903b\u8f91\u66f4\u52a0\u6e05\u6670\uff0c\u6536\u85cf\u680f\u4e5f\u53ef\u4ee5\u6b63\u5e38\u5730\u4f7f\u7528\u4e86\u3002"}),"\n",(0,l.jsxs)(s.p,{children:["SPA\u56e0\u4e3a\u9700\u8981\u521d\u59cb\u5316\u5927\u91cfJavaScript\u7a0b\u5e8f\uff0c\u5bf9\u4e8e\u7f51\u7edc\u8fde\u63a5\u6216\u8005\u8bbe\u5907\u6027\u80fd\u4e0d\u597d\u7684\u7528\u6237\uff0c\u4ed6\u4eec\u4f1a\u770b\u5230\u957f\u65f6\u95f4\u7684\u767d\u5c4f\uff0c\u9996\u5c4f\u4f18\u5316\u5c31\u662f\u5728\u4e00\u5f00\u59cb\u7684html\u4e2d\u52a0\u5165\u4e00\u4e9b\u4fe1\u606f\uff0c\u6bd4\u5982\u7ed9\u7528\u6237\u770b\u4e00\u4e2a",(0,l.jsx)(s.code,{children:"\u52a0\u8f7d\u4e2d..."}),"\u7684\u52a8\u753b\uff0c\u8ba9\u7528\u6237\u8010\u5fc3\u7b49\u5f85\u3002\u6216\u8005\u662f\u5728",(0,l.jsx)(s.code,{children:"head"}),"\u680f\u91cc\u653e\u4e00\u4e9b\u4fe1\u606f\uff0c\u4f7f\u5f97\u7f51\u7ad9\u53ef\u4ee5\u88ab\u641c\u7d22\u5f15\u64ce\u66f4\u597d\u5730\u641c\u5230\u3002"]}),"\n",(0,l.jsx)(s.h3,{id:"\u6784\u5efa\u7cfb\u7edf",children:"\u6784\u5efa\u7cfb\u7edf"}),"\n",(0,l.jsxs)(s.p,{children:["\u6d4f\u89c8\u5668\u5176\u5b9e\u5e76\u4e0d\u80fd\u76f4\u63a5\u7406\u89e3\u524d\u7aef\u6846\u67b6(Vue,React\u7b49)\u5199\u7684\u4ee3\u7801\u3002\u56e0\u4e3a\u5b83\u4eec\u5e76\u4e0d\u662f\u6807\u51c6JavaScript\uff0c\u5b83\u4eec\u542b\u6709\u5927\u91cf\u81ea\u5b9a\u4e49\u7684\u8bed\u6cd5\u3002\u56e0\u6b64\uff0c\u524d\u7aef\u5f00\u53d1\u5fc5\u987b\u8981\u628a\u4f7f\u7528\u4e86\u6846\u67b6\u7684\u4ee3\u7801",(0,l.jsx)(s.strong,{children:"\u7f16\u8bd1"}),"\u6210\u6d4f\u89c8\u5668\u53ef\u4ee5\u7406\u89e3\u7684HTML,CSS,JavaScript\u3002\u8bf7\u6ce8\u610f\uff0c\u7c7b\u4f3cJQuery\u8fd9\u6837\u7684\u5e93\u662f\u4e0d\u9700\u8981\u7f16\u8bd1\u7684\uff0c\u56e0\u4e3a\u5b83\u4eec\u5e76\u6ca1\u6709\u8d85\u51fa\u539f\u751f\u7684JavaScript\u529f\u80fd\u548c\u8bed\u6cd5\uff0c\u800c\u53ea\u662f\u4e00\u4e2a\u7c7b\u5e93\u3002\u4f60\u53ea\u9700\u8981\u5728\u4f60\u7684HTML\u91cc\u5305\u542b\u5b83\u4eec\u5c31\u53ef\u4ee5\u3002"]}),"\n",(0,l.jsx)(s.p,{children:"\u6784\u5efa\u7cfb\u7edf\u662f\u73b0\u4ee3\u524d\u7aef\u5f00\u53d1\u7684\u91cd\u8981\u4e00\u73af\uff0c\u9664\u4e86\u7f16\u8bd1\u9ad8\u7ea7JavaScript\u4ee3\u7801\u5916\uff0c\u6784\u5efa\u7cfb\u7edf\u901a\u5e38\u8fd8\u4f1a\u505a\u4e00\u4e9b\u6253\u5305\uff0c\u538b\u7f29\u7b49\u6742\u6d3b\uff1b\u8fd9\u662f\u73b0\u4ee3\u524d\u7aef\u5f00\u53d1\u5fc5\u4e0d\u53ef\u5c11\u7684\u4e00\u73af\u3002\u5e38\u7528\u7684\u6784\u5efa\u7cfb\u7edf\u6709Vite\u548cWebpack"}),"\n",(0,l.jsx)(s.hr,{}),"\n",(0,l.jsx)(s.p,{children:"JavaScript\u5e76\u4e0d\u662f\u5929\u751f\u5f00\u53d1\u590d\u6742\u5e94\u7528\u7684\u8bed\u8a00\uff0c\u6240\u4ee5SPA\u6846\u67b6\u63d0\u4f9b\u4e86\u90a3\u4e48\u591a\u7684\u673a\u5236\uff0c\u6765\u628a\u8fd9\u4e2a\u4e3a\u7b80\u5355\u811a\u672c\u8bbe\u8ba1\u7684\u8bed\u8a00\u53d8\u6210\u4e00\u4e2a\u8db3\u591f\u5f00\u53d1\u53ef\u9760Web\u5e94\u7528\u7684\u8bed\u8a00\uff0c\u5c3d\u7ba1\u4e00\u5c42\u4e00\u5c42\u7684\u5d4c\u5957\u62d6\u6162\u4e86\u6027\u80fd\uff0c\u4f46\u662fWeb\u7684\u6027\u80fd\u74f6\u9888\u901a\u5e38\u4e0d\u5728\u4e8e\u8ba1\u7b97\u800c\u662fI/O,\u52a0\u4e0a\u4e1a\u754c\u5927\u73af\u5883\u7684\u5404\u79cd\u56e0\u7d20,\u5bfc\u81f4\u4e86\u524d\u7aef\u57fa\u672c\u51e0\u5929\u5c31\u8981\u63a8\u51fa\u65b0\u6280\u672f\uff0c\u773c\u82b1\u7f2d\u4e71\u5c42\u51fa\u4e0d\u7a77\uff0c\u4f46\u662f\u8fd9\u4e9b\u6280\u672f\u5e95\u5c42\u90fd\u662f\u5dee\u4e0d\u591a\u7684\u3002\u91cd\u8981\u7684\u662f\u4e0d\u8981\u88ab\u5404\u79cd\u5ba3\u4f20\u8ff7\u60d1\u4e86\u8ba4\u77e5\uff0c\u800c\u8981\u8ba4\u6e05\u5b83\u4eec\u7684\u672c\u8d28\u3002"}),"\n",(0,l.jsx)(s.p,{children:(0,l.jsx)(s.img,{alt:"JavaScript fatigue",src:n(90053).A+"",width:"1323",height:"2425"})}),"\n",(0,l.jsxs)(s.blockquote,{children:["\n",(0,l.jsxs)(s.p,{children:['"JavaScript Fatigue"\uff0c\u56fe\u6e90',(0,l.jsx)(s.a,{href:"https://auth0.com/blog/how-to-manage-javascript-fatigue/",children:"Auth0\u535a\u5ba2"})]}),"\n"]}),"\n",(0,l.jsx)(s.h2,{id:"javascript\u5168\u6808",children:"JavaScript\u5168\u6808"}),"\n",(0,l.jsx)(s.h3,{id:"nodejs",children:"Node.js"}),"\n",(0,l.jsxs)(s.p,{children:["\u524d\u9762\u63d0\u5230\uff0cJavaScript\u662f\u4e13\u95e8\u8bbe\u8ba1\u8fd0\u884c\u5728\u6d4f\u89c8\u5668\u4e2d\u7684\u8bed\u8a00\uff0c\u4e5f\u5c31\u662f\u8bf4\uff0cJavaScript\u7684\u8fd0\u884c\u65f6\u5c31\u662f\u6d4f\u89c8\u5668\uff0c\u4e0d\u8fc7JavaScript\u4e5f\u6709\u6d4f\u89c8\u5668\u4e4b\u5916\u7684\u8fd0\u884c\u65f6\uff0c\u6700\u51fa\u540d\u7684\u53eb\u505a",(0,l.jsx)(s.code,{children:"Node.js"}),"\uff1b"]}),"\n",(0,l.jsx)(s.p,{children:"\u7b80\u5355\u6765\u8bf4\uff0cNode.js \u8ba9JavaScript\u8d70\u51fa\u4e86\u6d4f\u89c8\u5668\uff0c\u53ef\u4ee5\u76f4\u63a5\u5728\u670d\u52a1\u5668\u4e0a\u8fd0\u884c\u4e86\u3002\u8fd9\u610f\u5473\u7740\uff0c\u5f00\u53d1\u8005\u53ef\u4ee5\u7528\u540c\u4e00\u79cd\u8bed\u8a00\uff08JavaScript\uff09\u6765\u7f16\u5199\u524d\u7aef\uff08\u7528\u6237\u5728\u6d4f\u89c8\u5668\u91cc\u770b\u5230\u7684\u754c\u9762\uff09\u548c\u540e\u7aef\uff08\u670d\u52a1\u5668\u4e0a\u5904\u7406\u6570\u636e\u7684\u903b\u8f91\uff09\uff0c\u8fd9\u5c31\u662f\u6240\u8c13\u7684\u2018JavaScript\u5168\u6808\u2019\u5f00\u53d1\u3002\u5e38\u89c1\u7684JavaScript\u540e\u7aef\u6846\u67b6\u6709Express.js Koa.js Nest.js\u3002"}),"\n",(0,l.jsx)(s.h3,{id:"web\u5f00\u53d1\u4e4b\u5916",children:"Web\u5f00\u53d1\u4e4b\u5916"}),"\n",(0,l.jsx)(s.p,{children:"Node.js\u80fd\u505a\u7684\u4e5f\u4e0d\u53ea\u662fWeb\u5f00\u53d1\uff0c\u4f20\u7edf\u7f16\u7a0b\u8bed\u8a00\u53ef\u4ee5\u505a\u7684Node.js\u90fd\u53ef\u4ee5\uff0c\u5728Web\u5916\u6700\u91cd\u8981\u7684\u9886\u57df\u5c31\u662f\u684c\u9762\u5f00\u53d1\u4e86\uff0c\u901a\u5e38\u4f7f\u7528Electron\u6846\u67b6\uff0c\u53ef\u4ee5\u8ba9\u4f60\u4f7f\u7528HTML,CSS\u6765\u7f16\u5199GUI\u754c\u9762\uff0c\u7528JavaScript\u6765\u64cd\u4f5c\u754c\u9762\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u56e0\u4e3a\u4f9d\u8d56\u95ee\u9898\uff0c\u901a\u5e38\u6bcf\u4e2aElectron App \u90fd\u6253\u5305\u4e86\u81ea\u5df1\u7684Node.js\u8fd0\u884c\u65f6\uff0c\u6bcf\u5b89\u88c5\u4e00\u4e2aApp\uff0c\u5c31\u76f8\u5f53\u4e8e\u5b89\u88c5\u4e86\u4e00\u4e2a\u6d4f\u89c8\u5668\u5185\u6838\u3002\u8fd9\u4e25\u91cd\u6d6a\u8d39\u4e86\u7535\u8111\u7684\u5185\u5b58\u548c\u786c\u76d8\u7a7a\u95f4\uff0c\u4f46\u597d\u5904\u5c31\u662f\u65b9\u4fbf\u4e86\u5f00\u53d1\u3002\u4f1a\u5199Web\u5c31\u80fd\u505a\u684c\u9762\u5f00\u53d1\uff0c\u964d\u4f4e\u4e86\u5b66\u4e60\u6210\u672c\uff0c\u4e5f\u66f4\u65b9\u4fbf\u8de8\u5e73\u53f0\u3002"}),"\n",(0,l.jsx)(s.h2,{id:"\u6700\u65b0\u6280\u672f",children:"\u6700\u65b0\u6280\u672f"}),"\n",(0,l.jsx)(s.h3,{id:"websocket",children:"WebSocket"}),"\n",(0,l.jsx)(s.p,{children:"HTTP\u5df2\u7ecf\u5f88\u597d\u4e86\uff0c\u4f46\u662f\u534f\u8bae\u672c\u8eab\u6709\u4e00\u4e2a\u7f3a\u70b9:\u4e00\u4e2aHTTP\u8fde\u63a5\u5206\u4e3a\u8bf7\u6c42\u548c\u54cd\u5e94\uff0c\u53ea\u80fd\u7531\u5ba2\u6237\u7aef\u53d1\u8d77\u8bf7\u6c42\uff0c\u670d\u52a1\u7aef\u8fd4\u56de\u54cd\u5e94\uff0c\u5982\u679c\u5ba2\u6237\u7aef\u6ca1\u6709\u5148\u53d1\u4e00\u70b9\u4ec0\u4e48\u7ed9\u670d\u52a1\u7aef\u7684\u8bdd\uff0c\u670d\u52a1\u7aef\u662f\u6ca1\u529e\u6cd5\u5148\u7ed9\u5ba2\u6237\u7aef\u53d1\u4fe1\u606f\u7684\uff0c\u8fd9\u5c31\u7ed9\u4e00\u4e9b\u66f4\u52a0\u590d\u6742\u7684\u8981\u6c42\u589e\u6dfb\u4e86\u969c\u788d\uff1a\u6bd4\u5982\u901a\u8fc7\u6d4f\u89c8\u5668\u548c\u522b\u4eba\u804a\u5929\uff0c\u9700\u8981\u63a5\u53d7\u6765\u81ea\u670d\u52a1\u5668\u53d1\u7ed9\u4f60\u7684\u5176\u4ed6\u4eba\u7684\u804a\u5929\u7684\u4fe1\u606f\uff1b\u6216\u8005\u662f\u5728\u6d4f\u89c8\u5668\u4e0a\u73a9\u6e38\u620f\uff0c\u9700\u8981\u548c\u670d\u52a1\u5668\u4ea4\u6362\u6570\u636e\u3002\u8fd9\u53ef\u4ee5\u901a\u8fc7\u8f6e\u8be2\u6765\u89e3\u51b3\uff0c\u4f46\u662f\u8fd9\u6837\u8fd8\u662f\u4e0d\u65b9\u4fbf\uff0c\u6548\u7387\u4e5f\u8f83\u4f4e\u3002"}),"\n",(0,l.jsx)(s.p,{children:"WebSocket\u662f\u4e00\u4e2a\u5168\u65b0\u7684\u534f\u8bae\uff0c\u652f\u6301\u5ba2\u6237\u7aef\u548c\u670d\u52a1\u5668\u7684\u5168\u53cc\u5de5\u901a\u4fe1\uff0c\u5373\u5ba2\u6237\u7aef\u548c\u670d\u52a1\u5668\u90fd\u53ef\u4ee5\u4e3b\u52a8\u5730\u53d1\u6d88\u606f\uff0c\u800c\u4e14\u53ef\u4ee5\u540c\u65f6\u8fdb\u884c\uff0c\u800c\u4e14\u662f\u91c7\u7528\u8f83\u5c0f\u7684\u6570\u636e\u5e27\u683c\u5f0f\uff0c\u964d\u4f4e\u4e86\u7f51\u7edc\u5f00\u9500\uff0c\u63d0\u9ad8\u4e86\u6570\u636e\u4f20\u8f93\u901f\u5ea6\u3002WebSocket\u5728\u5efa\u7acb\u8fde\u63a5\u540e\u4fdd\u6301\u957f\u65f6\u95f4\u6709\u6548\uff0c\u4e0d\u9700\u8981\u4e3a\u6bcf\u6b21\u6d88\u606f\u53d1\u9001\u91cd\u65b0\u5efa\u7acb\u8fde\u63a5\uff0c\u56e0\u6b64\u6548\u7387\u66f4\u9ad8\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u4e3a\u4e86\u517c\u5bb9HTTP\u534f\u8bae\uff0cWebSocket\u4e5f\u662f\u76d1\u542c80\u548c443\u7aef\u53e3(HTTPS),\u63e1\u624b\u91c7\u7528\u4e86HTTP\u534f\u8bae\uff0c\u901a\u8fc7\u5347\u7ea7\u534f\u8bae\u6765\u5efa\u7acb\u8fde\u63a5\uff0c\u5982\u679c\u53ef\u4ee5\u5347\u7ea7\uff0c\u670d\u52a1\u5668\u4f1a\u8fd4\u56de101\u72b6\u6001\u7801\uff0c\u5347\u7ea7\u8fde\u63a5."}),"\n",(0,l.jsx)(s.h3,{id:"webassembly",children:"WebAssembly"}),"\n",(0,l.jsx)(s.p,{children:"WebAssembly\u662f\u6700\u8fd1\u65b0\u51fa\u73b0\u7684\u6280\u672f\uff0c\u4ed6\u5141\u8bb8\u5f00\u53d1\u8005\u5c06C/C++ , Rust\u7b49\u539f\u672c\u7684\u4e00\u4e9b\u7f16\u8bd1\u578b\u8bed\u8a00\u7f16\u8bd1\u6210\u6d4f\u89c8\u5668\u53ef\u4ee5\u6267\u884c\u7684\u5b57\u8282\u7801\uff0c\u4f7f\u5f97\u5728\u6d4f\u89c8\u5668\u4e2d\u4e5f\u53ef\u4ee5\u6267\u884c\u8fd9\u4e9b\u7a0b\u5e8f\uff0c\u76ee\u524d\u4e5f\u6709\u4e00\u4e9b\u4f7f\u7528WebAssembly\u7684\u5e94\u7528\uff0c\u53ef\u4ee5\u53bb\u770b\u770b\uff0c\u6700\u5927\u7684\u597d\u5904\u5c31\u662f\u4e0d\u4f1aJavaScript\u4e5f\u80fd\u5f00\u53d1\u524d\u7aef\uff0c\u4e5f\u53ef\u4ee5\u590d\u7528\u4ee5\u524d\u4e3a\u684c\u9762\u5199\u7684\u4ee3\u7801\u3002\u8fd9\u8fd8\u662f\u4e00\u4e2a\u975e\u5e38\u65b0\u5174\u7684\u9886\u57df\uff0c\u503c\u5f97\u6280\u672f\u6295\u8d44\ud83d\ude04"}),"\n",(0,l.jsx)(s.h2,{id:"\u603b\u7ed3\u4e0e\u8d44\u6e90",children:"\u603b\u7ed3\u4e0e\u8d44\u6e90"}),"\n",(0,l.jsx)(s.p,{children:"Web\u7684\u5386\u53f2\u603b\u5171\u7ecf\u5386\u4e86\u4e09\u4e2a\u9636\u6bb5\uff1a\u9996\u5148\u4e3a\u4e86\u4f20\u8f93\u57fa\u672c\u6587\u4ef6\u800c\u53d1\u660e\u4e86HTTP\uff0c\u4e3a\u4e86\u65b9\u4fbf\u5730\u9884\u89c8\u6587\u6863\u800c\u53d1\u660e\u4e86HTML\u548cCSS\uff0c\u8fd9\u662fWeb\u7684\u9759\u6001\u7f51\u9875\u7684\u65f6\u4ee3\uff1b\u4e3a\u4e86\u7ed9\u9759\u6001\u7f51\u9875\u589e\u52a0\u52a8\u6001\u5185\u5bb9\uff0c\u6279\u91cf\u751f\u6210\u8bb8\u591a\u7684\u7f51\u9875\uff0c\u4eba\u4eec\u53d1\u660e\u4e86\u52a8\u6001\u7f51\u9875\u6280\u672f\uff0c\u5f62\u6210\u4e86\u540e\u7aef\u7a0b\u5e8f\u7684\u6982\u5ff5\uff0c\u8fd9\u662f\u52a8\u6001\u7f51\u9875\u7684\u65f6\u4ee3\uff1b\u4e3a\u4e86\u8ba9\u5ba2\u6237\u7aef\u6d4f\u89c8\u5668\u66f4\u52a0\u5f3a\u5927\uff0c\u7ed9\u540e\u7aef\u51cf\u8d1f\uff0c\u4eba\u4eec\u53d1\u660e\u4e86JavaScript\uff0c\u53c8\u642d\u5efa\u4e86\u590d\u6742\u7684Web\u5e94\u7528\u7a0b\u5e8f\uff0c\u5f62\u6210\u4e86\u524d\u7aef\u7a0b\u5e8f\u7684\u6982\u5ff5\uff0c\u8fd9\u662fWeb\u7684\u5e94\u7528\u7a0b\u5e8f\u65f6\u4ee3\u3002"}),"\n",(0,l.jsx)(s.p,{children:"\u867d\u7136\u6280\u672f\u53d8\u5f97\u8d8a\u6765\u8d8a\u590d\u6742\uff0c\u4f46\u662f\u53d1\u5c55\u7684\u8109\u7edc\u662f\u53ef\u4ee5\u6293\u4f4f\u7684\uff1aWeb\u7531\u4e8e\u5176\u7279\u6027\uff0c\u88ab\u4eba\u4eec\u627f\u8f7d\u4e86\u8d8a\u6765\u8d8a\u9ad8\u7684\u671f\u671b\uff1a\u4ece\u64cd\u4f5c\u6587\u4ef6\uff0c\u5230\u6d4f\u89c8\u4fe1\u606f\uff0c\u5230\u6210\u719f\u7684\u5e94\u7528\u7a0b\u5e8f\u5e73\u53f0\u3002\u6700\u91cd\u8981\u7684\u662f\u77e5\u9053Web\u7684\u8bf8\u591a\u540d\u8bcd\uff0c\u6982\u5ff5\uff0c\u6280\u672f\u5e76\u4e0d\u662f\u7a81\u7136\u51fa\u73b0\u7684\uff0c\u800c\u662f\u7ecf\u5386\u4e86\u534a\u4e2a\u4e16\u7eaa\u7684\u5386\u53f2\u6c89\u6dc0\uff0c\u5b83\u4eec\u4e5f\u4e0d\u662f\u4e3a\u4e86\u521b\u65b0\u800c\u521b\u65b0\uff0c\u6bcf\u4e2a\u6280\u672f\u80fd\u591f\u51fa\u73b0\u5e76\u53d7\u5230\u6b22\u8fce\uff0c\u4e00\u5b9a\u662f\u56e0\u4e3a\u89e3\u51b3\u4e86\u67d0\u4e2a\u75db\u70b9\u624d\u6709\u4e86\u4ef7\u503c\u3002"}),"\n",(0,l.jsx)(s.h3,{id:"\u7f16\u5e74\u53f2",children:"\u7f16\u5e74\u53f2"}),"\n",(0,l.jsx)(s.p,{children:"\u6309\u7167\u65f6\u95f4\u987a\u5e8f\u603b\u7ed3\u5bf9Web\u610f\u4e49\u91cd\u5927\u7684\u6280\u672f\uff1a"}),"\n",(0,l.jsxs)(i,{children:[(0,l.jsx)("summary",{children:"\u7f16\u5e74\u53f2(AI\u5199\u7684\uff0c\u53ef\u80fd\u6709\u70b9\u5c0f\u9519\u8bef)"}),(0,l.jsx)("h3",{id:"-1966-1990-",children:"\u65e9\u671f (1966-1990)"}),(0,l.jsxs)("ul",{children:[(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1966\u5e74"}),(0,l.jsx)("p",{children:" \u4e92\u8054\u7f51\u7684\u524d\u8eab\u201c\u963f\u5e15\u7f51\u201d (ARPANET) \u7acb\u9879: \u7f8e\u56fd\u56fd\u9632\u90e8\u9ad8\u7ea7\u7814\u7a76\u8ba1\u5212\u5c40\uff08ARPA\uff09\u542f\u52a8\u4e86\u963f\u5e15\u7f51\u9879\u76ee\uff0c\u65e8\u5728\u7814\u7a76\u80fd\u591f\u5728\u90e8\u5206\u7f51\u7edc\u906d\u5230\u7834\u574f\u540e\u4ecd\u80fd\u7ef4\u6301\u901a\u4fe1\u7684\u8ba1\u7b97\u673a\u7f51\u7edc\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1969\u5e74"}),(0,l.jsx)("p",{children:" \u963f\u5e15\u7f51\u9996\u6b21\u6210\u529f\u901a\u4fe1: 10\u670829\u65e5\uff0c\u963f\u5e15\u7f51\u4e0a\u7684\u7b2c\u4e00\u6761\u6d88\u606f\u6210\u529f\u4ece\u52a0\u5dde\u5927\u5b66\u6d1b\u6749\u77f6\u5206\u6821\uff08UCLA\uff09\u53d1\u9001\u5230\u65af\u5766\u798f\u7814\u7a76\u9662\uff08SRI\uff09\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1983\u5e74"}),(0,l.jsx)("p",{children:" TCP/IP\u534f\u8bae\u6210\u4e3a\u963f\u5e15\u7f51\u6807\u51c6: 1\u67081\u65e5\uff0cTCP/IP\u534f\u8bae\u53d6\u4ee3\u4e86\u539f\u6709\u7684\u7f51\u7edc\u63a7\u5236\u534f\u8bae\uff08NCP\uff09\uff0c\u6210\u4e3a\u963f\u5e15\u7f51\u7684\u6807\u51c6\u901a\u4fe1\u534f\u8bae\uff0c\u8fd9\u4e00\u4e8b\u4ef6\u88ab\u8ba4\u4e3a\u662f\u4e92\u8054\u7f51\u8bde\u751f\u7684\u6807\u5fd7\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1989\u5e74"}),(0,l.jsx)("p",{children:" HTTP\u534f\u8bae\u88ab\u53d1\u660e: Tim Berners-Lee\u5728\u6b27\u6d32\u6838\u5b50\u7814\u7a76\u4e2d\u5fc3\uff08CERN\uff09\u53d1\u660e\u4e86\u8d85\u6587\u672c\u4f20\u8f93\u534f\u8bae\uff08HTTP\uff09\uff0c\u4e3a\u4e07\u7ef4\u7f51\u7684\u8bde\u751f\u5960\u5b9a\u4e86\u57fa\u7840\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1990\u5e74"}),(0,l.jsx)("p",{children:" HTML\u88ab\u53d1\u660e: Tim Berners-Lee\u5f00\u53d1\u4e86\u8d85\u6587\u672c\u6807\u8bb0\u8bed\u8a00\uff08HTML\uff09\uff0c\u4f5c\u4e3a\u521b\u5efa\u7f51\u9875\u7684\u6807\u51c6\u5316\u8bed\u8a00\u3002"}),(0,l.jsx)("p",{children:" \u4e16\u754c\u4e0a\u7b2c\u4e00\u4e2a\u7f51\u9875\u6d4f\u89c8\u5668\u548cWeb\u670d\u52a1\u5668\u8bde\u751f: Tim Berners-Lee\u7f16\u5199\u4e86\u7b2c\u4e00\u4e2a\u7f51\u9875\u6d4f\u89c8\u5668WorldWideWeb\uff08\u540e\u6539\u540d\u4e3aNexus\uff09\u548c\u7b2c\u4e00\u4e2aWeb\u670d\u52a1\u5668CERN httpd\u3002"})]})]}),(0,l.jsx)("h3",{id:"-1991-2004-",children:"\u840c\u82bd\u4e0e\u6210\u957f (1991-2004)"}),(0,l.jsxs)("ul",{children:[(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1991\u5e74"}),(0,l.jsx)("p",{children:" \u4e92\u8054\u7f51\u5411\u516c\u4f17\u5f00\u653e: 8\u67086\u65e5\uff0cTim Berners-Lee\u5728\u516c\u5171\u65b0\u95fb\u7ec4\u4e0a\u53d1\u5e03\u4e86\u4e07\u7ef4\u7f51\u9879\u76ee\uff0c\u6807\u5fd7\u7740\u4e92\u8054\u7f51\u5f00\u59cb\u5411\u516c\u4f17\u5f00\u653e\uff0c\u5e76\u9010\u6e10\u666e\u53ca\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1993\u5e74"}),(0,l.jsx)("p",{children:" NCSA Mosaic\u6d4f\u89c8\u5668\u53d1\u5e03: NCSA\uff08\u7f8e\u56fd\u56fd\u5bb6\u8d85\u7ea7\u8ba1\u7b97\u5e94\u7528\u4e2d\u5fc3\uff09\u53d1\u5e03\u4e86Mosaic\u6d4f\u89c8\u5668\uff0c\u8fd9\u662f\u7b2c\u4e00\u4e2a\u80fd\u591f\u56fe\u6587\u6df7\u6392\u7684\u6d4f\u89c8\u5668\uff0c\u6781\u5927\u5730\u63a8\u52a8\u4e86Web\u7684\u666e\u53ca\u3002"}),(0,l.jsx)("p",{children:" CGI\u88ab\u53d1\u660e: NCSA HTTPd\u670d\u52a1\u5668\u7b2c\u4e00\u4e2a\u5b9e\u73b0\u4e86\u901a\u7528\u7f51\u5173\u63a5\u53e3\uff08CGI\uff09\uff0c\u4f7f\u5f97Web\u670d\u52a1\u5668\u80fd\u591f\u8c03\u7528\u5916\u90e8\u7a0b\u5e8f\uff0c\u4ece\u800c\u5b9e\u73b0\u52a8\u6001\u7f51\u9875\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1994\u5e74"}),(0,l.jsx)("p",{children:" HTTPS\u534f\u8bae\u88ab\u53d1\u660e: Netscape\u516c\u53f8\u53d1\u660e\u4e86HTTPS\u534f\u8bae\uff08\u5b89\u5168\u7684HTTP\uff09\uff0c\u5e76\u5728\u5176\u6d4f\u89c8\u5668\u4e2d\u5b9e\u73b0\u3002"}),(0,l.jsx)("p",{children:" Netscape\u6d4f\u89c8\u5668\u53d1\u5e03: Netscape Navigator\u53d1\u5e03\uff0c\u8fc5\u901f\u6210\u4e3a\u5f53\u65f6\u6700\u6d41\u884c\u7684\u6d4f\u89c8\u5668\u3002"}),(0,l.jsx)("p",{children:" CSS\u88ab\u53d1\u660e: H\xe5kon Wium Lie\u9996\u6b21\u63d0\u51fa\u4e86\u5c42\u53e0\u6837\u5f0f\u8868\uff08CSS\uff09\u7684\u6784\u60f3\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1995\u5e74"}),(0,l.jsx)("p",{children:" MySQL\u9996\u6b21\u53d1\u5e03: MySQL\u6570\u636e\u5e93\u7684\u7b2c\u4e00\u4e2a\u5185\u90e8\u7248\u672c\u53d1\u5e03\uff0c\u4e4b\u540e\u9010\u6e10\u53d1\u5c55\u6210\u4e3aWeb\u9886\u57df\u6700\u53d7\u6b22\u8fce\u7684\u5f00\u6e90\u6570\u636e\u5e93\u4e4b\u4e00\u3002"}),(0,l.jsx)("p",{children:" Apache\u9879\u76ee\u542f\u52a8: Apache\u9879\u76ee\u7ec4\u63a5\u624b\u4e86NCSA HTTPd\u7684\u5f00\u53d1\uff0c\u5e76\u5c06\u5176\u53d1\u5c55\u6210\u4e3a\u81f3\u4eca\u4ecd\u7136\u975e\u5e38\u6d41\u884c\u7684Apache HTTP Server\u3002"}),(0,l.jsx)("p",{children:" JavaScript\u53d1\u5e03: Netscape\u516c\u53f8\u53d1\u5e03\u4e86JavaScript\uff08\u6700\u521d\u540d\u4e3aLiveScript\uff09\uff0c\u4e3a\u7f51\u9875\u6dfb\u52a0\u4e86\u52a8\u6001\u4ea4\u4e92\u80fd\u529b\u3002"}),(0,l.jsx)("p",{children:" PHP\u53d1\u5e03: Rasmus Lerdorf\u53d1\u5e03\u4e86PHP\uff08Personal Home Page Tools\uff09\uff0c\u4e00\u79cd\u7528\u4e8e\u521b\u5efa\u52a8\u6001\u7f51\u9875\u7684\u670d\u52a1\u5668\u7aef\u811a\u672c\u8bed\u8a00\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1996\u5e74"}),(0,l.jsx)("p",{children:" HTTP/1.0\u53d1\u5e03: HTTP/1.0\u4f5c\u4e3aRFC 1945\u53d1\u5e03\uff0c\u5bf9\u65e9\u671f\u7684HTTP\u534f\u8bae\u8fdb\u884c\u4e86\u8865\u5145\u548c\u89c4\u8303\u3002"}),(0,l.jsx)("p",{children:" CSS 1\u6210\u4e3aW3C\u63a8\u8350\u6807\u51c6\uff1aCSS Level 1\u6b63\u5f0f\u53d1\u5e03\uff0c\u4e3a\u7f51\u9875\u6837\u5f0f\u63d0\u4f9b\u4e86\u6807\u51c6\u5316\u65b9\u6848\u3002"}),(0,l.jsx)("p",{children:" XML\u88ab\u53d1\u660e: W3C\u5f00\u59cb\u5236\u5b9a\u53ef\u6269\u5c55\u6807\u8bb0\u8bed\u8a00\uff08XML\uff09\uff0c\u65e8\u5728\u4ee5\u7ed3\u6784\u5316\u7684\u65b9\u5f0f\u4f20\u8f93\u548c\u5b58\u50a8\u6570\u636e\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1997\u5e74"}),(0,l.jsx)("p",{children:" HTTP/1.1\u53d1\u5e03: HTTP/1.1\u4f5c\u4e3aRFC 2068\u53d1\u5e03\uff0c\u5f15\u5165\u4e86\u6301\u4e45\u8fde\u63a5\u3001\u7ba1\u9053\u5316\u548c\u5206\u5757\u4f20\u8f93\u7b49\u91cd\u8981\u6539\u8fdb\uff0c\u81f3\u4eca\u4ecd\u662f\u5e7f\u6cdb\u4f7f\u7528\u7684\u534f\u8bae\u7248\u672c\u3002"}),(0,l.jsx)("p",{children:" Java Servlet\u53d1\u5e03: Sun Microsystems\u53d1\u5e03\u4e86Java Servlet\u6280\u672f\uff0c\u63d0\u4f9b\u4e86\u4e00\u79cd\u5728Web\u670d\u52a1\u5668\u4e0a\u8fd0\u884cJava\u7a0b\u5e8f\u7684\u65b9\u5f0f\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1998\u5e74"}),(0,l.jsx)("p",{children:" XMLHttpRequest\u5bf9\u8c61\u51fa\u73b0: \u5fae\u8f6f\u5728Internet Explorer 5.0\u4e2d\u9996\u6b21\u5f15\u5165\u4e86XMLHttpRequest\u5bf9\u8c61\uff0c\u4e3a\u65e5\u540eAJAX\u7684\u51fa\u73b0\u5960\u5b9a\u4e86\u57fa\u7840\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"1999\u5e74"}),(0,l.jsx)("p",{children:" JSP\u53d1\u5e03: Sun Microsystems\u53d1\u5e03\u4e86JavaServer Pages\uff08JSP\uff09\uff0c\u5141\u8bb8\u5f00\u53d1\u8005\u5c06Java\u4ee3\u7801\u5d4c\u5165\u5230HTML\u9875\u9762\u4e2d\u3002"}),(0,l.jsx)("p",{children:" HTML 4.01\u53d1\u5e03: HTML 4.01\u6210\u4e3aW3C\u63a8\u8350\u6807\u51c6\uff0c\u662f2000\u5e74\u4ee3\u4f7f\u7528\u6700\u5e7f\u6cdb\u7684HTML\u7248\u672c\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2000\u5e74"}),(0,l.jsx)("p",{children:" REST\u88ab\u63d0\u51fa: Roy Fielding\u5728\u4ed6\u7684\u535a\u58eb\u8bba\u6587\u4e2d\u63d0\u51fa\u4e86\u8868\u8ff0\u6027\u72b6\u6001\u8f6c\u79fb\uff08REST\uff09\u7684\u8f6f\u4ef6\u67b6\u6784\u98ce\u683c\uff0c\u4e3aWeb API\u7684\u8bbe\u8ba1\u63d0\u4f9b\u4e86\u91cd\u8981\u7684\u7406\u8bba\u6307\u5bfc\u3002"}),(0,l.jsx)("p",{children:" JSON\u88ab\u53d1\u660e: Douglas Crockford\u63d0\u51fa\u4e86JavaScript\u5bf9\u8c61\u8868\u793a\u6cd5\uff08JSON\uff09\uff0c\u4f5c\u4e3a\u4e00\u79cd\u8f7b\u91cf\u7ea7\u7684\u6570\u636e\u4ea4\u6362\u683c\u5f0f\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2002\u5e74"}),(0,l.jsx)("p",{children:" Firefox\u53d1\u5e03: Mozilla\u57fa\u91d1\u4f1a\u53d1\u5e03\u4e86Firefox\u6d4f\u89c8\u5668\uff0c\u4f5c\u4e3aNetscape\u7684\u7ee7\u4efb\u8005\uff0c\u4ee5\u5176\u5f00\u6e90\u3001\u53ef\u6269\u5c55\u548c\u5bf9Web\u6807\u51c6\u7684\u826f\u597d\u652f\u6301\u800c\u53d7\u5230\u6b22\u8fce\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2004\u5e74"}),(0,l.jsx)("p",{children:" Ruby On Rails\u53d1\u5e03: David Heinemeier Hansson\u53d1\u5e03\u4e86Ruby on Rails\uff0c\u8fd9\u662f\u4e00\u4e2a\u5168\u6808Web\u5e94\u7528\u6846\u67b6\uff0c\u4ee5\u5176\u201c\u7ea6\u5b9a\u5927\u4e8e\u914d\u7f6e\u201d\u7684\u7406\u5ff5\u548c\u5feb\u901f\u5f00\u53d1\u80fd\u529b\u800c\u95fb\u540d\u3002"})]})]}),(0,l.jsx)("h3",{id:"-2005-",children:"\u7e41\u8363\u4e0e\u53d8\u9769 (2005\u81f3\u4eca)"}),(0,l.jsxs)("ul",{children:[(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2005\u5e74"}),(0,l.jsx)("p",{children:" MVC\u67b6\u6784\u7684\u6d41\u884c: \u6a21\u578b-\u89c6\u56fe-\u63a7\u5236\u5668\uff08MVC\uff09\u67b6\u6784\u6a21\u5f0f\u5927\u7ea6\u57282000\u5e74\u4ee3\u4e2d\u671f\u968f\u7740Ruby on Rails\u548cDjango\u7b49\u6846\u67b6\u7684\u5174\u8d77\u800c\u5728Web\u5f00\u53d1\u9886\u57df\u6d41\u884c\u8d77\u6765\u3002"}),(0,l.jsx)("p",{children:" AJAX\u88ab\u5e7f\u6cdb\u8ba4\u77e5: Jesse James Garrett\u521b\u9020\u4e86AJAX\uff08Asynchronous JavaScript and XML\uff09\u8fd9\u4e2a\u672f\u8bed\uff0c\u63cf\u8ff0\u4e86\u4e00\u79cd\u4f7f\u7528\u73b0\u6709\u6280\u672f\u521b\u5efa\u66f4\u5177\u52a8\u6001\u6027\u548c\u4ea4\u4e92\u6027\u7684Web\u5e94\u7528\u7684\u65b9\u6cd5\u3002"}),(0,l.jsx)("p",{children:" Django\u53d1\u5e03: Django\uff0c\u4e00\u4e2a\u57fa\u4e8ePython\u7684\u9ad8\u7ea7Web\u6846\u67b6\uff0c\u9996\u6b21\u53d1\u5e03\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2006\u5e74"}),(0,l.jsx)("p",{children:" jQuery\u53d1\u5e03: John Resig\u53d1\u5e03\u4e86jQuery\uff0c\u8fd9\u662f\u4e00\u4e2a\u5feb\u901f\u3001\u5c0f\u5de7\u4e14\u529f\u80fd\u4e30\u5bcc\u7684JavaScript\u5e93\uff0c\u6781\u5927\u5730\u7b80\u5316\u4e86HTML\u6587\u6863\u904d\u5386\u3001\u4e8b\u4ef6\u5904\u7406\u3001\u52a8\u753b\u548cAjax\u4ea4\u4e92\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2008\u5e74"}),(0,l.jsx)("p",{children:" HTML5\u7b2c\u4e00\u4efd\u516c\u5f00\u8349\u6848\u53d1\u5e03: WHATWG\u53d1\u5e03\u4e86HTML5\u7684\u7b2c\u4e00\u4efd\u516c\u5f00\u5de5\u4f5c\u8349\u6848\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2009\u5e74"}),(0,l.jsx)("p",{children:" Node.js\u53d1\u5e03: Ryan Dahl\u53d1\u5e03\u4e86Node.js\uff0c\u8fd9\u662f\u4e00\u4e2a\u57fa\u4e8eChrome V8\u5f15\u64ce\u7684JavaScript\u8fd0\u884c\u73af\u5883\uff0c\u4f7f\u5f97JavaScript\u53ef\u4ee5\u5728\u670d\u52a1\u5668\u7aef\u8fd0\u884c\u3002"}),(0,l.jsx)("p",{children:" ES5\u53d1\u5e03: ECMAScript 5\uff08ES5\uff09\u53d1\u5e03\uff0c\u4e3aJavaScript\u8bed\u8a00\u5e26\u6765\u4e86\u91cd\u8981\u7684\u6539\u8fdb\uff0c\u4f8b\u5982\u4e25\u683c\u6a21\u5f0f\u548c\u5bf9JSON\u7684\u539f\u751f\u652f\u6301\u3002"}),(0,l.jsx)("p",{children:" AngularJS\u53d1\u5e03: Google\u53d1\u5e03\u4e86AngularJS\uff0c\u8fd9\u662f\u7b2c\u4e00\u4e2a\u88ab\u5e7f\u6cdb\u91c7\u7528\u7684\u73b0\u4ee3\u524d\u7aef\u6846\u67b6\uff0c\u5f15\u5165\u4e86\u6570\u636e\u7ed1\u5b9a\u3001\u4f9d\u8d56\u6ce8\u5165\u7b49\u6982\u5ff5\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2010\u5e74"}),(0,l.jsx)("p",{children:" Express.js\u53d1\u5e03: Express.js\uff0c\u4e00\u4e2a\u57fa\u4e8eNode.js\u5e73\u53f0\u7684\u6781\u7b80\u3001\u7075\u6d3b\u7684web\u5e94\u7528\u5f00\u53d1\u6846\u67b6\uff0c\u9996\u6b21\u53d1\u5e03\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2011\u5e74"}),(0,l.jsx)("p",{children:" WebSocket\u534f\u8bae\u6807\u51c6\u5316: WebSocket\u534f\u8bae\u88abIETF\u6807\u51c6\u5316\u4e3aRFC 6455\uff0c\u63d0\u4f9b\u4e86\u6d4f\u89c8\u5668\u4e0e\u670d\u52a1\u5668\u4e4b\u95f4\u5168\u53cc\u5de5\u901a\u4fe1\u7684\u80fd\u529b\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2013\u5e74"}),(0,l.jsx)("p",{children:" \u524d\u540e\u7aef\u5206\u79bb\u67b6\u6784\u7684\u5174\u8d77: \u5927\u7ea6\u57282013\u5e74\u5de6\u53f3\uff0c\u968f\u7740\u524d\u7aef\u6846\u67b6\uff08\u5982AngularJS, React\uff09\u7684\u6210\u719f\u548cRESTful API\u7684\u666e\u53ca\uff0c\u524d\u540e\u7aef\u5206\u79bb\u7684\u67b6\u6784\u6a21\u5f0f\u5f00\u59cb\u5174\u8d77\u3002"}),(0,l.jsx)("p",{children:" React.js\u53d1\u5e03: Facebook\u53d1\u5e03\u4e86React.js\uff0c\u8fd9\u662f\u4e00\u4e2a\u7528\u4e8e\u6784\u5efa\u7528\u6237\u754c\u9762\u7684JavaScript\u5e93\uff0c\u4ee5\u5176\u7ec4\u4ef6\u5316\u548c\u865a\u62dfDOM\u7684\u6982\u5ff5\u800c\u53d7\u5230\u6b22\u8fce\u3002"}),(0,l.jsx)("p",{children:" Electron\u53d1\u5e03: GitHub\u53d1\u5e03\u4e86Electron\uff08\u6700\u521d\u540d\u4e3aAtom Shell\uff09\uff0c\u8fd9\u662f\u4e00\u4e2a\u4f7f\u7528Web\u6280\u672f\u6784\u5efa\u8de8\u5e73\u53f0\u684c\u9762\u5e94\u7528\u7684\u6846\u67b6\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2014\u5e74"}),(0,l.jsx)("p",{children:" HTML5\u6b63\u5f0f\u53d1\u5e03: W3C\u6b63\u5f0f\u53d1\u5e03\u4e86HTML5\u63a8\u8350\u6807\u51c6\u3002"}),(0,l.jsx)("p",{children:" Vue.js\u53d1\u5e03: \u5c24\u96e8\u6eaa\u53d1\u5e03\u4e86Vue.js\uff0c\u8fd9\u662f\u4e00\u4e2a\u6e10\u8fdb\u5f0fJavaScript\u6846\u67b6\uff0c\u4ee5\u5176\u6613\u7528\u6027\u548c\u7075\u6d3b\u6027\u800c\u8457\u79f0\u3002"}),(0,l.jsx)("p",{children:" SPA\u67b6\u6784\u7684\u6d41\u884c: \u5355\u9875\u9762\u5e94\u7528\uff08SPA\uff09\u67b6\u6784\u968f\u7740AJAX\u7684\u51fa\u73b0\u548c\u524d\u7aef\u6846\u67b6\u7684\u53d1\u5c55\u800c\u9010\u6e10\u6d41\u884c\uff0c\u5927\u7ea6\u57282010\u5e74\u4ee3\u4e2d\u671f\u6210\u4e3a\u6784\u5efa\u5bcc\u4ea4\u4e92Web\u5e94\u7528\u7684\u4e3b\u6d41\u65b9\u5f0f\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2015\u5e74"}),(0,l.jsx)("p",{children:" ES6\u53d1\u5e03: ECMAScript 2015\uff08ES6\uff09\u53d1\u5e03\uff0c\u4e3aJavaScript\u5e26\u6765\u4e86\u5927\u91cf\u65b0\u7279\u6027\uff0c\u5982\u7c7b\u3001\u6a21\u5757\u3001\u7bad\u5934\u51fd\u6570\u3001Promise\u7b49\uff0c\u662fJavaScript\u8bed\u8a00\u7684\u4e00\u6b21\u91cd\u5927\u66f4\u65b0\u3002"}),(0,l.jsx)("p",{children:" REST\u5f00\u59cb\u6d41\u884c: \u968f\u7740\u79fb\u52a8\u4e92\u8054\u7f51\u548c\u524d\u540e\u7aef\u5206\u79bb\u67b6\u6784\u7684\u5174\u8d77\uff0cRESTful API\u6210\u4e3aWeb\u670d\u52a1\u7684\u4e3b\u6d41\u8bbe\u8ba1\u98ce\u683c\u3002"}),(0,l.jsx)("p",{children:" WebAssembly\u9996\u6b21\u5ba3\u5e03: WebAssembly\uff0c\u4e00\u79cd\u65b0\u7684\u3001\u53ef\u79fb\u690d\u7684\u3001\u5927\u5c0f\u548c\u52a0\u8f7d\u65f6\u95f4\u9ad8\u6548\u7684\u683c\u5f0f\uff0c\u65e8\u5728\u4e3aWeb\u5e26\u6765\u8fd1\u4e4e\u539f\u751f\u7684\u6027\u80fd\uff0c\u9996\u6b21\u88ab\u5ba3\u5e03\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2016\u5e74"}),(0,l.jsx)("p",{children:" Next.js\u53d1\u5e03: Vercel\uff08\u5f53\u65f6\u540d\u4e3aZEIT\uff09\u53d1\u5e03\u4e86Next.js\uff0c\u8fd9\u662f\u4e00\u4e2a\u57fa\u4e8eReact\u7684\u670d\u52a1\u7aef\u6e32\u67d3\u6846\u67b6\uff0c\u7b80\u5316\u4e86React\u5e94\u7528\u7684\u5f00\u53d1\u3002"})]})]}),(0,l.jsxs)("ul",{children:[(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2017\u5e74"}),(0,l.jsx)("p",{children:" WebAssembly MVP\u53d1\u5e03: WebAssembly\u7684\u6700\u5c0f\u53ef\u884c\u4ea7\u54c1\uff08MVP\uff09\u5728\u4e3b\u6d41\u6d4f\u89c8\u5668\u4e2d\u5f97\u5230\u652f\u6301\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2018\u5e74"}),(0,l.jsx)("p",{children:" WebAssembly\u9996\u4e2a\u516c\u5f00\u5de5\u4f5c\u8349\u6848\u53d1\u5e03: W3C\u53d1\u5e03\u4e86WebAssembly\u6838\u5fc3\u89c4\u8303\u3001JavaScript\u63a5\u53e3\u548cWeb API\u7684\u7b2c\u4e00\u4e2a\u516c\u5f00\u5de5\u4f5c\u8349\u6848\u3002"})]}),(0,l.jsxs)("li",{children:[(0,l.jsx)("p",{children:"2019\u5e74"}),(0,l.jsx)("p",{children:" WebAssembly\u6210\u4e3aW3C\u63a8\u8350\u6807\u51c6: WebAssembly\u6838\u5fc3\u89c4\u8303\u6210\u4e3aW3C\u7684\u5b98\u65b9\u63a8\u8350\u6807\u51c6\u3002"})]})]})]}),"\n",(0,l.jsx)(s.h3,{id:"\u8d44\u6e90",children:"\u8d44\u6e90"}),"\n",(0,l.jsx)(s.p,{children:(0,l.jsx)(s.em,{children:"(MDN\u662f\u4e00\u4e2a\u975e\u5e38\u597d\u7684\u7f51\u7ad9\uff0c\u662f\u5f00\u53d1FireFox\u7684Mozilla\u516c\u53f8\u5199\u7684\uff0c\u57fa\u672c\u4e0a\u662f\u524d\u7aef\u5f00\u53d1\u7684\u5723\u7ecf\u4e86\uff0c\u5bf9\u4e8e\u540e\u7aef\u4eba\uff0c\u8fd9\u4e2a\u7f51\u7ad9\u4e5f\u6709\u8bb8\u591a\u5f88\u597d\u7684\u5185\u5bb9)"})}),"\n",(0,l.jsxs)(s.ol,{children:["\n",(0,l.jsx)(s.li,{children:(0,l.jsx)(s.a,{href:"https://developer.mozilla.org/zh-CN/docs/Web/HTTP",children:"\u5173\u4e8eHTTP\u534f\u8bae\u7684\u8be6\u7ec6\u89e3\u91ca"})}),"\n",(0,l.jsxs)(s.li,{children:[(0,l.jsx)(s.a,{href:"https://developer.mozilla.org/zh-CN/docs/Learn_web_development",children:"Web\u5f00\u53d1\u6559\u7a0b"})," ",(0,l.jsx)(s.em,{children:"HTML,CSS,JavaScript\u90fd\u6709\uff0c\u9700\u8981\u5b66\u4ec0\u4e48\u5c31\u53bb\u770b\u4ec0\u4e48"})]}),"\n",(0,l.jsx)(s.li,{children:(0,l.jsx)(s.a,{href:"https://developer.mozilla.org/zh-CN/docs/Learn_web_development/Extensions/Server-side",children:"\u540e\u7aef\u5f00\u53d1\u6559\u7a0b"})}),"\n"]}),"\n",(0,l.jsxs)(s.admonition,{type:"info",children:[(0,l.jsxs)(s.p,{children:["\u8fd9\u662f\u4e09\u7bc7\u7cfb\u5217\u6587\u7ae0\u4e2d\u7684\u7b2c",(0,l.jsx)(s.strong,{children:"3"}),"\u7bc7"]}),(0,l.jsx)(s.p,{children:"\u70b9\u51fb\u4ee5\u8df3\u8f6c\uff1a"}),(0,l.jsx)(s.p,{children:(0,l.jsx)(s.a,{href:"/blog/Web%E7%9A%84%E5%8E%86%E5%8F%B21%EF%B8%8F%E2%83%A3-HTTP",children:"HTTP"})}),(0,l.jsx)(s.p,{children:(0,l.jsx)(s.a,{href:"/blog/Web%E7%9A%84%E5%8E%86%E5%8F%B22%EF%B8%8F%E2%83%A3-%E5%8A%A8%E6%80%81%E7%BD%91%E9%A1%B5",children:"\u52a8\u6001\u7f51\u9875"})}),(0,l.jsxs)(s.p,{children:[(0,l.jsx)(s.strong,{children:"Web\u5e94\u7528"}),"(\u4f60\u5728\u770b\u7684\u6587\u7ae0)"]})]})]})}function j(e={}){const{wrapper:s}={...(0,r.R)(),...e.components};return s?(0,l.jsx)(s,{...e,children:(0,l.jsx)(p,{...e})}):p(e)}},28453:(e,s,n)=>{n.d(s,{R:()=>c,x:()=>d});var i=n(96540);const l={},r=i.createContext(l);function c(e){const s=i.useContext(r);return i.useMemo((function(){return"function"==typeof e?e(s):{...s,...e}}),[s,e])}function d(e){let s;return s=e.disableParentContext?"function"==typeof e.components?e.components(l):e.components||l:c(e.components),i.createElement(r.Provider,{value:s},e.children)}},64263:e=>{e.exports=JSON.parse('{"permalink":"/blog/Web\u7684\u5386\u53f23\ufe0f\u20e3-Web\u5e94\u7528","editUrl":"https://github.com/ZSCNetSupportDept/website/tree/master/blog/Web\u7684\u5386\u53f23\ufe0f\u20e3-Web\u5e94\u7528.md","source":"@site/blog/Web\u7684\u5386\u53f23\ufe0f\u20e3-Web\u5e94\u7528.md","title":"Web\u7684\u5386\u53f23\ufe0f\u20e3-Web\u5e94\u7528","description":"\u968f\u7740\u6280\u672f\u7684\u4e0d\u65ad\u53d1\u5c55\uff0c\u5c24\u5176\u662f\u79fb\u52a8\u8bbe\u5907\u7684\u666e\u53ca\u548c\u79fb\u52a8\u4e92\u8054\u7f51\u7684\u53d1\u5c55\uff0c\u4f7f\u5f97\u52a8\u6001\u7f51\u9875\u5bf9\u4e8e\u65e5\u76ca\u590d\u6742\u7684\u9700\u6c42\u529b\u4e0d\u4ece\u5fc3\u3002","date":"2025-07-13T03:23:58.000Z","tags":[],"readingTime":45.91,"hasTruncateMarker":true,"authors":[],"frontMatter":{},"unlisted":false,"prevItem":{"title":"Web\u7684\u5386\u53f22\ufe0f\u20e3-\u52a8\u6001\u7f51\u9875","permalink":"/blog/Web\u7684\u5386\u53f22\ufe0f\u20e3-\u52a8\u6001\u7f51\u9875"},"nextItem":{"title":"\u5973\u751f\u5bbf\u820d\u7684\u7f51\u7edc\u7ed3\u6784\u89e3\u91ca","permalink":"/blog/2025/5/9/\u5973\u751f\u5bbf\u820d\u7684\u7f51\u7edc\u7ed3\u6784\u89e3\u91ca"}}')},90053:(e,s,n)=>{n.d(s,{A:()=>i});const i=n.p+"assets/images/comic-301f3ee2297b346a30c21987f2cde629.png"}}]);