index.html 100 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width,initial-scale=1">
  6. <title>《JavaScript高级程序设计》笔记 | 彪哥博客</title>
  7. <meta name="generator" content="VuePress 1.9.5">
  8. <link rel="icon" href="/blog/img/favicon.ico">
  9. <meta name="description" content="web前端技术博客,专注web前端学习与总结。JavaScript,js,ES6,TypeScript,vue,React,python,css3,html5,Node,git,github等技术文章。">
  10. <meta name="keywords" content="前端博客,个人技术博客,前端,前端开发,前端框架,web前端,前端面试题,技术文档,学习,面试,JavaScript,js,ES6,TypeScript,vue,python,css3,html5,Node,git,github,markdown">
  11. <meta name="theme-color" content="#11a8cd">
  12. <link rel="preload" href="/blog/assets/css/0.styles.dc03b589.css" as="style"><link rel="preload" href="/blog/assets/js/app.90754bd5.js" as="script"><link rel="preload" href="/blog/assets/js/2.106f41fb.js" as="script"><link rel="preload" href="/blog/assets/js/3.6748bd5c.js" as="script"><link rel="preload" href="/blog/assets/js/25.b4de33d1.js" as="script"><link rel="prefetch" href="/blog/assets/js/10.cad3aa70.js"><link rel="prefetch" href="/blog/assets/js/100.08a8b2d8.js"><link rel="prefetch" href="/blog/assets/js/101.2aabb12c.js"><link rel="prefetch" href="/blog/assets/js/102.13f3cc4d.js"><link rel="prefetch" href="/blog/assets/js/103.c19aee03.js"><link rel="prefetch" href="/blog/assets/js/104.91a6aec1.js"><link rel="prefetch" href="/blog/assets/js/105.71de1aa4.js"><link rel="prefetch" href="/blog/assets/js/106.207422de.js"><link rel="prefetch" href="/blog/assets/js/107.bf754f60.js"><link rel="prefetch" href="/blog/assets/js/108.87ddbf21.js"><link rel="prefetch" href="/blog/assets/js/109.de6075c6.js"><link rel="prefetch" href="/blog/assets/js/11.f2e9eca8.js"><link rel="prefetch" href="/blog/assets/js/110.f19c57ae.js"><link rel="prefetch" href="/blog/assets/js/111.da99a105.js"><link rel="prefetch" href="/blog/assets/js/112.9dd75c6f.js"><link rel="prefetch" href="/blog/assets/js/113.9322f157.js"><link rel="prefetch" href="/blog/assets/js/114.c5150cc6.js"><link rel="prefetch" href="/blog/assets/js/115.4fb547bf.js"><link rel="prefetch" href="/blog/assets/js/116.2ddf1aa8.js"><link rel="prefetch" href="/blog/assets/js/117.3c970f48.js"><link rel="prefetch" href="/blog/assets/js/118.921e1d54.js"><link rel="prefetch" href="/blog/assets/js/119.0141defb.js"><link rel="prefetch" href="/blog/assets/js/12.98512c60.js"><link rel="prefetch" href="/blog/assets/js/120.de47a761.js"><link rel="prefetch" href="/blog/assets/js/121.a0b3693a.js"><link rel="prefetch" href="/blog/assets/js/122.6c7dd225.js"><link rel="prefetch" href="/blog/assets/js/123.dbff103c.js"><link rel="prefetch" href="/blog/assets/js/124.493776ef.js"><link rel="prefetch" href="/blog/assets/js/125.554c9fbf.js"><link rel="prefetch" href="/blog/assets/js/126.2421fe84.js"><link rel="prefetch" href="/blog/assets/js/127.805f10a4.js"><link rel="prefetch" href="/blog/assets/js/128.6543adba.js"><link rel="prefetch" href="/blog/assets/js/129.d7c56b92.js"><link rel="prefetch" href="/blog/assets/js/13.a79fa0c7.js"><link rel="prefetch" href="/blog/assets/js/130.593d21f0.js"><link rel="prefetch" href="/blog/assets/js/131.4c90d8b8.js"><link rel="prefetch" href="/blog/assets/js/132.4ad12bdc.js"><link rel="prefetch" href="/blog/assets/js/133.485de1b9.js"><link rel="prefetch" href="/blog/assets/js/134.78bc8f57.js"><link rel="prefetch" href="/blog/assets/js/135.47498729.js"><link rel="prefetch" href="/blog/assets/js/136.d99350df.js"><link rel="prefetch" href="/blog/assets/js/137.57ba6d3f.js"><link rel="prefetch" href="/blog/assets/js/138.d976c801.js"><link rel="prefetch" href="/blog/assets/js/139.766f20b7.js"><link rel="prefetch" href="/blog/assets/js/14.0fdf0c78.js"><link rel="prefetch" href="/blog/assets/js/140.0d9b8fbc.js"><link rel="prefetch" href="/blog/assets/js/141.128b6e26.js"><link rel="prefetch" href="/blog/assets/js/142.e004a584.js"><link rel="prefetch" href="/blog/assets/js/143.5a19a0b2.js"><link rel="prefetch" href="/blog/assets/js/144.5f397211.js"><link rel="prefetch" href="/blog/assets/js/145.cde5f3a0.js"><link rel="prefetch" href="/blog/assets/js/146.4185092c.js"><link rel="prefetch" href="/blog/assets/js/147.ac0e55d3.js"><link rel="prefetch" href="/blog/assets/js/148.30f02604.js"><link rel="prefetch" href="/blog/assets/js/149.760a79ed.js"><link rel="prefetch" href="/blog/assets/js/15.fce722b2.js"><link rel="prefetch" href="/blog/assets/js/150.3a1675b7.js"><link rel="prefetch" href="/blog/assets/js/151.0d73a46e.js"><link rel="prefetch" href="/blog/assets/js/152.c9c054d4.js"><link rel="prefetch" href="/blog/assets/js/153.b007c8a2.js"><link rel="prefetch" href="/blog/assets/js/154.a3acc6bf.js"><link rel="prefetch" href="/blog/assets/js/155.b5c0abcd.js"><link rel="prefetch" href="/blog/assets/js/156.2ba750fc.js"><link rel="prefetch" href="/blog/assets/js/157.fe92af0c.js"><link rel="prefetch" href="/blog/assets/js/158.e16fda40.js"><link rel="prefetch" href="/blog/assets/js/159.7fc7fd44.js"><link rel="prefetch" href="/blog/assets/js/16.871928af.js"><link rel="prefetch" href="/blog/assets/js/160.b581a0f4.js"><link rel="prefetch" href="/blog/assets/js/161.97acae68.js"><link rel="prefetch" href="/blog/assets/js/162.cec1b9a3.js"><link rel="prefetch" href="/blog/assets/js/163.a00f98f7.js"><link rel="prefetch" href="/blog/assets/js/164.cbf4cf52.js"><link rel="prefetch" href="/blog/assets/js/165.bc7a523a.js"><link rel="prefetch" href="/blog/assets/js/166.ca626fb4.js"><link rel="prefetch" href="/blog/assets/js/167.0ca68106.js"><link rel="prefetch" href="/blog/assets/js/168.2e605db8.js"><link rel="prefetch" href="/blog/assets/js/169.401b96d4.js"><link rel="prefetch" href="/blog/assets/js/17.2399cb2b.js"><link rel="prefetch" href="/blog/assets/js/170.7c8b0366.js"><link rel="prefetch" href="/blog/assets/js/171.c3155533.js"><link rel="prefetch" href="/blog/assets/js/172.b659d767.js"><link rel="prefetch" href="/blog/assets/js/173.62c681db.js"><link rel="prefetch" href="/blog/assets/js/174.5c66f092.js"><link rel="prefetch" href="/blog/assets/js/175.d41dd28b.js"><link rel="prefetch" href="/blog/assets/js/176.e60d7f0a.js"><link rel="prefetch" href="/blog/assets/js/177.10de95b1.js"><link rel="prefetch" href="/blog/assets/js/178.f301674d.js"><link rel="prefetch" href="/blog/assets/js/179.77bb52e9.js"><link rel="prefetch" href="/blog/assets/js/18.c338fe95.js"><link rel="prefetch" href="/blog/assets/js/180.d2a4e612.js"><link rel="prefetch" href="/blog/assets/js/181.a53e32e0.js"><link rel="prefetch" href="/blog/assets/js/182.38687994.js"><link rel="prefetch" href="/blog/assets/js/183.544fef00.js"><link rel="prefetch" href="/blog/assets/js/184.711e54a6.js"><link rel="prefetch" href="/blog/assets/js/185.20075148.js"><link rel="prefetch" href="/blog/assets/js/186.08c67f20.js"><link rel="prefetch" href="/blog/assets/js/187.7ca2d0c6.js"><link rel="prefetch" href="/blog/assets/js/188.cd167879.js"><link rel="prefetch" href="/blog/assets/js/189.e8e2eb21.js"><link rel="prefetch" href="/blog/assets/js/19.6b963460.js"><link rel="prefetch" href="/blog/assets/js/190.8b557318.js"><link rel="prefetch" href="/blog/assets/js/191.10d0f80b.js"><link rel="prefetch" href="/blog/assets/js/192.127fef4c.js"><link rel="prefetch" href="/blog/assets/js/193.781690eb.js"><link rel="prefetch" href="/blog/assets/js/194.4b375e2e.js"><link rel="prefetch" href="/blog/assets/js/195.003e3d67.js"><link rel="prefetch" href="/blog/assets/js/196.7a3f55e5.js"><link rel="prefetch" href="/blog/assets/js/197.30d4c5b4.js"><link rel="prefetch" href="/blog/assets/js/198.628c2c1a.js"><link rel="prefetch" href="/blog/assets/js/199.d7c8cbb8.js"><link rel="prefetch" href="/blog/assets/js/20.839dae41.js"><link rel="prefetch" href="/blog/assets/js/200.1fed86d2.js"><link rel="prefetch" href="/blog/assets/js/201.5ba078d9.js"><link rel="prefetch" href="/blog/assets/js/202.b49b23f4.js"><link rel="prefetch" href="/blog/assets/js/203.d88a03d9.js"><link rel="prefetch" href="/blog/assets/js/204.fb928277.js"><link rel="prefetch" href="/blog/assets/js/205.432c3d8d.js"><link rel="prefetch" href="/blog/assets/js/206.ed726599.js"><link rel="prefetch" href="/blog/assets/js/207.c3794556.js"><link rel="prefetch" href="/blog/assets/js/208.416f7a9e.js"><link rel="prefetch" href="/blog/assets/js/209.d396aad5.js"><link rel="prefetch" href="/blog/assets/js/21.bd21bd29.js"><link rel="prefetch" href="/blog/assets/js/210.02e4ee2f.js"><link rel="prefetch" href="/blog/assets/js/211.0f8a9304.js"><link rel="prefetch" href="/blog/assets/js/212.9220dd3d.js"><link rel="prefetch" href="/blog/assets/js/213.89521ebd.js"><link rel="prefetch" href="/blog/assets/js/214.cd5ec468.js"><link rel="prefetch" href="/blog/assets/js/215.0084d772.js"><link rel="prefetch" href="/blog/assets/js/216.ebd468b9.js"><link rel="prefetch" href="/blog/assets/js/217.fac21407.js"><link rel="prefetch" href="/blog/assets/js/218.9793e19a.js"><link rel="prefetch" href="/blog/assets/js/219.b99343b6.js"><link rel="prefetch" href="/blog/assets/js/22.e6bcf65d.js"><link rel="prefetch" href="/blog/assets/js/220.8065033b.js"><link rel="prefetch" href="/blog/assets/js/221.97268a80.js"><link rel="prefetch" href="/blog/assets/js/222.22bf261f.js"><link rel="prefetch" href="/blog/assets/js/223.d5ff1bff.js"><link rel="prefetch" href="/blog/assets/js/224.364b4b11.js"><link rel="prefetch" href="/blog/assets/js/225.bd8b00c7.js"><link rel="prefetch" href="/blog/assets/js/226.78192713.js"><link rel="prefetch" href="/blog/assets/js/227.06ec006e.js"><link rel="prefetch" href="/blog/assets/js/228.166546a8.js"><link rel="prefetch" href="/blog/assets/js/229.fd44d2be.js"><link rel="prefetch" href="/blog/assets/js/23.ebbc3fd3.js"><link rel="prefetch" href="/blog/assets/js/230.109a1752.js"><link rel="prefetch" href="/blog/assets/js/231.c6faedb6.js"><link rel="prefetch" href="/blog/assets/js/232.f938a3a8.js"><link rel="prefetch" href="/blog/assets/js/233.0dc59324.js"><link rel="prefetch" href="/blog/assets/js/234.bb73adca.js"><link rel="prefetch" href="/blog/assets/js/235.97ed69db.js"><link rel="prefetch" href="/blog/assets/js/236.a8c51930.js"><link rel="prefetch" href="/blog/assets/js/237.6ae31c88.js"><link rel="prefetch" href="/blog/assets/js/238.2f5c56ae.js"><link rel="prefetch" href="/blog/assets/js/239.506a4e9f.js"><link rel="prefetch" href="/blog/assets/js/24.19bd04ec.js"><link rel="prefetch" href="/blog/assets/js/26.0bb98ba9.js"><link rel="prefetch" href="/blog/assets/js/27.df98327e.js"><link rel="prefetch" href="/blog/assets/js/28.31289bac.js"><link rel="prefetch" href="/blog/assets/js/29.45af5621.js"><link rel="prefetch" href="/blog/assets/js/30.d5c08e66.js"><link rel="prefetch" href="/blog/assets/js/31.78e43a68.js"><link rel="prefetch" href="/blog/assets/js/32.53ca76ee.js"><link rel="prefetch" href="/blog/assets/js/33.081e8ef6.js"><link rel="prefetch" href="/blog/assets/js/34.cb1866c1.js"><link rel="prefetch" href="/blog/assets/js/35.314ba98e.js"><link rel="prefetch" href="/blog/assets/js/36.1f6a5fae.js"><link rel="prefetch" href="/blog/assets/js/37.45e6d22f.js"><link rel="prefetch" href="/blog/assets/js/38.70b82353.js"><link rel="prefetch" href="/blog/assets/js/39.df6c26ac.js"><link rel="prefetch" href="/blog/assets/js/4.44654b1a.js"><link rel="prefetch" href="/blog/assets/js/40.80101c19.js"><link rel="prefetch" href="/blog/assets/js/41.2b5e8c27.js"><link rel="prefetch" href="/blog/assets/js/42.c6ded3fe.js"><link rel="prefetch" href="/blog/assets/js/43.6d9424d6.js"><link rel="prefetch" href="/blog/assets/js/44.835e4b5c.js"><link rel="prefetch" href="/blog/assets/js/45.d74d29a2.js"><link rel="prefetch" href="/blog/assets/js/46.d15a7dc0.js"><link rel="prefetch" href="/blog/assets/js/47.8d66ca97.js"><link rel="prefetch" href="/blog/assets/js/48.3c1102e1.js"><link rel="prefetch" href="/blog/assets/js/49.e17a3436.js"><link rel="prefetch" href="/blog/assets/js/5.88de390f.js"><link rel="prefetch" href="/blog/assets/js/50.6750f186.js"><link rel="prefetch" href="/blog/assets/js/51.9f93af9f.js"><link rel="prefetch" href="/blog/assets/js/52.f3ef3b5e.js"><link rel="prefetch" href="/blog/assets/js/53.a6bacd25.js"><link rel="prefetch" href="/blog/assets/js/54.dbb7c9ab.js"><link rel="prefetch" href="/blog/assets/js/55.2562d0c8.js"><link rel="prefetch" href="/blog/assets/js/56.14ea4931.js"><link rel="prefetch" href="/blog/assets/js/57.a2fad780.js"><link rel="prefetch" href="/blog/assets/js/58.8165b971.js"><link rel="prefetch" href="/blog/assets/js/59.556cab0d.js"><link rel="prefetch" href="/blog/assets/js/6.277038ca.js"><link rel="prefetch" href="/blog/assets/js/60.f048aa7c.js"><link rel="prefetch" href="/blog/assets/js/61.bdb307a8.js"><link rel="prefetch" href="/blog/assets/js/62.37a94f10.js"><link rel="prefetch" href="/blog/assets/js/63.74811780.js"><link rel="prefetch" href="/blog/assets/js/64.81f21b8a.js"><link rel="prefetch" href="/blog/assets/js/65.d970ff03.js"><link rel="prefetch" href="/blog/assets/js/66.cb805d9b.js"><link rel="prefetch" href="/blog/assets/js/67.39f85baa.js"><link rel="prefetch" href="/blog/assets/js/68.7f79766a.js"><link rel="prefetch" href="/blog/assets/js/69.fa8624bd.js"><link rel="prefetch" href="/blog/assets/js/7.e0a6d1b0.js"><link rel="prefetch" href="/blog/assets/js/70.1f3e978d.js"><link rel="prefetch" href="/blog/assets/js/71.13cd9358.js"><link rel="prefetch" href="/blog/assets/js/72.739b22a8.js"><link rel="prefetch" href="/blog/assets/js/73.95f69ae2.js"><link rel="prefetch" href="/blog/assets/js/74.b6624f6a.js"><link rel="prefetch" href="/blog/assets/js/75.b0d9aa06.js"><link rel="prefetch" href="/blog/assets/js/76.681b78df.js"><link rel="prefetch" href="/blog/assets/js/77.46f6e413.js"><link rel="prefetch" href="/blog/assets/js/78.aebd00ee.js"><link rel="prefetch" href="/blog/assets/js/79.1b784d15.js"><link rel="prefetch" href="/blog/assets/js/8.9428e7ee.js"><link rel="prefetch" href="/blog/assets/js/80.1f550d53.js"><link rel="prefetch" href="/blog/assets/js/81.101cc131.js"><link rel="prefetch" href="/blog/assets/js/82.077c8298.js"><link rel="prefetch" href="/blog/assets/js/83.2e375d11.js"><link rel="prefetch" href="/blog/assets/js/84.38102a34.js"><link rel="prefetch" href="/blog/assets/js/85.24532d6a.js"><link rel="prefetch" href="/blog/assets/js/86.1dabbf00.js"><link rel="prefetch" href="/blog/assets/js/87.763da0f2.js"><link rel="prefetch" href="/blog/assets/js/88.ff6e5f7c.js"><link rel="prefetch" href="/blog/assets/js/89.187e5e16.js"><link rel="prefetch" href="/blog/assets/js/9.da143545.js"><link rel="prefetch" href="/blog/assets/js/90.3c8cff94.js"><link rel="prefetch" href="/blog/assets/js/91.a50bd44d.js"><link rel="prefetch" href="/blog/assets/js/92.5484868f.js"><link rel="prefetch" href="/blog/assets/js/93.c8ee75e3.js"><link rel="prefetch" href="/blog/assets/js/94.b18a3e9b.js"><link rel="prefetch" href="/blog/assets/js/95.cddef6ae.js"><link rel="prefetch" href="/blog/assets/js/96.80e5a938.js"><link rel="prefetch" href="/blog/assets/js/97.1f5e5197.js"><link rel="prefetch" href="/blog/assets/js/98.e3a275c8.js"><link rel="prefetch" href="/blog/assets/js/99.d33bf89e.js">
  13. <link rel="stylesheet" href="/blog/assets/css/0.styles.dc03b589.css">
  14. </head>
  15. <body class="theme-mode-light">
  16. <div id="app" data-server-rendered="true"><div class="theme-container sidebar-open have-rightmenu"><header class="navbar blur"><div title="目录" class="sidebar-button"><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" role="img" viewBox="0 0 448 512" class="icon"><path fill="currentColor" d="M436 124H12c-6.627 0-12-5.373-12-12V80c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12z"></path></svg></div> <a href="/blog/" class="home-link router-link-active"><img src="/blog/img/logo.png" alt="彪哥博客" class="logo"> <span class="site-name can-hide">彪哥博客</span></a> <div class="links"><div class="search-box"><input aria-label="Search" autocomplete="off" spellcheck="false" value=""> <!----></div> <nav class="nav-links can-hide"><div class="nav-item"><a href="/blog/" class="nav-link">首页</a></div><div class="nav-item"><a href="http://fseller.com" target="_blank" rel="noopener noreferrer" class="nav-link external">
  17. 个人游戏网站
  18. <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="前端" class="dropdown-title"><a href="/blog/web/" class="link-title">前端</a> <span class="title" style="display:none;">前端</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><h4>前端文章</h4> <ul class="dropdown-subitem-wrapper"><li class="dropdown-subitem"><a href="/blog/pages/8143cc480faf9a11/" class="nav-link">JavaScript</a></li></ul></li><li class="dropdown-item"><h4>学习笔记</h4> <ul class="dropdown-subitem-wrapper"><li class="dropdown-subitem"><a href="/blog/note/javascript/" class="nav-link">《JavaScript教程》</a></li><li class="dropdown-subitem"><a href="/blog/note/js/" aria-current="page" class="nav-link router-link-exact-active router-link-active">《JavaScript高级程序设计》</a></li><li class="dropdown-subitem"><a href="/blog/note/es6/" class="nav-link">《ES6 教程》</a></li><li class="dropdown-subitem"><a href="/blog/note/vue/" class="nav-link">《Vue》</a></li><li class="dropdown-subitem"><a href="/blog/note/react/" class="nav-link">《React》</a></li><li class="dropdown-subitem"><a href="/blog/note/typescript-axios/" class="nav-link">《TypeScript 从零实现 axios》</a></li><li class="dropdown-subitem"><a href="/blog/note/git/" class="nav-link">《Git》</a></li><li class="dropdown-subitem"><a href="/blog/pages/51afd6/" class="nav-link">TypeScript</a></li><li class="dropdown-subitem"><a href="/blog/pages/4643cd/" class="nav-link">JS设计模式总结</a></li></ul></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="页面" class="dropdown-title"><a href="/blog/ui/" class="link-title">页面</a> <span class="title" style="display:none;">页面</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/blog/pages/8309a5b876fc95e3/" class="nav-link">HTML</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/0a83b083bdf257cb/" class="nav-link">CSS</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="技术" class="dropdown-title"><a href="/blog/technology/" class="link-title">技术</a> <span class="title" style="display:none;">技术</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/blog/pages/9a7ee40fc232253e/" class="nav-link">技术文档</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/4c778760be26d8b3/" class="nav-link">GitHub技巧</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/117708e0af7f0bd9/" class="nav-link">Nodejs</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/41f87d890d0a02af/" class="nav-link">博客搭建</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="更多" class="dropdown-title"><a href="/blog/more/" class="link-title">更多</a> <span class="title" style="display:none;">更多</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/blog/pages/f2a556/" class="nav-link">学习</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/aea6571b7a8bae86/" class="nav-link">面试</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/2d615df9a36a98ed/" class="nav-link">心情杂货</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/baaa02/" class="nav-link">实用技巧</a></li><li class="dropdown-item"><!----> <a href="/blog/friends/" class="nav-link">友情链接</a></li></ul></div></div><div class="nav-item"><a href="/blog/about/" class="nav-link">关于</a></div><div class="nav-item"><a href="/blog/pages/beb6c0bd8a66cea6/" class="nav-link">收藏</a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="索引" class="dropdown-title"><a href="/blog/archives/" class="link-title">索引</a> <span class="title" style="display:none;">索引</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/blog/categories/" class="nav-link">分类</a></li><li class="dropdown-item"><!----> <a href="/blog/tags/" class="nav-link">标签</a></li><li class="dropdown-item"><!----> <a href="/blog/archives/" class="nav-link">归档</a></li></ul></div></div> <a href="https://github.com/heBody/blog" target="_blank" rel="noopener noreferrer" class="repo-link">
  19. GitHub
  20. <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></nav></div></header> <div class="sidebar-mask"></div> <div class="sidebar-hover-trigger"></div> <aside class="sidebar" style="display:none;"><div class="blogger"><img src="/blog/img/head.jpg"> <div class="blogger-info"><h3>彪哥</h3> <span>爱好前端</span></div></div> <nav class="nav-links"><div class="nav-item"><a href="/blog/" class="nav-link">首页</a></div><div class="nav-item"><a href="http://fseller.com" target="_blank" rel="noopener noreferrer" class="nav-link external">
  21. 个人游戏网站
  22. <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="前端" class="dropdown-title"><a href="/blog/web/" class="link-title">前端</a> <span class="title" style="display:none;">前端</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><h4>前端文章</h4> <ul class="dropdown-subitem-wrapper"><li class="dropdown-subitem"><a href="/blog/pages/8143cc480faf9a11/" class="nav-link">JavaScript</a></li></ul></li><li class="dropdown-item"><h4>学习笔记</h4> <ul class="dropdown-subitem-wrapper"><li class="dropdown-subitem"><a href="/blog/note/javascript/" class="nav-link">《JavaScript教程》</a></li><li class="dropdown-subitem"><a href="/blog/note/js/" aria-current="page" class="nav-link router-link-exact-active router-link-active">《JavaScript高级程序设计》</a></li><li class="dropdown-subitem"><a href="/blog/note/es6/" class="nav-link">《ES6 教程》</a></li><li class="dropdown-subitem"><a href="/blog/note/vue/" class="nav-link">《Vue》</a></li><li class="dropdown-subitem"><a href="/blog/note/react/" class="nav-link">《React》</a></li><li class="dropdown-subitem"><a href="/blog/note/typescript-axios/" class="nav-link">《TypeScript 从零实现 axios》</a></li><li class="dropdown-subitem"><a href="/blog/note/git/" class="nav-link">《Git》</a></li><li class="dropdown-subitem"><a href="/blog/pages/51afd6/" class="nav-link">TypeScript</a></li><li class="dropdown-subitem"><a href="/blog/pages/4643cd/" class="nav-link">JS设计模式总结</a></li></ul></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="页面" class="dropdown-title"><a href="/blog/ui/" class="link-title">页面</a> <span class="title" style="display:none;">页面</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/blog/pages/8309a5b876fc95e3/" class="nav-link">HTML</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/0a83b083bdf257cb/" class="nav-link">CSS</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="技术" class="dropdown-title"><a href="/blog/technology/" class="link-title">技术</a> <span class="title" style="display:none;">技术</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/blog/pages/9a7ee40fc232253e/" class="nav-link">技术文档</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/4c778760be26d8b3/" class="nav-link">GitHub技巧</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/117708e0af7f0bd9/" class="nav-link">Nodejs</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/41f87d890d0a02af/" class="nav-link">博客搭建</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="更多" class="dropdown-title"><a href="/blog/more/" class="link-title">更多</a> <span class="title" style="display:none;">更多</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/blog/pages/f2a556/" class="nav-link">学习</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/aea6571b7a8bae86/" class="nav-link">面试</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/2d615df9a36a98ed/" class="nav-link">心情杂货</a></li><li class="dropdown-item"><!----> <a href="/blog/pages/baaa02/" class="nav-link">实用技巧</a></li><li class="dropdown-item"><!----> <a href="/blog/friends/" class="nav-link">友情链接</a></li></ul></div></div><div class="nav-item"><a href="/blog/about/" class="nav-link">关于</a></div><div class="nav-item"><a href="/blog/pages/beb6c0bd8a66cea6/" class="nav-link">收藏</a></div><div class="nav-item"><div class="dropdown-wrapper"><button type="button" aria-label="索引" class="dropdown-title"><a href="/blog/archives/" class="link-title">索引</a> <span class="title" style="display:none;">索引</span> <span class="arrow right"></span></button> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/blog/categories/" class="nav-link">分类</a></li><li class="dropdown-item"><!----> <a href="/blog/tags/" class="nav-link">标签</a></li><li class="dropdown-item"><!----> <a href="/blog/archives/" class="nav-link">归档</a></li></ul></div></div> <a href="https://github.com/heBody/blog" target="_blank" rel="noopener noreferrer" class="repo-link">
  23. GitHub
  24. <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></nav> <ul class="sidebar-links"><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>JavaScript文章</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading open"><span>学习笔记</span> <span class="arrow down"></span></p> <ul class="sidebar-links sidebar-group-items"><li><a href="/blog/note/javascript/" class="sidebar-link">《JavaScript教程》笔记</a></li><li><a href="/blog/note/js/" aria-current="page" class="active sidebar-link">《JavaScript高级程序设计》笔记</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第1章-javascript简介" class="sidebar-link">第1章 JavaScript简介</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第2章-在html中使用javascript" class="sidebar-link">第2章 在HTML中使用JavaScript</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第3章-基本概念" class="sidebar-link">第3章 基本概念</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第4章-变量、作用域和内存问题" class="sidebar-link">第4章 变量、作用域和内存问题</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第5章-引用类型" class="sidebar-link">第5章 引用类型</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header level3"><a href="/blog/note/js/#array类型" class="sidebar-link">Array类型</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#join-转换方法-不改原数组" class="sidebar-link">join() 转换方法 (不改原数组)</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#栈方法-后进先出-push-、pop-改变原数组" class="sidebar-link">栈方法,后进先出 push() 、pop() (改变原数组)</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#队列方法-先进先出-push-、shift-、unshift-改变原数组" class="sidebar-link">队列方法,先进先出 push()、shift() 、unshift() (改变原数组)</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#重排序方法-reverse-反转-sort-排序-改变原数组" class="sidebar-link">重排序方法 reverse() 反转 sort() 排序 (改变原数组)</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#操作方法-concat-拼接-slice-切片-splice-移接" class="sidebar-link">操作方法 concat() 拼接,slice() 切片,splice() 移接</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#位置方法-indexof-、lastindexof" class="sidebar-link">位置方法 indexOf()、lastIndexOf()</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#迭代方法-every-、some-、filter-、map-、foreach-都不会改变原数组" class="sidebar-link">迭代方法 every()、some() 、filter()、map() 、forEach() (都不会改变原数组)</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#归并方法-reduce-reduceright" class="sidebar-link">归并方法 reduce() reduceRight()</a></li></ul></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第6章-面向对象的程序设计" class="sidebar-link">第6章 面向对象的程序设计</a><ul class="sidebar-sub-headers"><li class="sidebar-sub-header level3"><a href="/blog/note/js/#_6-1-理解对象" class="sidebar-link">6.1 理解对象</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#_6-1-1-对象的属性" class="sidebar-link">6.1.1 对象的属性</a></li><li class="sidebar-sub-header level5"><a href="/blog/note/js/#_1-数据属性" class="sidebar-link">1.数据属性</a></li><li class="sidebar-sub-header level5"><a href="/blog/note/js/#_2-访问器属性" class="sidebar-link">2.访问器属性</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#_6-1-2-定义多个属性" class="sidebar-link">6.1.2 定义多个属性</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#_6-1-3-读取属性的特性-描述符对象" class="sidebar-link">6.1.3 读取属性的特性(描述符对象)</a></li><li class="sidebar-sub-header level3"><a href="/blog/note/js/#_6-2-创建对象" class="sidebar-link">6.2 创建对象</a></li><li class="sidebar-sub-header level4"><a href="/blog/note/js/#_6-2-1-工厂模式" class="sidebar-link">6.2.1 工厂模式</a></li></ul></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第7章-函数表达式" class="sidebar-link">第7章 函数表达式</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第8章-bom" class="sidebar-link">第8章 BOM</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第9章-客户端检测" class="sidebar-link">第9章 客户端检测</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第10章-dom" class="sidebar-link">第10章 DOM</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第11章-dom扩展" class="sidebar-link">第11章 DOM扩展</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第12章-dom2和dom3" class="sidebar-link">第12章 DOM2和DOM3</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第13章-事件" class="sidebar-link">第13章 事件</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第14章-表单脚本" class="sidebar-link">第14章 表单脚本</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第15章-使用canvas绘图" class="sidebar-link">第15章 使用Canvas绘图</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第16章-html5脚本编程" class="sidebar-link">第16章 HTML5脚本编程</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第17章-错误处理与调试" class="sidebar-link">第17章 错误处理与调试</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第18章-javascript与xml" class="sidebar-link">第18章 JavaScript与XML</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第19章-e4x" class="sidebar-link">第19章 E4X</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第20章-json" class="sidebar-link">第20章 JSON</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第21章-ajax与comet" class="sidebar-link">第21章 Ajax与Comet</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第22章-高级技巧" class="sidebar-link">第22章 高级技巧</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第23章-离线应用与客户端存储" class="sidebar-link">第23章 离线应用与客户端存储</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第24章-最佳实践" class="sidebar-link">第24章 最佳实践</a></li><li class="sidebar-sub-header level2"><a href="/blog/note/js/#第25章-新兴的api" class="sidebar-link">第25章 新兴的API</a></li></ul></li><li><a href="/blog/note/es6/" class="sidebar-link">《ES6 教程》笔记</a></li><li><a href="/blog/note/vue/" class="sidebar-link">《Vue》笔记</a></li><li><a href="/blog/note/react/" class="sidebar-link">《React》笔记</a></li><li><a href="/blog/note/typescript-axios/" class="sidebar-link">《TypeScript 从零实现 axios》</a></li><li><a href="/blog/note/git/" class="sidebar-link">《Git》学习笔记</a></li><li><a href="/blog/pages/51afd6/" class="sidebar-link">TypeScript笔记</a></li><li><a href="/blog/note/wx-miniprogram/" class="sidebar-link">小程序笔记</a></li><li><a href="/blog/pages/4643cd/" class="sidebar-link">JS设计模式总结笔记</a></li></ul></section></li></ul> </aside> <div><main class="page"><div class="theme-vdoing-wrapper "><div class="articleInfo-wrap" data-v-06970110><div class="articleInfo" data-v-06970110><ul class="breadcrumbs" data-v-06970110><li data-v-06970110><a href="/blog/" title="首页" class="iconfont icon-home router-link-active" data-v-06970110></a></li> <li data-v-06970110><a href="/blog/web/#前端" data-v-06970110>前端</a></li><li data-v-06970110><a href="/blog/web/#学习笔记" data-v-06970110>学习笔记</a></li></ul> <div class="info" data-v-06970110><div title="作者" class="author iconfont icon-touxiang" data-v-06970110><a href="https://github.com/heBody" target="_blank" title="作者" class="beLink" data-v-06970110>heBody</a></div> <div title="创建时间" class="date iconfont icon-riqi" data-v-06970110><a href="javascript:;" data-v-06970110>2020-06-12</a></div> <!----></div></div></div> <!----> <div class="content-wrapper"><div class="right-menu-wrapper"><div class="right-menu-margin"><div class="right-menu-title">目录</div> <div class="right-menu-content"></div></div></div> <h1><img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAAAXNSR0IArs4c6QAABH1JREFUSA3tVl1oHFUUPmdmd2ltklqbpJDiNnXFmgbFktho7YMPNiJSSZM0+CAYSkUELVhM6YuwIPpgoOKDqOBDC0XE2CQoNtQXBUFTTcCi+Wlh1V2TQExsUzcltd3M9Tt3ZjZzZ2fT+OJTL8yeM+eee757fmeJbq//KQL8X3DUSFOcfr7cRsRtxNQMWueeVzOkaITIGqQHNg5y8+jNW9ldM7A6nTpAjuolUikAwq7CE3WcM2RRDz+XGVgN3FptU/aUSlvq9Pa3iZ1+sgAqJyyAFqkipd9dqiwHF3P65YycLWc/6sqGrvoEoIp6DOFaX5h6+dnfjkWprwqsPk0dUGq5vySwDImC10KxFHgGL1SWoc92O3eVht09qdXNH11I2SsTsJYqMWzihqGMi+A+Garf3BAuuLI5oGlULyNfyB/HYNujwktOfRrMr5t77NmevqaUopx0grnKAyvVpmwUDB4x6FPXuGvYLTDwWsejwgtgkYKPqRJg8SV6xaiZ3ZTppGneS4yfH5/66fZSDHv+QZci/+h5c5UHtpy67JUqGppM0sh0Nc1dW6/N1W5Yoqat8/TU/VnadmdeW2PLLSyh0cvxBs3KbqTmwYPpxN4do/mzE8nEpvX/UMu2Wbp74zUAK5q6WkHns7V0eWkdPbPzd3rxkTGybadYySumVzhcaJFbs5UrEkQ/+CK8gF5dnh/6ciIZ73gwQ927L1IitoxKLXYP3SjYdOrHHfTZhRRlFyrorafPk20B3HPD1y2G3qKZME5Jcf3t/HUC13/8tSd++vqFveMUTwAUxSUFI1QekR1+bIze3D9MF2aq6cPvG72CgnldWCFqyRw3lwH8ZMerjTD9ElRO7Gv44wNpC90aASqGfVlz/Rx17srQ57/UU26hkhQqUB7dBR71WmzQhHUnblGmVOEw0jhbV1n9OlXUDCIRGaNV5Jp43N516fN7JmnTHdfp7Hgy0luO4aMhtkLL8Bi3bUWYvzh5Mn1dTxrL6QmGuRhGL/TiTTxRoEdTszSaq9GR0NGA3KdkOz3hqSV3MIDhQ5IVX/Ivx3umBti2es2h4eZby7x8br1rkf7Mo90AqC8aQ3sJeNzqFRu+vSANAQe3PL7l0HGOAdwDCeZYvNKeoZp1Qfs6Aipndh86HmFRi0LAnEO47wsqM6cdfjh3jBPUzhZy7nvlUfFsamED1VQt6aISHVymXZ/B2aCtIG8AI8xfobj2d3en1wWVhOeHELKmLQ1s211s88comkv4UCwWyF787mJdYXtNfhKAXVqnKTq8QZvGAGGOfaTo5pGZ/PwbUCr5+DPr/1J92JNHr9aOl/F3iI5+O1nfybsGxoimvZ3ViWSluDITw3P37mypheDIPY0tw7+O/5ApbkYw+zpfaUVu32Pi98+defdUhEpZkRFq0aqyNh9FuL9hpYbEm6iwi0z2REd09ZmyENEbuhjDWzKvZXTqKYaBIr3tt5kuPtQBZFvEUwHt60vfCNu41XsksH9Ij1BMMz1Y0OOunHNShFIP5868g5zeXmuLwL9T4b6Q2+KejgAAAABJRU5ErkJggg==">《JavaScript高级程序设计》笔记<!----></h1> <div class="theme-vdoing-content content__default"><h1 id="《javascript高级程序设计》笔记"><a href="#《javascript高级程序设计》笔记" class="header-anchor">#</a> 《JavaScript高级程序设计》笔记</h1> <h2 id="第1章-javascript简介"><a href="#第1章-javascript简介" class="header-anchor">#</a> 第1章 JavaScript简介</h2> <ul><li><p>JavaScript诞生于<strong>1995</strong>年</p></li> <li><p>一个完整的JavaScript由这三部分组成:</p> <ul><li><strong>ECMAScript</strong> (核心)</li> <li><strong>DOM</strong> (文档对象模型)</li> <li><strong>BOM</strong> (浏览器对象模型)</li></ul></li> <li><p>ECMAScript的 <strong>宿主环境</strong> 包含 :</p> <ul><li>浏览器</li> <li>Node</li> <li>flash</li></ul></li> <li><p>ECMAScript大致规定了下列组成部分:</p> <ul><li>语法</li> <li>类型</li> <li>语句</li> <li>关键字</li> <li>保留字</li> <li>操作符</li> <li>对象</li></ul></li></ul> <h2 id="第2章-在html中使用javascript"><a href="#第2章-在html中使用javascript" class="header-anchor">#</a> 第2章 在HTML中使用JavaScript</h2> <ul><li><code>&lt;script&gt;</code> 标签有下列常见属性:
  25. <ul><li>async 表示立即下载脚本,不妨碍页面的其他操作(异步下载)
  26. <ul><li>无法保证每个js的顺序</li> <li>用于互不依赖的js</li> <li>主要目的是不让页面等js</li></ul></li> <li>defer 延迟到文档完全解析和显示之后在执行
  27. <ul><li>在<code>&lt;/html&gt;</code>标签之后执行</li></ul></li> <li>src 外部文件链接</li> <li>type 表示编写代码使用的脚本语言的内容类型
  28. <ul><li><code>text/javascript</code></li></ul></li></ul></li></ul> <h2 id="第3章-基本概念"><a href="#第3章-基本概念" class="header-anchor">#</a> 第3章 基本概念</h2> <ul><li><p>语法,借鉴了C语言</p> <ul><li><strong>区分大小写</strong></li> <li><strong>标识符</strong>,指的是<strong>变量、函数、属性</strong>的名字
  29. <ul><li>第一个字符必须是 字母、下划线、或美元符号</li> <li>其他字符可以是字母、下划线、美元符号或数字</li></ul></li></ul></li> <li><p>严格模式</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token string">&quot;use strict&quot;</span>
  30. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div></li> <li><p>数据类型</p> <ul><li>基本数据类型
  31. <ul><li>Undefined、Null、Boolean、Number、String</li> <li><code>typeof</code>操作符,一般用于基本类型的检测,返回相应类型的字符串
  32. <ul><li>“undefined”,&quot;boolean&quot;,&quot;string&quot;,&quot;number&quot;,&quot;object&quot;,&quot;function&quot;</li></ul></li></ul></li> <li>复杂数据类型
  33. <ul><li>Object</li></ul></li></ul></li> <li><p><code>Null</code>类型</p> <ul><li>表示<strong>空对象指针</strong></li> <li>只要意在保存对象的变量还没有真正保证对象,则保存<code>null</code></li> <li><code>undefined</code>派生自<code>null</code>,因此用<code>==</code>比较返回<code>true</code></li></ul></li> <li><p>浮点数,指的是数值中包含一个小数点,并且小数点后面至少有一位数字</p></li> <li><p>NaN</p> <ul><li>任何涉及NaN的操作都返回<code>NaN</code></li> <li><code>NaN</code>与任何值都不相等,包括<code>NaN</code>本身</li></ul></li> <li><p>数值转换</p> <ul><li>有3个函数可以把非数值转换为数值
  34. <ul><li>Number() 可以用于任何数据类型</li> <li>parseInt() 专门用于字符串转数值,用于解析整数</li> <li>parseFloat() 专门用于字符串转数值,用于解析浮点数</li></ul></li></ul></li> <li><p>字符串</p> <ul><li>数值、布尔值、对象、字符串值本身 都有toString()方法,用于转为字符串</li> <li>undefined和null没有toString()方法,但可以使用String()方法</li></ul></li> <li><p>Object类型</p> <ul><li><p>对象其实就是一组数据与功能的集合</p></li> <li><p>使用Object()构造函数创建对象</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> obj <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">Object</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span> <span class="token comment">// 同 obj = {}</span>
  35. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div></li> <li><p>每个对象实例都有下列属性和方法</p> <ul><li><code>constructor</code> 指向用于创建当前对象的构造函数 。(对于上面例子而言,就是<code>Object()</code>)</li> <li><code>hasOwnProperty(propertyName)</code> 用于检查给定属性是否在当前对象实例中</li> <li><code>isPrototypeOf(Object)</code> 用于检查传入的对象是否是当前对象的原型</li> <li><code>propertyIsEnumerable(propertyName)</code> 用于检查给定的属性是否能够使用<code>for-in</code>来枚举</li> <li><code>toLocaleString()</code> 返回对象的字符串表示,该字符串与执行环境的地区对应</li> <li><code>toString()</code> 返回对象的字符串表示</li> <li><code>valueOf()</code> 返回对象的字符串、数值、布尔值表示。通常与<code>toString()</code>返回值相同</li></ul> <p><strong>所有对象都有以上属性和方法</strong></p></li></ul></li> <li><p><strong>操作符</strong></p> <ul><li>一元操作符
  36. <ul><li>++</li> <li>--</li> <li>前置与后置的区别是与其他数运算时,前置会先执行递增(减)再与其他数运算,后置会先与其他数运算再对自身执行递增(减)</li></ul></li> <li>布尔操作符
  37. <ul><li>与 (&amp;&amp;)
  38. <ul><li>短路操作,即如果第一个操作数能决定结果,就不会对第二个操作数求值</li></ul></li> <li>或 (||)
  39. <ul><li>短路操作,即如果第一个操作数能决定结果,就不会对第二个操作数求值</li></ul></li> <li>非 (!)
  40. <ul><li>先使用Boolean()转成布尔值再取反</li></ul></li></ul></li></ul></li> <li><p><strong>语句</strong>(也称流控制语句)</p> <ul><li><p>if-else</p></li> <li><p>do-while</p> <ul><li><p>后测试循环语句,在对表达式求值之前,循环体内的代码至少会被执行一次</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> i <span class="token operator">=</span> <span class="token number">0</span>
  41. <span class="token keyword">do</span> <span class="token punctuation">{</span>
  42. i <span class="token operator">+=</span> <span class="token number">2</span>
  43. <span class="token punctuation">}</span> <span class="token keyword">while</span> <span class="token punctuation">(</span>i <span class="token operator">&lt;</span> <span class="token number">10</span><span class="token punctuation">)</span> <span class="token comment">// 只要i小于10就会一直循环</span>
  44. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br></div></div></li></ul></li> <li><p>while</p> <ul><li><p>前测试语句</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> i <span class="token operator">=</span> <span class="token number">0</span>
  45. <span class="token keyword">while</span> <span class="token punctuation">(</span>i <span class="token operator">&lt;</span> <span class="token number">10</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  46. i <span class="token operator">+=</span> <span class="token number">2</span>
  47. <span class="token punctuation">}</span> <span class="token comment">// 只要i小于10就会一直循环</span>
  48. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br></div></div></li></ul></li> <li><p>for</p> <ul><li><p>使用while循环做不到的,使用for循环同样做不到。就是说,for循环只是把与循环有关的代码集合在一个位置</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">for</span><span class="token punctuation">(</span>初始化<span class="token punctuation">;</span>条件<span class="token punctuation">;</span>循环后执行<span class="token punctuation">)</span><span class="token punctuation">{</span>
  49. <span class="token comment">// ...</span>
  50. <span class="token punctuation">}</span>
  51. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br></div></div></li> <li><p>break 立即退出循环</p></li> <li><p>continue 退出当前单次循环</p></li></ul></li> <li></li> <li><p>for- in 用来枚举对象的属性</p></li></ul></li> <li><p>函数</p> <ul><li>任何函数都可以在任何时候返回任何值</li> <li>未指定返回值的函数会返回一个undefined</li> <li>通过arguments访问参数,它是一个类数组</li></ul></li></ul> <h2 id="第4章-变量、作用域和内存问题"><a href="#第4章-变量、作用域和内存问题" class="header-anchor">#</a> 第4章 变量、作用域和内存问题</h2> <ul><li><p>变量包含两种类型的值:</p> <ul><li>基本类型值,指的是简单的数据段</li> <li>引用类型值,指的是那些可能由多个值构成的<strong>对象</strong></li></ul></li> <li><p>复制变量值</p> <ul><li>复制基本类型的变量值只是复制了该值的副本</li> <li>复制引用类型的变量值时,同样也会将存储在变量对象的值复制一份放到新变量的空间中,不同的是,这个值的副本实际上是一个指针,而这个指针指向存储在堆中的一个对象。两个变量指向同一个对象。</li></ul></li> <li><p>传递参数</p> <ul><li>所有函数的参数都是按值传递的</li></ul></li> <li><p>检测类型</p> <ul><li><code>typeof</code> 检测基础类型</li> <li><code>instanceof</code>检测引用类型
  52. <ul><li>变量 instanceof 构造函数(例:obj instanceof Object)</li> <li>所有引用类型的值都是Object的实例</li></ul></li></ul></li> <li><p>执行环境</p> <ul><li>在浏览器中,全局执行环境是<code>window</code>对象</li> <li>每个函数都有自己的<strong>执行环境</strong></li></ul></li> <li><p>作用域链</p> <ul><li>当代码在一个环境中执行时,会创建变量对象的一个<strong>作用域链</strong></li> <li>作用域链的前端,始终是当前执行的代码所在环境的变量对象。</li> <li>作用域链中的下一个变量对象来自包含(外部)环境,而再下一个变量对象则来自下一个包含对象。这样一直延续到全局执行环境。</li> <li>全局执行环境的变量对象始终都是作用域链中的最后一个对象。</li></ul></li> <li><p>垃圾收集</p> <ul><li>JavaScript具有自动垃圾收集机制
  53. <ul><li>对于不再使用的变量打上标记,被打上标记的变量将在执行回收时被清除,释放内存空间。</li></ul></li></ul></li></ul> <h2 id="第5章-引用类型"><a href="#第5章-引用类型" class="header-anchor">#</a> 第5章 引用类型</h2> <ul><li><p>引用类型的值是引用类型的一个实例</p></li> <li><p>引用类型就是一种数据结构,描述了一类对象所具有的属性和方法</p></li> <li><p>创建Object实例的方式有两种:</p> <ul><li><div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> obj <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">Object</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
  54. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div></li> <li><div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> obj <span class="token operator">=</span> <span class="token punctuation">{</span><span class="token punctuation">}</span> <span class="token comment">// 与 new Object() 相同,但实际不会调用Object构造函数</span>
  55. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div></li></ul></li> <li><p>访问对象的属性有两种:</p> <ul><li>点表示法 和 方括号表示法</li></ul></li></ul> <h3 id="array类型"><a href="#array类型" class="header-anchor">#</a> Array类型</h3> <ul><li><p>length属性不是只读的</p></li> <li><p>检测数组</p> <ul><li><div class="language-js line-numbers-mode"><pre class="language-js"><code>value <span class="token keyword">instanceof</span> <span class="token class-name">Array</span>
  56. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div></li> <li><div class="language-js line-numbers-mode"><pre class="language-js"><code>Array<span class="token punctuation">.</span><span class="token function">isArray</span><span class="token punctuation">(</span>value<span class="token punctuation">)</span>
  57. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div></li></ul></li> <li><p>转换方法</p> <ul><li>toLocaleString() 与toString()相同</li> <li>toString() 返回数组中每个值的字符串形式用逗号分隔拼接而成的字符串</li> <li>valueOf() 返回数组本身</li></ul></li></ul> <h4 id="join-转换方法-不改原数组"><a href="#join-转换方法-不改原数组" class="header-anchor">#</a> join() 转换方法 (不改原数组)</h4> <p>接收一个参数,用作分隔符的字符串,然后返回包含所有数组项的字符串。</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> arr <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token string">'red'</span><span class="token punctuation">,</span><span class="token string">'blue'</span><span class="token punctuation">,</span><span class="token string">'green'</span><span class="token punctuation">]</span>
  58. <span class="token keyword">var</span> arrStr <span class="token operator">=</span> arr<span class="token punctuation">.</span><span class="token function">join</span><span class="token punctuation">(</span><span class="token string">'|'</span><span class="token punctuation">)</span> <span class="token comment">// &quot;red|blue|green&quot;</span>
  59. arr<span class="token punctuation">.</span><span class="token function">join</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token comment">// &quot;red,blue,green&quot;</span>
  60. arr<span class="token punctuation">.</span><span class="token function">join</span><span class="token punctuation">(</span><span class="token string">''</span><span class="token punctuation">)</span> <span class="token comment">// &quot;redbluegreen&quot;</span>
  61. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br></div></div><h4 id="栈方法-后进先出-push-、pop-改变原数组"><a href="#栈方法-后进先出-push-、pop-改变原数组" class="header-anchor">#</a> 栈方法,后进先出 push() 、pop() (改变原数组)</h4> <ul><li>push() 向数组末尾添加成员,返回总长</li> <li>pop() 移除数组末尾一个成员,返回该成员</li></ul> <h4 id="队列方法-先进先出-push-、shift-、unshift-改变原数组"><a href="#队列方法-先进先出-push-、shift-、unshift-改变原数组" class="header-anchor">#</a> 队列方法,先进先出 push()、shift() 、unshift() (改变原数组)</h4> <ul><li><p>shift() 移除数组首个成员,返回该成员</p></li> <li><p>unshift() 在数组前面添加成员,返回总长</p></li></ul> <p>push()和shift() 形成队列方法</p> <p>unshift和pop() 形成反方向队列方法</p> <h4 id="重排序方法-reverse-反转-sort-排序-改变原数组"><a href="#重排序方法-reverse-反转-sort-排序-改变原数组" class="header-anchor">#</a> 重排序方法 reverse() 反转 sort() 排序 (改变原数组)</h4> <ul><li>reverse() 反转数组项的顺序</li> <li>sort() 接收一个函数作为参数,函数接收两个参数。
  62. <ul><li>自定义排序:函数内,如果第一个参数应该位于第二个之前,则手动返回一个负数,如果两个参数相等,手动返回0,如果第一个参数应该位于第二个参数之后,则手动返回一个正数。</li></ul></li></ul> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token comment">// 升序</span>
  63. arr<span class="token punctuation">.</span><span class="token function">sort</span><span class="token punctuation">(</span><span class="token keyword">function</span><span class="token punctuation">(</span><span class="token parameter">a<span class="token punctuation">,</span>b</span><span class="token punctuation">)</span><span class="token punctuation">{</span>
  64. <span class="token keyword">if</span><span class="token punctuation">(</span>a <span class="token operator">&lt;</span> b<span class="token punctuation">)</span> <span class="token punctuation">{</span>
  65. <span class="token keyword">return</span> <span class="token operator">-</span><span class="token number">1</span>
  66. <span class="token punctuation">}</span> <span class="token keyword">else</span> <span class="token keyword">if</span> <span class="token punctuation">(</span>a <span class="token operator">&gt;</span> b<span class="token punctuation">)</span> <span class="token punctuation">{</span>
  67. <span class="token keyword">return</span> <span class="token number">1</span>
  68. <span class="token punctuation">}</span> <span class="token keyword">else</span> <span class="token punctuation">{</span>
  69. retunr <span class="token number">0</span>
  70. <span class="token punctuation">}</span>
  71. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  72. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br></div></div><p>简写:</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code>arr<span class="token punctuation">.</span><span class="token function">sort</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">a<span class="token punctuation">,</span>b</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  73. <span class="token keyword">return</span> a<span class="token operator">-</span>b <span class="token comment">// 升序, b-a 降序</span>
  74. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  75. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br></div></div><h4 id="操作方法-concat-拼接-slice-切片-splice-移接"><a href="#操作方法-concat-拼接-slice-切片-splice-移接" class="header-anchor">#</a> 操作方法 concat() 拼接,slice() 切片,splice() 移接</h4> <ul><li><p>concat() 拼接数组 (<strong>不改原数组</strong>)</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> arr1 <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token string">'a'</span><span class="token punctuation">,</span><span class="token string">'b'</span><span class="token punctuation">]</span>
  76. <span class="token keyword">var</span> arr2 <span class="token operator">=</span> arr1<span class="token punctuation">.</span><span class="token function">concat</span><span class="token punctuation">(</span><span class="token string">'c'</span><span class="token punctuation">,</span><span class="token string">'d'</span><span class="token punctuation">)</span> <span class="token comment">// ['a','b','c','d']</span>
  77. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div></li> <li><p>slice() 切片(<strong>不改原数组</strong>)</p> <ul><li>slice(起始位置 [, 结束位置]) 返回起始位置到结束位置的成员,不包含结束位置。</li></ul> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> arr1 <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">3</span><span class="token punctuation">,</span><span class="token number">4</span><span class="token punctuation">,</span><span class="token number">5</span><span class="token punctuation">]</span>
  78. <span class="token keyword">var</span> arr2 <span class="token operator">=</span> arr1<span class="token punctuation">.</span><span class="token function">slice</span><span class="token punctuation">(</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">3</span><span class="token punctuation">)</span> <span class="token comment">// [2,3]</span>
  79. <span class="token keyword">var</span> arr3 <span class="token operator">=</span> arr1<span class="token punctuation">.</span><span class="token function">slice</span><span class="token punctuation">(</span><span class="token number">2</span><span class="token punctuation">)</span> <span class="token comment">// [3,4,5]</span>
  80. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br></div></div></li> <li><p>splice() 移接 (<strong>改变原数组</strong>)</p> <ul><li>splice(起始位置, 要删除的个数,要插入的项)
  81. <ul><li>要插入的项 可以有0个或多个</li></ul></li> <li>splice() 始终返回一个数组,该数组成员中包含原始数组中被删除的项,如果没有则返回空数组。</li> <li>数组最强大的方法,可用于删除、插入、替换操作</li></ul> <div class="language-js line-numbers-mode"><pre class="language-js"><code>arr <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">3</span><span class="token punctuation">,</span><span class="token number">4</span><span class="token punctuation">]</span>
  82. arr<span class="token punctuation">.</span><span class="token function">splice</span><span class="token punctuation">(</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">1</span><span class="token punctuation">)</span> <span class="token comment">// [2]</span>
  83. arr <span class="token comment">// [1,3,4]</span>
  84. arr <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">3</span><span class="token punctuation">,</span><span class="token number">4</span><span class="token punctuation">]</span>
  85. arr<span class="token punctuation">.</span><span class="token function">splice</span><span class="token punctuation">(</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">0</span><span class="token punctuation">,</span><span class="token string">'a'</span><span class="token punctuation">)</span> <span class="token comment">// []</span>
  86. arr <span class="token comment">// [1,2,'a',3,4]</span>
  87. arr <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">3</span><span class="token punctuation">,</span><span class="token number">4</span><span class="token punctuation">]</span>
  88. arr<span class="token punctuation">.</span><span class="token function">splice</span><span class="token punctuation">(</span><span class="token number">3</span><span class="token punctuation">,</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token string">'a'</span><span class="token punctuation">)</span> <span class="token comment">// [4]</span>
  89. arr <span class="token comment">// [1,2,3,'a']</span>
  90. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br></div></div></li></ul> <h4 id="位置方法-indexof-、lastindexof"><a href="#位置方法-indexof-、lastindexof" class="header-anchor">#</a> 位置方法 indexOf()、lastIndexOf()</h4> <ul><li>查找项的位置,没有则返回-1</li> <li>indexOf() 从前面开始找,lastIndexOf() 从后面开始找</li></ul> <h4 id="迭代方法-every-、some-、filter-、map-、foreach-都不会改变原数组"><a href="#迭代方法-every-、some-、filter-、map-、foreach-都不会改变原数组" class="header-anchor">#</a> 迭代方法 every()、some() 、filter()、map() 、forEach() (都不会改变原数组)</h4> <ul><li><p>5个迭代方法,每个方法都接收两个参数:</p> <ul><li>在每项上运行的函数</li> <li>运行函数的作用域对象</li></ul></li> <li><p>函数接收三个参数:</p> <ul><li>数组项的值</li> <li>该项的索引</li> <li>数组本身</li></ul></li> <li><p>every() 如果函数对每项都返回true,则返回true</p> <ul><li><p>例:判断数组每一项是否都大于2</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> numbers <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">3</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">1</span><span class="token punctuation">]</span>
  91. <span class="token keyword">var</span> result <span class="token operator">=</span> numbers<span class="token punctuation">.</span><span class="token function">every</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">item<span class="token punctuation">,</span>index<span class="token punctuation">,</span>array</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  92. <span class="token keyword">return</span> item <span class="token operator">&gt;</span> <span class="token number">2</span>
  93. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  94. result <span class="token comment">// false</span>
  95. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br></div></div></li></ul></li> <li><p>some() 如果函数对任一项返回true,则返回true</p> <ul><li><p>例:判断数组是否包含大于2的值</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> numbers <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">3</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">1</span><span class="token punctuation">]</span>
  96. <span class="token keyword">var</span> result <span class="token operator">=</span> numbers<span class="token punctuation">.</span><span class="token function">some</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">item<span class="token punctuation">,</span>index<span class="token punctuation">,</span>array</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  97. <span class="token keyword">return</span> item <span class="token operator">&gt;</span> <span class="token number">2</span>
  98. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  99. result <span class="token comment">// true</span>
  100. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br></div></div></li></ul></li> <li><p>filter() 返回函数会返回true的项组成的数组</p> <ul><li><p>例:过滤掉数组中小于等于2的数</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> numbers <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">3</span><span class="token punctuation">,</span><span class="token number">4</span><span class="token punctuation">,</span><span class="token number">5</span><span class="token punctuation">]</span>
  101. <span class="token keyword">var</span> result <span class="token operator">=</span> numbers<span class="token punctuation">.</span><span class="token function">filter</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">item<span class="token punctuation">,</span>index<span class="token punctuation">,</span>array</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  102. <span class="token keyword">return</span> item <span class="token operator">&gt;</span><span class="token number">2</span>
  103. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  104. result <span class="token comment">// [3,4,5]</span>
  105. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br></div></div></li></ul></li> <li><p>map() 返回每次函数调用的结果组成的数组</p> <ul><li><p>例:给数组每一项乘以2</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> numbers <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">3</span><span class="token punctuation">,</span><span class="token number">4</span><span class="token punctuation">,</span><span class="token number">5</span><span class="token punctuation">]</span>
  106. <span class="token keyword">var</span> result <span class="token operator">=</span> numbers<span class="token punctuation">.</span><span class="token function">map</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">item<span class="token punctuation">,</span>index<span class="token punctuation">,</span>array</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  107. <span class="token keyword">return</span> item <span class="token operator">*</span> <span class="token number">2</span>
  108. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  109. result <span class="token comment">// [2,4,6,8,10]</span>
  110. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br></div></div></li></ul></li> <li><p>forEach() 循环数组每一项,没有返回值</p> <ul><li><p>例:循环每一项</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> numbers <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">3</span><span class="token punctuation">,</span><span class="token number">4</span><span class="token punctuation">,</span><span class="token number">5</span><span class="token punctuation">]</span>
  111. numbers<span class="token punctuation">.</span><span class="token function">forEach</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">item<span class="token punctuation">,</span>index<span class="token punctuation">,</span>array</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  112. <span class="token comment">// 做一些操作</span>
  113. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  114. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br></div></div></li></ul></li></ul> <h4 id="归并方法-reduce-reduceright"><a href="#归并方法-reduce-reduceright" class="header-anchor">#</a> 归并方法 reduce() reduceRight()</h4> <ul><li><p>reduce() 归并为</p></li> <li><p>reduceRight() 从右边归并</p></li> <li><p>这两个方法都会迭代数组所有项,然后构建一个最终结果并返回</p></li> <li><p>方法接收两个参数: 每一项上调用的函数,归并基础的初始值</p></li> <li><p>函数接收4个参数:前一个的值、当前值、当前值的索引、数组对象</p></li> <li><p>例:求数组每一项之和</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> numbers <span class="token operator">=</span> <span class="token punctuation">[</span><span class="token number">1</span><span class="token punctuation">,</span><span class="token number">2</span><span class="token punctuation">,</span><span class="token number">3</span><span class="token punctuation">,</span><span class="token number">4</span><span class="token punctuation">,</span><span class="token number">5</span><span class="token punctuation">]</span>
  115. <span class="token keyword">var</span> result <span class="token operator">=</span> number<span class="token punctuation">.</span><span class="token function">reduce</span><span class="token punctuation">(</span><span class="token punctuation">(</span><span class="token parameter">prev<span class="token punctuation">,</span>cur<span class="token punctuation">,</span>index<span class="token punctuation">,</span>arr</span><span class="token punctuation">)</span> <span class="token operator">=&gt;</span> <span class="token punctuation">{</span>
  116. <span class="token keyword">return</span> prev <span class="token operator">+</span> cur
  117. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  118. result <span class="token comment">// 15</span>
  119. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br></div></div></li> <li><p>reduce()方法,第一次执行函数时,prev是数组的第一项,cur是数组的第二项</p></li></ul> <h2 id="第6章-面向对象的程序设计"><a href="#第6章-面向对象的程序设计" class="header-anchor">#</a> 第6章 面向对象的程序设计</h2> <h3 id="_6-1-理解对象"><a href="#_6-1-理解对象" class="header-anchor">#</a> 6.1 理解对象</h3> <ul><li>对象的定义:无序属性的集合,其属性可以包含基本值、对象或者函数。
  120. <ul><li>一组键值对,其中值可以是数据或函数</li></ul></li></ul> <h4 id="_6-1-1-对象的属性"><a href="#_6-1-1-对象的属性" class="header-anchor">#</a> 6.1.1 对象的属性</h4> <p>​ 包含两种:<strong>数据属性</strong> 和 <strong>访问器属性</strong></p> <h5 id="_1-数据属性"><a href="#_1-数据属性" class="header-anchor">#</a> 1.数据属性</h5> <ul><li>configurable 可配置性(限制 delete删除属性和<code>Object.defineProperty()</code>方法是否起效。),默认true</li> <li>enumerable 可列举性,默认true</li> <li>writable 可写性,默认true</li> <li>value 值,默认undefined</li></ul> <p>使用<code>Object.defineProperty()</code>方法修改这些默认属性。接收三个值:<strong>属性所在的对象、属性名、描述符对象</strong>。</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> person <span class="token operator">=</span> <span class="token punctuation">{</span><span class="token punctuation">}</span>
  121. Object<span class="token punctuation">.</span><span class="token function">defineProperty</span><span class="token punctuation">(</span>person<span class="token punctuation">,</span><span class="token string">'name'</span><span class="token punctuation">,</span><span class="token punctuation">{</span>
  122. <span class="token literal-property property">writable</span><span class="token operator">:</span> <span class="token boolean">false</span><span class="token punctuation">,</span>
  123. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token string">'xu'</span>
  124. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  125. console<span class="token punctuation">.</span><span class="token function">log</span><span class="token punctuation">(</span>person<span class="token punctuation">.</span>name<span class="token punctuation">)</span> <span class="token comment">// xu</span>
  126. person<span class="token punctuation">.</span>name <span class="token operator">=</span> <span class="token string">'gao'</span> <span class="token comment">// 修改无效</span>
  127. console<span class="token punctuation">.</span><span class="token function">log</span><span class="token punctuation">(</span>person<span class="token punctuation">.</span>name<span class="token punctuation">)</span> <span class="token comment">// xu</span>
  128. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br></div></div><p>使用此方法定义属性如未指定<code>configurable</code>、<code>enumerable</code>、<code>writable</code> 将默认<code>false</code>。</p> <h5 id="_2-访问器属性"><a href="#_2-访问器属性" class="header-anchor">#</a> 2.访问器属性</h5> <p>包含两个函数:getter函数和setter函数(这两个函数都是非必需)。读取时调用getter,访问时调用setter。</p> <p>使用<code>Object.defineProperty()</code>方法定义访问器属性。</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> book <span class="token operator">=</span> <span class="token punctuation">{</span>
  129. <span class="token literal-property property">_year</span><span class="token operator">:</span> <span class="token number">2020</span><span class="token punctuation">,</span>
  130. <span class="token literal-property property">edition</span><span class="token operator">:</span> <span class="token number">1</span>
  131. <span class="token punctuation">}</span><span class="token punctuation">;</span>
  132. Object<span class="token punctuation">.</span><span class="token function">defineProperty</span><span class="token punctuation">(</span>book<span class="token punctuation">,</span> <span class="token string">'year'</span><span class="token punctuation">,</span> <span class="token punctuation">{</span>
  133. <span class="token function-variable function">get</span><span class="token operator">:</span> <span class="token keyword">function</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  134. <span class="token keyword">return</span> <span class="token keyword">this</span><span class="token punctuation">.</span>_year
  135. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  136. <span class="token function-variable function">set</span><span class="token operator">:</span> <span class="token keyword">function</span><span class="token punctuation">(</span><span class="token parameter">newValue</span><span class="token punctuation">)</span><span class="token punctuation">{</span>
  137. <span class="token keyword">if</span><span class="token punctuation">(</span>newValue <span class="token operator">&gt;</span> <span class="token number">2020</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  138. <span class="token keyword">this</span><span class="token punctuation">.</span>_year <span class="token operator">=</span> newValue
  139. <span class="token keyword">this</span><span class="token punctuation">.</span>edition <span class="token operator">+=</span> newValue <span class="token operator">-</span> <span class="token number">2020</span>
  140. <span class="token punctuation">}</span>
  141. <span class="token punctuation">}</span>
  142. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  143. book<span class="token punctuation">.</span>year <span class="token operator">=</span> <span class="token number">2021</span>
  144. console<span class="token punctuation">.</span><span class="token function">log</span><span class="token punctuation">(</span>book<span class="token punctuation">.</span>edition<span class="token punctuation">)</span> <span class="token comment">// 2</span>
  145. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br><span class="line-number">18</span><br><span class="line-number">19</span><br></div></div><p>当getter函数和setter函数只指定其中一个时,另外一个将不能用。</p> <h4 id="_6-1-2-定义多个属性"><a href="#_6-1-2-定义多个属性" class="header-anchor">#</a> 6.1.2 定义多个属性</h4> <p><code>Object.defineProperties()</code>方法定义多个属性。接收两个参数: 要添加或修改属性的对象 、第二个参数是一个对象,其属性与第一个参数中的属性一一对应。</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> book <span class="token operator">=</span> <span class="token punctuation">{</span><span class="token punctuation">}</span>
  146. Object<span class="token punctuation">.</span><span class="token function">defineProperties</span><span class="token punctuation">(</span>book<span class="token punctuation">,</span> <span class="token punctuation">{</span>
  147. <span class="token literal-property property">_year</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token comment">// 数据属性</span>
  148. <span class="token literal-property property">writable</span><span class="token operator">:</span> <span class="token boolean">true</span><span class="token punctuation">,</span>
  149. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">2004</span>
  150. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  151. <span class="token literal-property property">edition</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token comment">// 数据属性</span>
  152. <span class="token literal-property property">writable</span><span class="token operator">:</span> <span class="token boolean">true</span><span class="token punctuation">,</span>
  153. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">1</span>
  154. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  155. <span class="token literal-property property">year</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token comment">// 访问器属性</span>
  156. <span class="token function-variable function">get</span><span class="token operator">:</span> <span class="token keyword">function</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  157. <span class="token keyword">return</span> <span class="token keyword">this</span><span class="token punctuation">.</span>_year
  158. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  159. <span class="token function-variable function">set</span><span class="token operator">:</span> <span class="token keyword">function</span><span class="token punctuation">(</span><span class="token parameter">newValue</span><span class="token punctuation">)</span><span class="token punctuation">{</span>
  160. <span class="token keyword">if</span><span class="token punctuation">(</span>newValue <span class="token operator">&gt;</span> <span class="token number">2004</span><span class="token punctuation">)</span><span class="token punctuation">{</span>
  161. <span class="token keyword">this</span><span class="token punctuation">.</span>_year <span class="token operator">=</span> newValue
  162. <span class="token keyword">this</span><span class="token punctuation">.</span>edition <span class="token operator">+=</span> newValue <span class="token operator">-</span> <span class="token number">2004</span>
  163. <span class="token punctuation">}</span>
  164. <span class="token punctuation">}</span>
  165. <span class="token punctuation">}</span>
  166. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  167. <span class="token comment">// 定义了三个属性,每个属性有不同的描述符</span>
  168. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br><span class="line-number">18</span><br><span class="line-number">19</span><br><span class="line-number">20</span><br><span class="line-number">21</span><br><span class="line-number">22</span><br><span class="line-number">23</span><br><span class="line-number">24</span><br></div></div><h4 id="_6-1-3-读取属性的特性-描述符对象"><a href="#_6-1-3-读取属性的特性-描述符对象" class="header-anchor">#</a> 6.1.3 读取属性的特性(描述符对象)</h4> <p><code>Object.getOwnPropertyDescriptor()</code>方法获取描述符,接收两个参数: 属性所在的对象、属性名</p> <div class="language-js line-numbers-mode"><pre class="language-js"><code><span class="token keyword">var</span> book <span class="token operator">=</span> <span class="token punctuation">{</span><span class="token punctuation">}</span>
  169. Object<span class="token punctuation">.</span><span class="token function">defineProperties</span><span class="token punctuation">(</span>book<span class="token punctuation">,</span> <span class="token punctuation">{</span>
  170. <span class="token literal-property property">_year</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token comment">// 数据属性</span>
  171. <span class="token literal-property property">writable</span><span class="token operator">:</span> <span class="token boolean">true</span><span class="token punctuation">,</span>
  172. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">2004</span>
  173. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  174. <span class="token literal-property property">edition</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token comment">// 数据属性</span>
  175. <span class="token literal-property property">writable</span><span class="token operator">:</span> <span class="token boolean">true</span><span class="token punctuation">,</span>
  176. <span class="token literal-property property">value</span><span class="token operator">:</span> <span class="token number">1</span>
  177. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  178. <span class="token literal-property property">year</span><span class="token operator">:</span> <span class="token punctuation">{</span> <span class="token comment">// 访问器属性</span>
  179. <span class="token function-variable function">get</span><span class="token operator">:</span> <span class="token keyword">function</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
  180. <span class="token keyword">return</span> <span class="token keyword">this</span><span class="token punctuation">.</span>_year
  181. <span class="token punctuation">}</span><span class="token punctuation">,</span>
  182. <span class="token function-variable function">set</span><span class="token operator">:</span> <span class="token keyword">function</span><span class="token punctuation">(</span><span class="token parameter">newValue</span><span class="token punctuation">)</span><span class="token punctuation">{</span>
  183. <span class="token keyword">if</span><span class="token punctuation">(</span>newValue <span class="token operator">&gt;</span> <span class="token number">2004</span><span class="token punctuation">)</span><span class="token punctuation">{</span>
  184. <span class="token keyword">this</span><span class="token punctuation">.</span>_year <span class="token operator">=</span> newValue
  185. <span class="token keyword">this</span><span class="token punctuation">.</span>edition <span class="token operator">+=</span> newValue <span class="token operator">-</span> <span class="token number">2004</span>
  186. <span class="token punctuation">}</span>
  187. <span class="token punctuation">}</span>
  188. <span class="token punctuation">}</span>
  189. <span class="token punctuation">}</span><span class="token punctuation">)</span>
  190. <span class="token keyword">var</span> descriptor <span class="token operator">=</span> Object<span class="token punctuation">.</span><span class="token function">getOwnPropertyDescriptor</span><span class="token punctuation">(</span>book<span class="token punctuation">,</span> <span class="token string">&quot;_year&quot;</span><span class="token punctuation">)</span>
  191. console<span class="token punctuation">.</span><span class="token function">log</span><span class="token punctuation">(</span>descriptor<span class="token punctuation">)</span> <span class="token comment">// {value: 2020, writable: true, enumerable: false, configurable: false}</span>
  192. <span class="token keyword">var</span> descriptor <span class="token operator">=</span> Object<span class="token punctuation">.</span><span class="token function">getOwnPropertyDescriptor</span><span class="token punctuation">(</span>book<span class="token punctuation">,</span> <span class="token string">&quot;year&quot;</span><span class="token punctuation">)</span>
  193. console<span class="token punctuation">.</span><span class="token function">log</span><span class="token punctuation">(</span>descriptor<span class="token punctuation">)</span> <span class="token comment">// {enumerable: false, configurable: false, get: ƒ, set: ƒ}</span>
  194. </code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br><span class="line-number">18</span><br><span class="line-number">19</span><br><span class="line-number">20</span><br><span class="line-number">21</span><br><span class="line-number">22</span><br><span class="line-number">23</span><br><span class="line-number">24</span><br><span class="line-number">25</span><br><span class="line-number">26</span><br><span class="line-number">27</span><br><span class="line-number">28</span><br></div></div><h3 id="_6-2-创建对象"><a href="#_6-2-创建对象" class="header-anchor">#</a> 6.2 创建对象</h3> <p>使用Object构造函数或对象字面量方式创建对象。缺点:使用同一个接口创建很多对象时,会产生大量重复代码。解决方案:使用工厂模式的一种变体。</p> <h4 id="_6-2-1-工厂模式"><a href="#_6-2-1-工厂模式" class="header-anchor">#</a> 6.2.1 工厂模式</h4> <h2 id="第7章-函数表达式"><a href="#第7章-函数表达式" class="header-anchor">#</a> 第7章 函数表达式</h2> <h2 id="第8章-bom"><a href="#第8章-bom" class="header-anchor">#</a> 第8章 BOM</h2> <h2 id="第9章-客户端检测"><a href="#第9章-客户端检测" class="header-anchor">#</a> 第9章 客户端检测</h2> <h2 id="第10章-dom"><a href="#第10章-dom" class="header-anchor">#</a> 第10章 DOM</h2> <h2 id="第11章-dom扩展"><a href="#第11章-dom扩展" class="header-anchor">#</a> 第11章 DOM扩展</h2> <h2 id="第12章-dom2和dom3"><a href="#第12章-dom2和dom3" class="header-anchor">#</a> 第12章 DOM2和DOM3</h2> <h2 id="第13章-事件"><a href="#第13章-事件" class="header-anchor">#</a> 第13章 事件</h2> <h2 id="第14章-表单脚本"><a href="#第14章-表单脚本" class="header-anchor">#</a> 第14章 表单脚本</h2> <h2 id="第15章-使用canvas绘图"><a href="#第15章-使用canvas绘图" class="header-anchor">#</a> 第15章 使用Canvas绘图</h2> <h2 id="第16章-html5脚本编程"><a href="#第16章-html5脚本编程" class="header-anchor">#</a> 第16章 HTML5脚本编程</h2> <h2 id="第17章-错误处理与调试"><a href="#第17章-错误处理与调试" class="header-anchor">#</a> 第17章 错误处理与调试</h2> <h2 id="第18章-javascript与xml"><a href="#第18章-javascript与xml" class="header-anchor">#</a> 第18章 JavaScript与XML</h2> <h2 id="第19章-e4x"><a href="#第19章-e4x" class="header-anchor">#</a> 第19章 E4X</h2> <h2 id="第20章-json"><a href="#第20章-json" class="header-anchor">#</a> 第20章 JSON</h2> <h2 id="第21章-ajax与comet"><a href="#第21章-ajax与comet" class="header-anchor">#</a> 第21章 Ajax与Comet</h2> <h2 id="第22章-高级技巧"><a href="#第22章-高级技巧" class="header-anchor">#</a> 第22章 高级技巧</h2> <h2 id="第23章-离线应用与客户端存储"><a href="#第23章-离线应用与客户端存储" class="header-anchor">#</a> 第23章 离线应用与客户端存储</h2> <h2 id="第24章-最佳实践"><a href="#第24章-最佳实践" class="header-anchor">#</a> 第24章 最佳实践</h2> <h2 id="第25章-新兴的api"><a href="#第25章-新兴的api" class="header-anchor">#</a> 第25章 新兴的API</h2></div></div> <div class="page-edit"><div class="edit-link"><a href="https://github.com/heBody/blog/edit/master/docs/01.前端/40.学习笔记/05.《JavaScript高级程序设计》笔记.md" target="_blank" rel="noopener noreferrer">编辑</a> <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></div> <div class="tags"><a href="/blog/tags/?tag=%E7%AC%94%E8%AE%B0" title="标签">#笔记</a><a href="/blog/tags/?tag=%E7%BA%A2%E5%AE%9D%E4%B9%A6" title="标签">#红宝书</a></div> <div class="last-updated"><span class="prefix">上次更新:</span> <span class="time">2022/12/14, 19:36:42</span></div></div> <div class="page-nav-wapper"><div class="page-nav-centre-wrap"><a href="/blog/note/javascript/" class="page-nav-centre page-nav-centre-prev"><div class="tooltip">《JavaScript教程》笔记</div></a> <a href="/blog/note/es6/" class="page-nav-centre page-nav-centre-next"><div class="tooltip">《ES6 教程》笔记</div></a></div> <div class="page-nav"><p class="inner"><span class="prev">
  195. <a href="/blog/note/javascript/" class="prev">《JavaScript教程》笔记</a></span> <span class="next"><a href="/blog/note/es6/">《ES6 教程》笔记</a>→
  196. </span></p></div></div></div> <div class="article-list"><div class="article-title"><a href="/blog/archives/" class="iconfont icon-bi">最近更新</a></div> <div class="article-wrapper"><dl><dd>01</dd> <dt><a href="/blog/pages/922650/"><div>
  197. Git修改分支名
  198. <!----></div></a> <span class="date">08-11</span></dt></dl><dl><dd>02</dd> <dt><a href="/blog/pages/55f894/"><div>
  199. CSS给table的tbody添加滚动条
  200. <!----></div></a> <span class="date">06-29</span></dt></dl><dl><dd>03</dd> <dt><a href="/blog/pages/829589/"><div>
  201. 我做了一个手写春联小网页,祝大家虎年暴富
  202. <span class="title-tag">
  203. 原创
  204. </span></div></a> <span class="date">01-28</span></dt></dl> <dl><dd></dd> <dt><a href="/blog/archives/" class="more">更多文章&gt;</a></dt></dl></div></div></main></div> <div class="footer"><div class="icons"><a href="mailto:30363811@qq.com" title="发邮件" target="_blank" class="iconfont icon-youjian"></a><a href="https://github.com/heBody" title="GitHub" target="_blank" class="iconfont icon-github"></a></div>
  205. Copyright © 2016-2022
  206. <span>Hesb | <a href="https://github.com/heBody/blob" target="_blank">MIT License</a></span></div> <div class="buttons"><div title="返回顶部" class="button blur go-to-top iconfont icon-fanhuidingbu" style="display:none;"></div> <div title="去评论" class="button blur go-to-comment iconfont icon-pinglun" style="display:none;"></div> <div title="主题模式" class="button blur theme-mode-but iconfont icon-zhuti"><ul class="select-box" style="display:none;"><li class="iconfont icon-zidong">
  207. 跟随系统
  208. </li><li class="iconfont icon-rijianmoshi">
  209. 浅色模式
  210. </li><li class="iconfont icon-yejianmoshi">
  211. 深色模式
  212. </li><li class="iconfont icon-yuedu">
  213. 阅读模式
  214. </li></ul></div></div> <!----> <!----> <!----></div><div class="global-ui"><div></div></div></div>
  215. <script src="/blog/assets/js/app.90754bd5.js" defer></script><script src="/blog/assets/js/2.106f41fb.js" defer></script><script src="/blog/assets/js/3.6748bd5c.js" defer></script><script src="/blog/assets/js/25.b4de33d1.js" defer></script>
  216. </body>
  217. </html>