{"id":3038,"date":"2026-02-02T22:51:44","date_gmt":"2026-02-02T14:51:44","guid":{"rendered":"https:\/\/blog.nonot.cn\/?p=3038"},"modified":"2026-02-02T22:51:44","modified_gmt":"2026-02-02T14:51:44","slug":"%e5%a6%82%e4%bd%95%e9%80%9a%e8%bf%87javascript%e5%ae%9e%e7%8e%b0%e5%bc%b9%e5%87%ba%e5%b1%82%e6%95%88%e6%9e%9c%ef%bc%9f","status":"publish","type":"post","link":"https:\/\/blog.nonot.cn\/index.php\/2026\/02\/02\/%e5%a6%82%e4%bd%95%e9%80%9a%e8%bf%87javascript%e5%ae%9e%e7%8e%b0%e5%bc%b9%e5%87%ba%e5%b1%82%e6%95%88%e6%9e%9c%ef%bc%9f\/","title":{"rendered":"\u5982\u4f55\u901a\u8fc7JavaScript\u5b9e\u73b0\u5f39\u51fa\u5c42\u6548\u679c\uff1f"},"content":{"rendered":"<p>\u5b9e\u73b0\u5f39\u51fa\u5c42\u6548\u679c\uff0c\u6211\u4eec\u4e3b\u8981\u901a\u8fc7JavaScript\u6765\u64cd\u4f5cDOM\u5143\u7d20\u548c\u4fee\u6539\u5b83\u4eec\u7684CSS\u6837\u5f0f\u3002\u6838\u5fc3\u601d\u8def\u65e0\u975e\u5c31\u662f\uff1a\u51c6\u5907\u597d\u4e00\u4e2a\u9ed8\u8ba4\u9690\u85cf\u7684HTML\u7ed3\u6784\uff0c\u7136\u540e\u7528JavaScript\u76d1\u542c\u67d0\u4e2a\u4e8b\u4ef6\uff08\u6bd4\u5982\u70b9\u51fb\u6309\u94ae\uff09\uff0c\u5f53\u4e8b\u4ef6\u89e6\u53d1\u65f6\uff0c\u6539\u53d8\u8fd9\u4e2aHTML\u5143\u7d20\u7684\u6837\u5f0f\uff0c\u8ba9\u5b83\u663e\u793a\u51fa\u6765\u3002\u540c\u65f6\uff0c\u901a\u5e38\u8fd8\u4f1a\u4f34\u968f\u4e00\u4e2a\u534a\u900f\u660e\u7684\u906e\u7f69\u5c42\uff0c\u9632\u6b62\u7528\u6237\u5728\u5f39\u51fa\u5c42\u663e\u793a\u65f6\u4e0e\u9875\u9762\u5176\u4ed6\u90e8\u5206\u4ea4\u4e92\u3002<\/p>\n<p>\u4e00\u4e2a\u57fa\u7840\u7684\u5f39\u51fa\u5c42\u5b9e\u73b0\uff0c\u901a\u5e38\u4f1a\u5305\u542b\u4ee5\u4e0b\u51e0\u4e2a\u6b65\u9aa4\uff1a<\/p>\n<p><strong>\u89e3\u51b3\u65b9\u6848<\/strong><\/p>\n<p>\u6211\u4eec\u5148\u6765\u642d\u5efa\u4e00\u4e2a\u6700\u7b80\u5355\u7684HTML\u7ed3\u6784\uff0c\u5305\u542b\u4e00\u4e2a\u89e6\u53d1\u6309\u94ae\u3001\u4e00\u4e2a\u5f39\u51fa\u5c42\u5bb9\u5668\u4ee5\u53ca\u4e00\u4e2a\u80cc\u666f\u906e\u7f69\u3002<\/p>\n<p>\u7acb\u5373\u5b66\u4e60\u201c<a href=\"https:\/\/pan.quark.cn\/s\/c1c2c2ed740f\" target=\"_blank\" rel=\"nofollow noopener\">Java\u514d\u8d39\u5b66\u4e60\u7b14\u8bb0\uff08\u6df1\u5165\uff09<\/a>\u201d\uff1b<\/p>\n<p class=\"line number1 index0 alt2\"><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">meta<\/code> <code class=\"html color1\">charset<\/code><code class=\"html plain\">=<\/code><code class=\"html string\">\"UTF-8\"<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number2 index1 alt1\"><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">meta<\/code> <code class=\"html color1\">name<\/code><code class=\"html plain\">=<\/code><code class=\"html string\">\"viewport\"<\/code> <code class=\"html color1\">content<\/code><code class=\"html plain\">=<\/code><code class=\"html string\">\"width=device-width, initial-scale=1.0\"<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number3 index2 alt2\"><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">title<\/code><code class=\"html plain\">&gt;JavaScript \u5f39\u51fa\u5c42\u793a\u4f8b&lt;\/<\/code><code class=\"html keyword\">title<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number4 index3 alt1\"><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">style<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number5 index4 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">body {<\/code><\/p>\n<p class=\"line number6 index5 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">font-family: Arial, sans-serif;<\/code><\/p>\n<p class=\"line number7 index6 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">margin: 0;<\/code><\/p>\n<p class=\"line number8 index7 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">padding: 20px;<\/code><\/p>\n<p class=\"line number9 index8 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">background-color: #f4f4f4;<\/code><\/p>\n<p class=\"line number10 index9 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">}<\/code><\/p>\n<p class=\"line number11 index10 alt2\">\n<p class=\"line number12 index11 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">.open-modal-btn {<\/code><\/p>\n<p class=\"line number13 index12 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">padding: 10px 20px;<\/code><\/p>\n<p class=\"line number14 index13 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">background-color: #007bff;<\/code><\/p>\n<p class=\"line number15 index14 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">color: white;<\/code><\/p>\n<p class=\"line number16 index15 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">border: none;<\/code><\/p>\n<p class=\"line number17 index16 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">border-radius: 5px;<\/code><\/p>\n<p class=\"line number18 index17 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">cursor: pointer;<\/code><\/p>\n<p class=\"line number19 index18 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">font-size: 16px;<\/code><\/p>\n<p class=\"line number20 index19 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">}<\/code><\/p>\n<p class=\"line number21 index20 alt2\">\n<p class=\"line number22 index21 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">.modal-overlay {<\/code><\/p>\n<p class=\"line number23 index22 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">position: fixed;<\/code><\/p>\n<p class=\"line number24 index23 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">top: 0;<\/code><\/p>\n<p class=\"line number25 index24 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">left: 0;<\/code><\/p>\n<p class=\"line number26 index25 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">width: 100%;<\/code><\/p>\n<p class=\"line number27 index26 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">height: 100%;<\/code><\/p>\n<p class=\"line number28 index27 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">background-color: rgba(0, 0, 0, 0.6);<\/code><\/p>\n<p class=\"line number29 index28 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">display: none; \/* \u9ed8\u8ba4\u9690\u85cf *\/<\/code><\/p>\n<p class=\"line number30 index29 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">justify-content: center;<\/code><\/p>\n<p class=\"line number31 index30 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">align-items: center;<\/code><\/p>\n<p class=\"line number32 index31 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">z-index: 1000;<\/code><\/p>\n<p class=\"line number33 index32 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">}<\/code><\/p>\n<p class=\"line number34 index33 alt1\">\n<p class=\"line number35 index34 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">.modal-content {<\/code><\/p>\n<p class=\"line number36 index35 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">background-color: white;<\/code><\/p>\n<p class=\"line number37 index36 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">padding: 30px;<\/code><\/p>\n<p class=\"line number38 index37 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">border-radius: 8px;<\/code><\/p>\n<p class=\"line number39 index38 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);<\/code><\/p>\n<p class=\"line number40 index39 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">width: 80%;<\/code><\/p>\n<p class=\"line number41 index40 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">max-width: 500px;<\/code><\/p>\n<p class=\"line number42 index41 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">position: relative;<\/code><\/p>\n<p class=\"line number43 index42 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">transform: translateY(-20px); \/* \u521d\u59cb\u7565\u5fae\u4e0a\u79fb\uff0c\u4e3a\u52a8\u753b\u505a\u51c6\u5907 *\/<\/code><\/p>\n<p class=\"line number44 index43 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">opacity: 0; \/* \u521d\u59cb\u900f\u660e *\/<\/code><\/p>\n<p class=\"line number45 index44 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">transition: transform 0.3s ease-out, opacity 0.3s ease-out; \/* \u6dfb\u52a0\u8fc7\u6e21\u6548\u679c *\/<\/code><\/p>\n<p class=\"line number46 index45 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">}<\/code><\/p>\n<p class=\"line number47 index46 alt2\">\n<p class=\"line number48 index47 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">.modal-overlay.active .modal-content {<\/code><\/p>\n<p class=\"line number49 index48 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">transform: translateY(0);<\/code><\/p>\n<p class=\"line number50 index49 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">opacity: 1;<\/code><\/p>\n<p class=\"line number51 index50 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">}<\/code><\/p>\n<p class=\"line number52 index51 alt1\">\n<p class=\"line number53 index52 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">.modal-overlay.active {<\/code><\/p>\n<p class=\"line number54 index53 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">display: flex; \/* \u5f39\u51fa\u65f6\u663e\u793a *\/<\/code><\/p>\n<p class=\"line number55 index54 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">}<\/code><\/p>\n<p class=\"line number56 index55 alt1\">\n<p class=\"line number57 index56 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">.close-modal-btn {<\/code><\/p>\n<p class=\"line number58 index57 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">position: absolute;<\/code><\/p>\n<p class=\"line number59 index58 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">top: 10px;<\/code><\/p>\n<p class=\"line number60 index59 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">right: 15px;<\/code><\/p>\n<p class=\"line number61 index60 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">font-size: 24px;<\/code><\/p>\n<p class=\"line number62 index61 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">cursor: pointer;<\/code><\/p>\n<p class=\"line number63 index62 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">border: none;<\/code><\/p>\n<p class=\"line number64 index63 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">background: none;<\/code><\/p>\n<p class=\"line number65 index64 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">color: #aaa;<\/code><\/p>\n<p class=\"line number66 index65 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">}<\/code><\/p>\n<p class=\"line number67 index66 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">.close-modal-btn:hover {<\/code><\/p>\n<p class=\"line number68 index67 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">color: #333;<\/code><\/p>\n<p class=\"line number69 index68 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">}<\/code><\/p>\n<p class=\"line number70 index69 alt1\"><code class=\"html plain\">&lt;\/<\/code><code class=\"html keyword\">style<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number71 index70 alt2\">\n<p class=\"line number72 index71 alt1\">\n<p class=\"line number73 index72 alt2\">\n<p class=\"line number74 index73 alt1\"><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">button<\/code> <code class=\"html color1\">class<\/code><code class=\"html plain\">=<\/code><code class=\"html string\">\"open-modal-btn\"<\/code><code class=\"html plain\">&gt;\u6253\u5f00\u5f39\u51fa\u5c42&lt;\/<\/code><code class=\"html keyword\">button<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number75 index74 alt2\">\n<p class=\"line number76 index75 alt1\"><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">div<\/code> <code class=\"html color1\">class<\/code><code class=\"html plain\">=<\/code><code class=\"html string\">\"modal-overlay\"<\/code> <code class=\"html color1\">id<\/code><code class=\"html plain\">=<\/code><code class=\"html string\">\"myModalOverlay\"<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number77 index76 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">div<\/code> <code class=\"html color1\">class<\/code><code class=\"html plain\">=<\/code><code class=\"html string\">\"modal-content\"<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number78 index77 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">button<\/code> <code class=\"html color1\">class<\/code><code class=\"html plain\">=<\/code><code class=\"html string\">\"close-modal-btn\"<\/code><code class=\"html plain\">&gt;\u00d7&lt;\/<\/code><code class=\"html keyword\">button<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number79 index78 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">h2<\/code><code class=\"html plain\">&gt;\u8fd9\u662f\u4e00\u4e2a\u5f39\u51fa\u5c42\u6807\u9898&lt;\/<\/code><code class=\"html keyword\">h2<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number80 index79 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">p<\/code><code class=\"html plain\">&gt;\u8fd9\u91cc\u662f\u5f39\u51fa\u5c42\u7684\u5185\u5bb9\u3002\u4f60\u53ef\u4ee5\u653e\u7f6e\u4efb\u4f55HTML\u5143\u7d20\uff0c\u6bd4\u5982\u8868\u5355\u3001\u56fe\u7247\u6216\u8005\u66f4\u591a\u6587\u672c\u3002&lt;\/<\/code><code class=\"html keyword\">p<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number81 index80 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">p<\/code><code class=\"html plain\">&gt;\u8fd9\u4e2a\u5f39\u51fa\u5c42\u901a\u8fc7JavaScript\u63a7\u5236\u663e\u793a\u548c\u9690\u85cf\uff0c\u540c\u65f6\u5e26\u6709\u4e00\u4e2a\u7b80\u5355\u7684\u8fc7\u6e21\u52a8\u753b\u3002&lt;\/<\/code><code class=\"html keyword\">p<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number82 index81 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">&lt;\/<\/code><code class=\"html keyword\">div<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number83 index82 alt2\"><code class=\"html plain\">&lt;\/<\/code><code class=\"html keyword\">div<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number84 index83 alt1\">\n<p class=\"line number85 index84 alt2\"><code class=\"html plain\">&lt;<\/code><code class=\"html keyword\">script<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p class=\"line number86 index85 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">const openBtn = document.querySelector('.open-modal-btn');<\/code><\/p>\n<p class=\"line number87 index86 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">const closeBtn = document.querySelector('.close-modal-btn');<\/code><\/p>\n<p class=\"line number88 index87 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">const modalOverlay = document.getElementById('myModalOverlay');<\/code><\/p>\n<p class=\"line number89 index88 alt2\">\n<p class=\"line number90 index89 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">\/\/ \u6253\u5f00\u5f39\u51fa\u5c42<\/code><\/p>\n<p class=\"line number91 index90 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">openBtn.addEventListener('click', () =&gt; {<\/code><\/p>\n<p class=\"line number92 index91 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">modalOverlay.classList.add('active');<\/code><\/p>\n<p class=\"line number93 index92 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">document.body.style.overflow = 'hidden'; \/\/ \u9632\u6b62\u9875\u9762\u6eda\u52a8<\/code><\/p>\n<p class=\"line number94 index93 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">});<\/code><\/p>\n<p class=\"line number95 index94 alt2\">\n<p class=\"line number96 index95 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">\/\/ \u5173\u95ed\u5f39\u51fa\u5c42<\/code><\/p>\n<p class=\"line number97 index96 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">closeBtn.addEventListener('click', () =&gt; {<\/code><\/p>\n<p class=\"line number98 index97 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">modalOverlay.classList.remove('active');<\/code><\/p>\n<p class=\"line number99 index98 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">document.body.style.overflow = ''; \/\/ \u6062\u590d\u9875\u9762\u6eda\u52a8<\/code><\/p>\n<p class=\"line number100 index99 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">});<\/code><\/p>\n<p class=\"line number101 index100 alt2\">\n<p class=\"line number102 index101 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">\/\/ \u70b9\u51fb\u906e\u7f69\u5c42\u5173\u95ed\uff08\u53ef\u9009\uff09<\/code><\/p>\n<p class=\"line number103 index102 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">modalOverlay.addEventListener('click', (event) =&gt; {<\/code><\/p>\n<p class=\"line number104 index103 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">if (event.target === modalOverlay) {<\/code><\/p>\n<p class=\"line number105 index104 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">modalOverlay.classList.remove('active');<\/code><\/p>\n<p class=\"line number106 index105 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">document.body.style.overflow = '';<\/code><\/p>\n<p class=\"line number107 index106 alt2\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">}<\/code><\/p>\n<p class=\"line number108 index107 alt1\"><code class=\"html spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"html plain\">});<\/code><\/p>\n<p class=\"line number109 index108 alt2\"><code class=\"html plain\">&lt;\/<\/code><code class=\"html keyword\">script<\/code><code class=\"html plain\">&gt;<\/code><\/p>\n<p>\u8fd9\u6bb5\u4ee3\u7801\u7684\u6838\u5fc3\u5728\u4e8eCSS\u7684<code>display: none;<\/code>\u548cJavaScript\u901a\u8fc7<code>classList.add('active')<\/code>\u6765\u5207\u6362<code>display: flex;<\/code>\u3002\u6211\u4e2a\u4eba\u6bd4\u8f83\u559c\u6b22\u7528CSS\u7c7b\u6765\u63a7\u5236\u663e\u793a\/\u9690\u85cf\uff0c\u56e0\u4e3a\u5b83\u80fd\u66f4\u597d\u5730\u914d\u5408CSS\u52a8\u753b\u548c\u8fc7\u6e21\uff0c\u8ba9\u5f39\u51fa\u6548\u679c\u770b\u8d77\u6765\u66f4\u81ea\u7136\uff0c\u800c\u4e0d\u662f\u751f\u786c\u5730\u8df3\u51fa\u3002<code>document.body.style.overflow = 'hidden';<\/code>\u00a0\u8fd9\u884c\u4ee3\u7801\u4e5f\u5f88\u5173\u952e\uff0c\u5b83\u80fd\u9632\u6b62\u5728\u5f39\u51fa\u5c42\u6253\u5f00\u65f6\uff0c\u5e95\u4e0b\u7684\u9875\u9762\u5185\u5bb9\u8ddf\u7740\u6eda\u52a8\uff0c\u8fd9\u5728\u7528\u6237\u4f53\u9a8c\u4e0a\u662f\u4e2a\u5c0f\u7ec6\u8282\uff0c\u4f46\u5f88\u91cd\u8981\u3002<\/p>\n<h3>\u5982\u4f55\u8ba9\u5f39\u51fa\u5c42\u5728\u9875\u9762\u52a0\u8f7d\u65f6\u81ea\u52a8\u663e\u793a\uff0c\u5e76\u652f\u6301\u5ef6\u65f6\u5173\u95ed\uff1f<\/h3>\n<p>\u6709\u65f6\u5019\uff0c\u6211\u4eec\u5e0c\u671b\u7528\u6237\u4e00\u8fdb\u5165\u9875\u9762\u5c31\u80fd\u770b\u5230\u67d0\u4e2a\u91cd\u8981\u7684\u63d0\u793a\u6216\u5e7f\u544a\uff0c\u8fd9\u5c31\u9700\u8981\u5f39\u51fa\u5c42\u81ea\u52a8\u663e\u793a\u3002\u540c\u65f6\uff0c\u4e3a\u4e86\u4e0d\u6253\u6270\u7528\u6237\u592a\u4e45\uff0c\u53ef\u80fd\u8fd8\u9700\u8981\u5b83\u5728\u4e00\u6bb5\u65f6\u95f4\u540e\u81ea\u52a8\u5173\u95ed\u3002<\/p>\n<p>\u8981\u5b9e\u73b0\u9875\u9762\u52a0\u8f7d\u65f6\u81ea\u52a8\u663e\u793a\uff0c\u6211\u4eec\u53ef\u4ee5\u5229\u7528<code>DOMContentLoaded<\/code>\u4e8b\u4ef6\u3002\u8fd9\u4e2a\u4e8b\u4ef6\u4f1a\u5728HTML\u6587\u6863\u88ab\u5b8c\u5168\u52a0\u8f7d\u548c\u89e3\u6790\u5b8c\u6210\u65f6\u89e6\u53d1\uff0c\u800c\u65e0\u9700\u7b49\u5f85\u6837\u5f0f\u8868\u3001\u56fe\u7247\u7b49\u8d44\u6e90\u52a0\u8f7d\u5b8c\u6bd5\uff0c\u901a\u5e38\u6bd4<code>window.onload<\/code>\u66f4\u65e9\u3002<\/p>\n<p>\u81f3\u4e8e\u5ef6\u65f6\u5173\u95ed\uff0cJavaScript\u7684<code>setTimeout<\/code>\u51fd\u6570\u5c31\u662f\u4e3a\u6b64\u800c\u751f\u3002\u5b83\u4f1a\u5728\u6307\u5b9a\u6beb\u79d2\u6570\u540e\u6267\u884c\u4e00\u6b21\u51fd\u6570\u3002<\/p>\n<p class=\"line number1 index0 alt2\"><code class=\"javascript plain\">document.addEventListener(<\/code><code class=\"javascript string\">'DOMContentLoaded'<\/code><code class=\"javascript plain\">, () =&gt; {<\/code><\/p>\n<p class=\"line number2 index1 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const modalOverlay = document.getElementById(<\/code><code class=\"javascript string\">'myModalOverlay'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number3 index2 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const closeBtn = document.querySelector(<\/code><code class=\"javascript string\">'.close-modal-btn'<\/code><code class=\"javascript plain\">); <\/code><code class=\"javascript comments\">\/\/ \u786e\u4fdd\u80fd\u83b7\u53d6\u5230\u5173\u95ed\u6309\u94ae<\/code><\/p>\n<p class=\"line number4 index3 alt1\">\n<p class=\"line number5 index4 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u9875\u9762\u52a0\u8f7d\u540e\u7acb\u5373\u663e\u793a\u5f39\u51fa\u5c42<\/code><\/p>\n<p class=\"line number6 index5 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalOverlay.classList.add(<\/code><code class=\"javascript string\">'active'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number7 index6 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">document.body.style.overflow = <\/code><code class=\"javascript string\">'hidden'<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number8 index7 alt1\">\n<p class=\"line number9 index8 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u8bbe\u7f6e5\u79d2\u540e\u81ea\u52a8\u5173\u95ed\u5f39\u51fa\u5c42<\/code><\/p>\n<p class=\"line number10 index9 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">setTimeout(() =&gt; {<\/code><\/p>\n<p class=\"line number11 index10 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalOverlay.classList.remove(<\/code><code class=\"javascript string\">'active'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number12 index11 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">document.body.style.overflow = <\/code><code class=\"javascript string\">''<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number13 index12 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">}, 5000); <\/code><code class=\"javascript comments\">\/\/ 5000\u6beb\u79d2 = 5\u79d2<\/code><\/p>\n<p class=\"line number14 index13 alt1\">\n<p class=\"line number15 index14 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u786e\u4fdd\u624b\u52a8\u5173\u95ed\u6309\u94ae\u4f9d\u7136\u6709\u6548<\/code><\/p>\n<p class=\"line number16 index15 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">closeBtn.addEventListener(<\/code><code class=\"javascript string\">'click'<\/code><code class=\"javascript plain\">, () =&gt; {<\/code><\/p>\n<p class=\"line number17 index16 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalOverlay.classList.remove(<\/code><code class=\"javascript string\">'active'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number18 index17 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">document.body.style.overflow = <\/code><code class=\"javascript string\">''<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number19 index18 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u5982\u679c\u81ea\u52a8\u5173\u95ed\u5b9a\u65f6\u5668\u8fd8\u5728\u8fd0\u884c\uff0c\u8fd9\u91cc\u53ef\u4ee5\u6e05\u9664\u5b83\uff0c\u907f\u514d\u51b2\u7a81<\/code><\/p>\n<p class=\"line number20 index19 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ clearTimeout(autoCloseTimerId); \/\/ \u9700\u8981\u4fdd\u5b58setTimeout\u7684\u8fd4\u56de\u503c<\/code><\/p>\n<p class=\"line number21 index20 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">});<\/code><\/p>\n<p class=\"line number22 index21 alt1\">\n<p class=\"line number23 index22 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u70b9\u51fb\u906e\u7f69\u5c42\u5173\u95ed<\/code><\/p>\n<p class=\"line number24 index23 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalOverlay.addEventListener(<\/code><code class=\"javascript string\">'click'<\/code><code class=\"javascript plain\">, (event) =&gt; {<\/code><\/p>\n<p class=\"line number25 index24 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript keyword\">if<\/code> <code class=\"javascript plain\">(event.target === modalOverlay) {<\/code><\/p>\n<p class=\"line number26 index25 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalOverlay.classList.remove(<\/code><code class=\"javascript string\">'active'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number27 index26 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">document.body.style.overflow = <\/code><code class=\"javascript string\">''<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number28 index27 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">}<\/code><\/p>\n<p class=\"line number29 index28 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">});<\/code><\/p>\n<p class=\"line number30 index29 alt1\"><code class=\"javascript plain\">});<\/code><\/p>\n<p>\u8fd9\u91cc\u6211\u628a\u6574\u4e2a\u903b\u8f91\u90fd\u653e\u5230\u4e86<code>DOMContentLoaded<\/code>\u4e8b\u4ef6\u76d1\u542c\u5668\u91cc\u3002\u8fd9\u6837\uff0c\u9875\u9762\u4e00\u52a0\u8f7d\u5b8cDOM\u7ed3\u6784\uff0c\u5f39\u51fa\u5c42\u5c31\u4f1a\u7acb\u523b\u51fa\u73b0\u3002<code>setTimeout<\/code>\u5219\u8d1f\u8d23\u57285\u79d2\u540e\u6267\u884c\u5173\u95ed\u64cd\u4f5c\u3002\u5b9e\u9645\u5f00\u53d1\u4e2d\uff0c\u5982\u679c\u7528\u6237\u57285\u79d2\u5185\u624b\u52a8\u5173\u95ed\u4e86\u5f39\u51fa\u5c42\uff0c\u6211\u4eec\u53ef\u80fd\u8fd8\u9700\u8981<code>clearTimeout<\/code>\u6765\u53d6\u6d88\u90a3\u4e2a\u81ea\u52a8\u5173\u95ed\u7684\u5b9a\u65f6\u5668\uff0c\u907f\u514d\u5b83\u5728\u5f39\u51fa\u5c42\u5df2\u7ecf\u5173\u95ed\u540e\u53c8\u5c1d\u8bd5\u6267\u884c\u5173\u95ed\u64cd\u4f5c\uff0c\u867d\u7136\u5728\u8fd9\u4e2a\u7b80\u5355\u4f8b\u5b50\u91cc\u5f71\u54cd\u4e0d\u5927\uff0c\u4f46\u517b\u6210\u597d\u4e60\u60ef\u5f88\u91cd\u8981\u3002<\/p>\n<h3>\u5f39\u51fa\u5c42\u5185\u5bb9\u5982\u4f55\u52a8\u6001\u52a0\u8f7d\uff0c\u4f8b\u5982\u4eceAPI\u83b7\u53d6\u6570\u636e\uff1f<\/h3>\n<p>\u5f88\u591a\u65f6\u5019\uff0c\u5f39\u51fa\u5c42\u7684\u5185\u5bb9\u5e76\u4e0d\u662f\u56fa\u5b9a\u7684\uff0c\u5b83\u53ef\u80fd\u9700\u8981\u6839\u636e\u7528\u6237\u7684\u64cd\u4f5c\u6216\u8005\u4ece<a title=\"\u540e\u7aef\" href=\"https:\/\/www.php.cn\/zt\/17190.html\" target=\"_blank\" rel=\"noopener\">\u540e\u7aef<\/a>API\u52a8\u6001\u83b7\u53d6\u3002\u6bd4\u5982\uff0c\u70b9\u51fb\u4e00\u4e2a\u5546\u54c1\u5217\u8868\u4e2d\u7684\u201c\u67e5\u770b\u8be6\u60c5\u201d\u6309\u94ae\uff0c\u5f39\u51fa\u7684\u5c42\u91cc\u5c31\u5e94\u8be5\u663e\u793a\u5bf9\u5e94\u5546\u54c1\u7684\u8be6\u7ec6\u4fe1\u606f\u3002<\/p>\n<div class=\"aritcle_card flexRow\">\n<div class=\"artcardd flexRow\"><a class=\"aritcle_card_img\" title=\"easyDialog \u7b80\u5355\u3001\u5b9e\u7528\u7684\u5f39\u51fa\u5c42\u7ec4\u4ef6\" href=\"https:\/\/www.php.cn\/xiazai\/js\/3489\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-3050\" title=\"5d7f1c6053595619-2-1-1-1-1\" src=\"https:\/\/blog.nonot.cn\/wp-content\/uploads\/replace\/bd7024cde2c62f4afbdb6ad93ad00542.png\" alt=\"5d7f1c6053595619-2-1-1-1-1\" width=\"426\" height=\"703\" \/><\/a><\/p>\n<div class=\"aritcle_card_info flexColumn\"><a title=\"easyDialog \u7b80\u5355\u3001\u5b9e\u7528\u7684\u5f39\u51fa\u5c42\u7ec4\u4ef6\" href=\"https:\/\/www.php.cn\/xiazai\/js\/3489\">easyDialog \u7b80\u5355\u3001\u5b9e\u7528\u7684\u5f39\u51fa\u5c42\u7ec4\u4ef6<\/a>easyDialog\u6ca1\u6709\u6a21\u677f\u673a\u5236\uff0c\u53ea\u8d1f\u8d23\u903b\u8f91\u5c42\u7684\u5f39\u51fa\u6548\u679c\uff0c\u81f3\u4e8e\u5185\u5bb9(\u6d88\u606f\u6846\u3001\u8868\u5355\u3001\u56fe\u7247\u7b49)\u8be5\u5982\u4f55\u5448\u73b0\uff0ceasyDialog\u90fd\u4e0d\u7ba1\uff0c\u5185\u5bb9\u5c5e\u4e8e\u4e1a\u52a1\u5c42\u7684\u4e1c\u897f\uff0c\u4e1a\u52a1\u9700\u6c42\u662f\u5343\u53d8\u4e07\u5316\u7684\uff0c\u5982\u679c\u903b\u8f91\u548c\u4e1a\u52a1\u7ed3\u5408\u5f88\u7d27\u5bc6\uff0c\u90a3\u4e48\u53ef\u79fb\u690d\u6027\u548c\u53ef\u6269\u5c55\u6027\u5c06\u5927\u5927\u964d\u4f4e\u3002<\/p>\n<\/div>\n<p><a class=\"aritcle_card_btn flexRow flexcenter\" title=\"easyDialog \u7b80\u5355\u3001\u5b9e\u7528\u7684\u5f39\u51fa\u5c42\u7ec4\u4ef6\" href=\"https:\/\/www.php.cn\/xiazai\/js\/3489\"><b><\/b>\u4e0b\u8f7d<\/a><\/div>\n<\/div>\n<p>\u8981\u5b9e\u73b0\u52a8\u6001\u52a0\u8f7d\uff0c\u6211\u4eec\u4e3b\u8981\u4f1a\u7528\u5230<code>fetch<\/code>\u00a0API\uff08\u6216\u8005\u8001\u65e7\u4e00\u70b9\u7684<code>XMLHttpRequest<\/code>\uff09\u3002<code>fetch<\/code>\u63d0\u4f9b\u4e86\u4e00\u79cd\u66f4\u73b0\u4ee3\u3001\u66f4\u5f3a\u5927\u7684\u65b9\u5f0f\u6765\u53d1\u8d77\u7f51\u7edc\u8bf7\u6c42\u3002<\/p>\n<p>\u6211\u4eec\u5047\u8bbe\u6709\u4e00\u4e2aAPI\u63a5\u53e3\u00a0<code>\/api\/product\/{id}<\/code>\u00a0\u53ef\u4ee5\u8fd4\u56de\u5546\u54c1\u8be6\u60c5\u3002<\/p>\n<p class=\"line number1 index0 alt2\"><code class=\"javascript comments\">\/\/ ... HTML \u548c CSS \u90e8\u5206\u540c\u4e0a ...<\/code><\/p>\n<p class=\"line number2 index1 alt1\">\n<p class=\"line number3 index2 alt2\"><code class=\"javascript plain\">&lt;script&gt;<\/code><\/p>\n<p class=\"line number4 index3 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const openBtn = document.querySelector(<\/code><code class=\"javascript string\">'.open-modal-btn'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number5 index4 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const closeBtn = document.querySelector(<\/code><code class=\"javascript string\">'.close-modal-btn'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number6 index5 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const modalOverlay = document.getElementById(<\/code><code class=\"javascript string\">'myModalOverlay'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number7 index6 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const modalContentElement = modalOverlay.querySelector(<\/code><code class=\"javascript string\">'.modal-content'<\/code><code class=\"javascript plain\">); <\/code><code class=\"javascript comments\">\/\/ \u83b7\u53d6\u5185\u5bb9\u5bb9\u5668<\/code><\/p>\n<p class=\"line number8 index7 alt1\">\n<p class=\"line number9 index8 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u5047\u8bbe\u6211\u4eec\u6709\u4e00\u4e2a\u52a0\u8f7d\u4e2d\u7684\u6307\u793a\u5668<\/code><\/p>\n<p class=\"line number10 index9 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const loadingIndicator = document.createElement(<\/code><code class=\"javascript string\">'p'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number11 index10 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">loadingIndicator.textContent = <\/code><code class=\"javascript string\">'\u52a0\u8f7d\u4e2d...'<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number12 index11 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">loadingIndicator.style.textAlign = <\/code><code class=\"javascript string\">'center'<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number13 index12 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">loadingIndicator.style.padding = <\/code><code class=\"javascript string\">'20px'<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number14 index13 alt1\">\n<p class=\"line number15 index14 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const originalContent = modalContentElement.innerHTML; <\/code><code class=\"javascript comments\">\/\/ \u4fdd\u5b58\u539f\u59cb\u5185\u5bb9\uff0c\u4ee5\u4fbf\u6062\u590d<\/code><\/p>\n<p class=\"line number16 index15 alt1\">\n<p class=\"line number17 index16 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">async <\/code><code class=\"javascript keyword\">function<\/code> <code class=\"javascript plain\">loadProductDetails(productId) {<\/code><\/p>\n<p class=\"line number18 index17 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u5148\u6e05\u7a7a\u5185\u5bb9\u5e76\u663e\u793a\u52a0\u8f7d\u6307\u793a\u5668<\/code><\/p>\n<p class=\"line number19 index18 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalContentElement.innerHTML = <\/code><code class=\"javascript string\">''<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number20 index19 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalContentElement.appendChild(loadingIndicator);<\/code><\/p>\n<p class=\"line number21 index20 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalOverlay.classList.add(<\/code><code class=\"javascript string\">'active'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number22 index21 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">document.body.style.overflow = <\/code><code class=\"javascript string\">'hidden'<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number23 index22 alt2\">\n<p class=\"line number24 index23 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript keyword\">try<\/code> <code class=\"javascript plain\">{<\/code><\/p>\n<p class=\"line number25 index24 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u6a21\u62df\u7f51\u7edc\u8bf7\u6c42<\/code><\/p>\n<p class=\"line number26 index25 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const response = await fetch(`\/api\/product\/${productId}`); <\/code><code class=\"javascript comments\">\/\/ \u5b9e\u9645\u9879\u76ee\u4e2d\u66ff\u6362\u4e3a\u4f60\u7684API\u5730\u5740<\/code><\/p>\n<p class=\"line number27 index26 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript keyword\">if<\/code> <code class=\"javascript plain\">(!response.ok) {<\/code><\/p>\n<p class=\"line number28 index27 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript keyword\">throw<\/code> <code class=\"javascript keyword\">new<\/code> <code class=\"javascript plain\">Error(`HTTP error! status: ${response.status}`);<\/code><\/p>\n<p class=\"line number29 index28 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">}<\/code><\/p>\n<p class=\"line number30 index29 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const product = await response.json();<\/code><\/p>\n<p class=\"line number31 index30 alt2\">\n<p class=\"line number32 index31 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u6784\u5efa\u65b0\u7684\u5185\u5bb9<\/code><\/p>\n<p class=\"line number33 index32 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalContentElement.innerHTML = `<\/code><\/p>\n<p class=\"line number34 index33 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">&lt;button class=<\/code><code class=\"javascript string\">\"close-modal-btn\"<\/code><code class=\"javascript plain\">&gt;\u00d7&lt;\/button&gt;<\/code><\/p>\n<p class=\"line number35 index34 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">&lt;h2&gt;${product.name}&lt;\/h2&gt;<\/code><\/p>\n<p class=\"line number36 index35 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">&lt;p&gt;\u4ef7\u683c: \u00a5${product.price.toFixed(2)}&lt;\/p&gt;<\/code><\/p>\n<p class=\"line number37 index36 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">&lt;p&gt;${product.description}&lt;\/p&gt;<\/code><\/p>\n<p class=\"line number38 index37 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">@@<\/code><code class=\"javascript preprocessor\">##@@<\/code><\/p>\n<p class=\"line number39 index38 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">`;<\/code><\/p>\n<p class=\"line number40 index39 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u91cd\u65b0\u7ed1\u5b9a\u5173\u95ed\u6309\u94ae\u4e8b\u4ef6\uff0c\u56e0\u4e3a\u5185\u5bb9\u88ab\u66ff\u6362\u4e86<\/code><\/p>\n<p class=\"line number41 index40 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalContentElement.querySelector(<\/code><code class=\"javascript string\">'.close-modal-btn'<\/code><code class=\"javascript plain\">).addEventListener(<\/code><code class=\"javascript string\">'click'<\/code><code class=\"javascript plain\">, closeModal);<\/code><\/p>\n<p class=\"line number42 index41 alt1\">\n<p class=\"line number43 index42 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">} <\/code><code class=\"javascript keyword\">catch<\/code> <code class=\"javascript plain\">(error) {<\/code><\/p>\n<p class=\"line number44 index43 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">console.error(<\/code><code class=\"javascript string\">'\u52a0\u8f7d\u5546\u54c1\u8be6\u60c5\u5931\u8d25:'<\/code><code class=\"javascript plain\">, error);<\/code><\/p>\n<p class=\"line number45 index44 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalContentElement.innerHTML = `<\/code><\/p>\n<p class=\"line number46 index45 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">&lt;button class=<\/code><code class=\"javascript string\">\"close-modal-btn\"<\/code><code class=\"javascript plain\">&gt;\u00d7&lt;\/button&gt;<\/code><\/p>\n<p class=\"line number47 index46 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">&lt;h2&gt;\u52a0\u8f7d\u5931\u8d25&lt;\/h2&gt;<\/code><\/p>\n<p class=\"line number48 index47 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">&lt;p&gt;\u65e0\u6cd5\u83b7\u53d6\u5546\u54c1\u4fe1\u606f\uff0c\u8bf7\u7a0d\u540e\u518d\u8bd5\u3002&lt;\/p&gt;<\/code><\/p>\n<p class=\"line number49 index48 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">`;<\/code><\/p>\n<p class=\"line number50 index49 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalContentElement.querySelector(<\/code><code class=\"javascript string\">'.close-modal-btn'<\/code><code class=\"javascript plain\">).addEventListener(<\/code><code class=\"javascript string\">'click'<\/code><code class=\"javascript plain\">, closeModal);<\/code><\/p>\n<p class=\"line number51 index50 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">}<\/code><\/p>\n<p class=\"line number52 index51 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">}<\/code><\/p>\n<p class=\"line number53 index52 alt2\">\n<p class=\"line number54 index53 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript keyword\">function<\/code> <code class=\"javascript plain\">closeModal() {<\/code><\/p>\n<p class=\"line number55 index54 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalOverlay.classList.remove(<\/code><code class=\"javascript string\">'active'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number56 index55 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">document.body.style.overflow = <\/code><code class=\"javascript string\">''<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number57 index56 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u6062\u590d\u539f\u59cb\u5185\u5bb9\uff0c\u6216\u8005\u4f60\u4e5f\u53ef\u4ee5\u9009\u62e9\u6e05\u7a7a<\/code><\/p>\n<p class=\"line number58 index57 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ modalContentElement.innerHTML = originalContent;<\/code><\/p>\n<p class=\"line number59 index58 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u5982\u679c\u6062\u590d\u539f\u59cb\u5185\u5bb9\uff0c\u9700\u8981\u91cd\u65b0\u7ed1\u5b9a\u539f\u59cb\u7684\u5173\u95ed\u6309\u94ae\u4e8b\u4ef6<\/code><\/p>\n<p class=\"line number60 index59 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">}<\/code><\/p>\n<p class=\"line number61 index60 alt2\">\n<p class=\"line number62 index61 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u7ed1\u5b9a\u6253\u5f00\u6309\u94ae\u4e8b\u4ef6\uff0c\u8fd9\u91cc\u6211\u4eec\u6a21\u62df\u52a0\u8f7dID\u4e3a123\u7684\u5546\u54c1<\/code><\/p>\n<p class=\"line number63 index62 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">openBtn.addEventListener(<\/code><code class=\"javascript string\">'click'<\/code><code class=\"javascript plain\">, () =&gt; loadProductDetails(<\/code><code class=\"javascript string\">'123'<\/code><code class=\"javascript plain\">));<\/code><\/p>\n<p class=\"line number64 index63 alt1\">\n<p class=\"line number65 index64 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u7ed1\u5b9a\u5173\u95ed\u6309\u94ae\u4e8b\u4ef6<\/code><\/p>\n<p class=\"line number66 index65 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">closeBtn.addEventListener(<\/code><code class=\"javascript string\">'click'<\/code><code class=\"javascript plain\">, closeModal); <\/code><code class=\"javascript comments\">\/\/ \u8fd9\u4e2a\u662f\u539f\u59cb\u7684\u5173\u95ed\u6309\u94ae\uff0c\u5982\u679c\u5185\u5bb9\u88ab\u66ff\u6362\uff0c\u8fd9\u4e2a\u53ef\u80fd\u5c31\u4e0d\u5b58\u5728\u4e86\uff0c\u9700\u8981\u91cd\u65b0\u7ed1\u5b9a<\/code><\/p>\n<p class=\"line number67 index66 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u56e0\u6b64\uff0c\u66f4\u7a33\u59a5\u7684\u505a\u6cd5\u662f\u5728\u52a8\u6001\u52a0\u8f7d\u5185\u5bb9\u540e\uff0c\u91cd\u65b0\u7ed9\u65b0\u7684\u5173\u95ed\u6309\u94ae\u7ed1\u5b9a\u4e8b\u4ef6\uff0c\u6216\u8005\u8ba9\u5173\u95ed\u6309\u94ae\u5728 modalContentElement \u5916\u90e8\u3002<\/code><\/p>\n<p class=\"line number68 index67 alt1\">\n<p class=\"line number69 index68 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u66f4\u597d\u7684\u505a\u6cd5\u662f\uff0c\u5173\u95ed\u6309\u94ae\u59cb\u7ec8\u5728 modal-overlay \u5185\u90e8\uff0c modal-content \u5916\u90e8\uff0c\u8fd9\u6837\u5b83\u4e0d\u4f1a\u88ab\u52a8\u6001\u5185\u5bb9\u66ff\u6362<\/code><\/p>\n<p class=\"line number70 index69 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u5047\u8bbecloseBtn\u662f\u5728modal-overlay\u4e0b\u7684\u76f4\u63a5\u5b50\u5143\u7d20\uff0c\u800c\u4e0d\u662fmodal-content\u7684\u5b50\u5143\u7d20<\/code><\/p>\n<p class=\"line number71 index70 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u90a3\u4e48 closeModal() \u5c31\u53ef\u4ee5\u76f4\u63a5\u7ed1\u5b9a\u5230\u8fd9\u4e2a\u552f\u4e00\u7684 closeBtn \u4e0a<\/code><\/p>\n<p class=\"line number72 index71 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u5728\u6211\u7684HTML\u7ed3\u6784\u91cc\uff0ccloseBtn\u662fmodal-content\u7684\u5b50\u5143\u7d20\uff0c\u6240\u4ee5\u66ff\u6362\u5185\u5bb9\u65f6\u9700\u8981\u91cd\u65b0\u7ed1\u5b9a\u3002<\/code><\/p>\n<p class=\"line number73 index72 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u4e3a\u4e86\u7b80\u5316\uff0c\u6211\u628a\u5173\u95ed\u6309\u94ae\u91cd\u65b0\u653e\u5728\u4e86 modal-content \u5185\u90e8\uff0c\u5e76\u5728\u6bcf\u6b21\u52a8\u6001\u52a0\u8f7d\u540e\u91cd\u65b0\u7ed1\u5b9a\u3002<\/code><\/p>\n<p class=\"line number74 index73 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u4e5f\u53ef\u4ee5\u5c06\u5173\u95ed\u6309\u94ae\u653e\u5230 modal-overlay \u7684\u540c\u7ea7\u6216\u4e0a\u7ea7\uff0c\u4f7f\u5176\u4e0d\u53d7 modal-content \u5185\u5bb9\u53d8\u5316\u7684\u5f71\u54cd\u3002<\/code><\/p>\n<p class=\"line number75 index74 alt2\"><code class=\"javascript plain\">&lt;\/script&gt;<\/code><\/p>\n<p>\u8fd9\u6bb5\u4ee3\u7801\u5c55\u793a\u4e86\u5982\u4f55\u5728\u4e00\u4e2a\u5f02\u6b65\u64cd\u4f5c\u4e2d\u66f4\u65b0\u5f39\u51fa\u5c42\u7684\u5185\u5bb9\u3002\u6211\u4e2a\u4eba\u8ba4\u4e3a\uff0c\u5728\u5904\u7406\u52a8\u6001\u5185\u5bb9\u65f6\uff0c\u663e\u793a\u4e00\u4e2a\u201c\u52a0\u8f7d\u4e2d\u201d\u7684\u72b6\u6001\u975e\u5e38\u91cd\u8981\uff0c\u8fd9\u80fd\u7ed9\u7528\u6237\u826f\u597d\u7684\u53cd\u9988\uff0c\u8ba9\u4ed6\u4eec\u77e5\u9053\u4e0d\u662f\u9875\u9762\u5361\u4f4f\u4e86\u3002\u9519\u8bef\u5904\u7406\u4e5f\u540c\u6837\u5173\u952e\uff0c\u5f53API\u8bf7\u6c42\u5931\u8d25\u65f6\uff0c\u544a\u77e5\u7528\u6237\u53d1\u751f\u4e86\u4ec0\u4e48\uff0c\u800c\u4e0d\u662f\u7559\u4e00\u4e2a\u7a7a\u767d\u7684\u5f39\u51fa\u5c42\u3002<\/p>\n<p>\u6211\u8fd9\u91cc\u5c06\u5173\u95ed\u6309\u94ae\u653e\u5728\u4e86<code>modal-content<\/code>\u5185\u90e8\uff0c\u8fd9\u610f\u5473\u7740\u6bcf\u6b21<code>modalContentElement.innerHTML<\/code>\u88ab\u66ff\u6362\u65f6\uff0c\u539f\u6765\u7684\u5173\u95ed\u6309\u94ae\u5c31\u6ca1\u4e86\uff0c\u9700\u8981\u7ed9\u65b0\u7684\u5173\u95ed\u6309\u94ae\u91cd\u65b0\u7ed1\u5b9a\u4e8b\u4ef6\u3002\u8fd9\u662f\u4e00\u79cd\u5e38\u89c1\u7684\u201c\u5751\u201d\uff0c\u9700\u8981\u7279\u522b\u6ce8\u610f\u3002\u4e00\u4e2a\u66f4\u5065\u58ee\u7684\u8bbe\u8ba1\u662f\u5c06\u5173\u95ed\u6309\u94ae\u653e\u5728<code>modal-content<\/code>\u7684\u5916\u90e8\uff0c\u4f46\u4ecd\u5728<code>modal-overlay<\/code>\u5185\u90e8\uff0c\u8fd9\u6837\u5b83\u5c31\u4e0d\u4f1a\u88ab\u52a8\u6001\u5185\u5bb9\u5f71\u54cd\u3002<\/p>\n<h3>\u5982\u4f55\u4f18\u5316\u5f39\u51fa\u5c42\u7684\u7528\u6237\u4f53\u9a8c\uff0c\u6bd4\u5982\u6dfb\u52a0\u952e\u76d8Esc\u5173\u95ed\u548c\u70b9\u51fb\u5916\u90e8\u533a\u57df\u5173\u95ed\uff1f<\/h3>\n<p>\u7528\u6237\u4f53\u9a8c\u662f<a title=\"\u524d\u7aef\" href=\"https:\/\/www.php.cn\/zt\/15813.html\" target=\"_blank\" rel=\"noopener\">\u524d\u7aef<\/a>\u5f00\u53d1\u4e2d\u4e0d\u53ef\u5ffd\u89c6\u7684\u4e00\u73af\u3002\u4e00\u4e2a\u597d\u7684\u5f39\u51fa\u5c42\uff0c\u9664\u4e86\u80fd\u663e\u793a\u5185\u5bb9\uff0c\u8fd8\u5e94\u8be5\u65b9\u4fbf\u7528\u6237\u5173\u95ed\u3002\u6700\u5e38\u89c1\u7684\u4e24\u79cd\u4fbf\u6377\u5173\u95ed\u65b9\u5f0f\u5c31\u662f\u6309<code>Esc<\/code>\u952e\u548c\u70b9\u51fb\u5f39\u51fa\u5c42\u5916\u90e8\u7684\u533a\u57df\u3002<\/p>\n<p>\u6211\u4eec\u53ef\u4ee5\u5728<code>modal-overlay<\/code>\u663e\u793a\u65f6\uff0c\u7ed9<code>document<\/code>\u6dfb\u52a0\u4e00\u4e2a<code>keydown<\/code>\u4e8b\u4ef6\u76d1\u542c\u5668\uff0c\u68c0\u67e5\u6309\u4e0b\u7684\u952e\u662f\u5426\u662f<code>Esc<\/code>\u3002\u81f3\u4e8e\u70b9\u51fb\u5916\u90e8\u533a\u57df\u5173\u95ed\uff0c\u6211\u4eec\u5728\u7b2c\u4e00\u4e2a\u89e3\u51b3\u65b9\u6848\u4e2d\u5176\u5b9e\u5df2\u7ecf\u5b9e\u73b0\u4e86\u4e00\u90e8\u5206\uff1a\u901a\u8fc7\u5224\u65ad<code>event.target === modalOverlay<\/code>\u6765\u786e\u4fdd\u53ea\u6709\u70b9\u51fb\u5230\u906e\u7f69\u5c42\u672c\u8eab\u624d\u5173\u95ed\u3002<\/p>\n<p class=\"line number1 index0 alt2\"><code class=\"javascript comments\">\/\/ ... HTML \u548c CSS \u90e8\u5206\u540c\u4e0a ...<\/code><\/p>\n<p class=\"line number2 index1 alt1\">\n<p class=\"line number3 index2 alt2\"><code class=\"javascript plain\">&lt;script&gt;<\/code><\/p>\n<p class=\"line number4 index3 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const openBtn = document.querySelector(<\/code><code class=\"javascript string\">'.open-modal-btn'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number5 index4 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const closeBtn = document.querySelector(<\/code><code class=\"javascript string\">'.close-modal-btn'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number6 index5 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">const modalOverlay = document.getElementById(<\/code><code class=\"javascript string\">'myModalOverlay'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number7 index6 alt2\">\n<p class=\"line number8 index7 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript keyword\">function<\/code> <code class=\"javascript plain\">openModal() {<\/code><\/p>\n<p class=\"line number9 index8 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalOverlay.classList.add(<\/code><code class=\"javascript string\">'active'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number10 index9 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">document.body.style.overflow = <\/code><code class=\"javascript string\">'hidden'<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number11 index10 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">document.addEventListener(<\/code><code class=\"javascript string\">'keydown'<\/code><code class=\"javascript plain\">, handleEscapeKey); <\/code><code class=\"javascript comments\">\/\/ \u76d1\u542cEsc\u952e<\/code><\/p>\n<p class=\"line number12 index11 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">}<\/code><\/p>\n<p class=\"line number13 index12 alt2\">\n<p class=\"line number14 index13 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript keyword\">function<\/code> <code class=\"javascript plain\">closeModal() {<\/code><\/p>\n<p class=\"line number15 index14 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalOverlay.classList.remove(<\/code><code class=\"javascript string\">'active'<\/code><code class=\"javascript plain\">);<\/code><\/p>\n<p class=\"line number16 index15 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">document.body.style.overflow = <\/code><code class=\"javascript string\">''<\/code><code class=\"javascript plain\">;<\/code><\/p>\n<p class=\"line number17 index16 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">document.removeEventListener(<\/code><code class=\"javascript string\">'keydown'<\/code><code class=\"javascript plain\">, handleEscapeKey); <\/code><code class=\"javascript comments\">\/\/ \u79fb\u9664Esc\u952e\u76d1\u542c\uff0c\u907f\u514d\u4e0d\u5fc5\u8981\u7684\u89e6\u53d1<\/code><\/p>\n<p class=\"line number18 index17 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">}<\/code><\/p>\n<p class=\"line number19 index18 alt2\">\n<p class=\"line number20 index19 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript keyword\">function<\/code> <code class=\"javascript plain\">handleEscapeKey(event) {<\/code><\/p>\n<p class=\"line number21 index20 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript keyword\">if<\/code> <code class=\"javascript plain\">(event.key === <\/code><code class=\"javascript string\">'Escape'<\/code><code class=\"javascript plain\">) {<\/code><\/p>\n<p class=\"line number22 index21 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">closeModal();<\/code><\/p>\n<p class=\"line number23 index22 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">}<\/code><\/p>\n<p class=\"line number24 index23 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">}<\/code><\/p>\n<p class=\"line number25 index24 alt2\">\n<p class=\"line number26 index25 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u6253\u5f00\u6309\u94ae<\/code><\/p>\n<p class=\"line number27 index26 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">openBtn.addEventListener(<\/code><code class=\"javascript string\">'click'<\/code><code class=\"javascript plain\">, openModal);<\/code><\/p>\n<p class=\"line number28 index27 alt1\">\n<p class=\"line number29 index28 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u5173\u95ed\u6309\u94ae<\/code><\/p>\n<p class=\"line number30 index29 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">closeBtn.addEventListener(<\/code><code class=\"javascript string\">'click'<\/code><code class=\"javascript plain\">, closeModal);<\/code><\/p>\n<p class=\"line number31 index30 alt2\">\n<p class=\"line number32 index31 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u70b9\u51fb\u906e\u7f69\u5c42\u5173\u95ed<\/code><\/p>\n<p class=\"line number33 index32 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">modalOverlay.addEventListener(<\/code><code class=\"javascript string\">'click'<\/code><code class=\"javascript plain\">, (event) =&gt; {<\/code><\/p>\n<p class=\"line number34 index33 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript comments\">\/\/ \u786e\u4fdd\u70b9\u51fb\u7684\u662f\u906e\u7f69\u5c42\u672c\u8eab\uff0c\u800c\u4e0d\u662f\u5f39\u51fa\u5c42\u5185\u90e8\u7684\u5185\u5bb9<\/code><\/p>\n<p class=\"line number35 index34 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript keyword\">if<\/code> <code class=\"javascript plain\">(event.target === modalOverlay) {<\/code><\/p>\n<p class=\"line number36 index35 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">closeModal();<\/code><\/p>\n<p class=\"line number37 index36 alt2\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">}<\/code><\/p>\n<p class=\"line number38 index37 alt1\"><code class=\"javascript spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"javascript plain\">});<\/code><\/p>\n<p class=\"line number39 index38 alt2\"><code class=\"javascript plain\">&lt;\/script&gt;<\/code><\/p>\n<p>&nbsp;<\/p>\n<p>\u8fd9\u91cc\u6211\u628a\u6253\u5f00\u548c\u5173\u95ed\u5f39\u51fa\u5c42\u7684\u903b\u8f91\u5c01\u88c5\u6210\u4e86<code>openModal<\/code>\u548c<code>closeModal<\/code>\u4e24\u4e2a\u51fd\u6570\uff0c\u8fd9\u6837\u4ee3\u7801\u66f4\u6e05\u6670\uff0c\u4e5f\u65b9\u4fbf\u5728\u4e0d\u540c\u5730\u65b9\u8c03\u7528\u3002\u5728<code>openModal<\/code>\u65f6\uff0c\u6211\u4eec\u7ed9<code>document<\/code>\u6dfb\u52a0\u4e86<code>keydown<\/code>\u4e8b\u4ef6\u76d1\u542c\uff0c\u4e13\u95e8\u5904\u7406<code>Esc<\/code>\u952e\u3002\u7279\u522b\u8981\u6ce8\u610f\u7684\u662f\uff0c\u5728<code>closeModal<\/code>\u65f6\uff0c\u4e00\u5b9a\u8981\u8bb0\u5f97\u79fb\u9664\u8fd9\u4e2a<code>keydown<\/code>\u4e8b\u4ef6\u76d1\u542c\u5668 (<code>removeEventListener<\/code>)\uff0c\u5426\u5219\u5f53\u5f39\u51fa\u5c42\u5173\u95ed\u540e\uff0c\u7528\u6237\u5728\u9875\u9762\u5176\u4ed6\u5730\u65b9\u6309<code>Esc<\/code>\u952e\uff0c\u53ef\u80fd\u4f1a\u89e6\u53d1\u4e00\u4e9b\u610f\u60f3\u4e0d\u5230\u7684\u884c\u4e3a\uff0c\u6216\u8005\u9020\u6210\u5185\u5b58\u6cc4\u9732\u3002\u8fd9\u662f\u6211\u4ee5\u524d\u8e29\u8fc7\u7684\u4e00\u4e2a\u5c0f\u5751\uff0c\u4e0d\u53ca\u65f6\u6e05\u7406\u4e8b\u4ef6\u76d1\u542c\u5668\uff0c\u53ef\u80fd\u4f1a\u8ba9\u4f60\u7684\u5e94\u7528\u53d8\u5f97\u201c\u5947\u602a\u201d\u3002<\/p>\n<p>\u70b9\u51fb\u5916\u90e8\u533a\u57df\u5173\u95ed\u7684\u903b\u8f91\u4e5f\u66f4\u52a0\u660e\u786e\u4e86\uff0c<code>event.target === modalOverlay<\/code>\u8fd9\u4e2a\u5224\u65ad\u662f\u5173\u952e\uff0c\u5b83\u786e\u4fdd\u4e86\u53ea\u6709\u5f53\u4f60\u76f4\u63a5\u70b9\u51fb\u5230\u534a\u900f\u660e\u7684\u80cc\u666f\u5c42\u65f6\uff0c\u5f39\u51fa\u5c42\u624d\u4f1a\u5173\u95ed\uff0c\u800c\u70b9\u51fb\u5f39\u51fa\u5c42\u5185\u90e8\u7684\u4efb\u4f55\u5143\u7d20\u90fd\u4e0d\u4f1a\u89e6\u53d1\u5173\u95ed\uff0c\u8fd9\u7b26\u5408\u7528\u6237\u7684\u76f4\u89c9\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u5b9e\u73b0\u5f39\u51fa\u5c42\u6548\u679c\uff0c\u6211\u4eec\u4e3b\u8981\u901a\u8fc7JavaScript\u6765\u64cd\u4f5cDOM&hellip;<\/p>\n","protected":false},"author":1,"featured_media":3051,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-3038","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-uncategorized"],"_links":{"self":[{"href":"https:\/\/blog.nonot.cn\/index.php\/wp-json\/wp\/v2\/posts\/3038","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.nonot.cn\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.nonot.cn\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.nonot.cn\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.nonot.cn\/index.php\/wp-json\/wp\/v2\/comments?post=3038"}],"version-history":[{"count":1,"href":"https:\/\/blog.nonot.cn\/index.php\/wp-json\/wp\/v2\/posts\/3038\/revisions"}],"predecessor-version":[{"id":3052,"href":"https:\/\/blog.nonot.cn\/index.php\/wp-json\/wp\/v2\/posts\/3038\/revisions\/3052"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/blog.nonot.cn\/index.php\/wp-json\/wp\/v2\/media\/3051"}],"wp:attachment":[{"href":"https:\/\/blog.nonot.cn\/index.php\/wp-json\/wp\/v2\/media?parent=3038"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.nonot.cn\/index.php\/wp-json\/wp\/v2\/categories?post=3038"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.nonot.cn\/index.php\/wp-json\/wp\/v2\/tags?post=3038"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}