05.html 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953
  1. <!DOCTYPE HTML>
  2. <html lang="" >
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
  6. <title>常用功能收集 · 代码收集</title>
  7. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  8. <meta name="description" content="">
  9. <meta name="generator" content="GitBook 3.1.1">
  10. <link rel="stylesheet" href="../../gitbook/style.css">
  11. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-search-pro/search.css">
  12. <link rel="stylesheet" href="../../gitbook/gitbook-plugin-highlight/website.css">
  13. <meta name="HandheldFriendly" content="true"/>
  14. <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
  15. <meta name="apple-mobile-web-app-capable" content="yes">
  16. <meta name="apple-mobile-web-app-status-bar-style" content="black">
  17. <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../../gitbook/images/apple-touch-icon-precomposed-152.png">
  18. <link rel="shortcut icon" href="../../gitbook/images/favicon.ico" type="image/x-icon">
  19. <link rel="next" href="../../angular/study_notes/" />
  20. <link rel="prev" href="04.html" />
  21. </head>
  22. <body>
  23. <div class="gb-page-wrapper">
  24. <header class="gb-page-header">
  25. <div class="container">
  26. <div id="book-search-input" role="search">
  27. <input type="text" placeholder="Type to search" />
  28. </div>
  29. <a href="../.." class="logo">
  30. <img src="../../gitbook/images/logo/128.png">
  31. <h1>代码收集</h1>
  32. </a>
  33. <a href="https://github.com/seamong/myBlogs/blob/doc/JavaScript/cases/05.md" target="_blank" class="btn btn-link pull-right hidden-xs">
  34. <i class="octicon octicon-mark-github"></i> 在GitHub编辑本页
  35. </a>
  36. <a href="../../faq.md" class="btn btn-link pull-right hidden-xs">
  37. F.A.Q
  38. </a>
  39. <a href="https://github.com/seamong/myBlogs/README.md" target="_blank" class="btn btn-link pull-right hidden-xs">
  40. 当前版本0.0.1
  41. </a>
  42. </div>
  43. </header>
  44. <div class="gb-page-body">
  45. <div class="gb-page-inner">
  46. <div class="container">
  47. <div class="row">
  48. <div class="col-md-3">
  49. <div class="panel panel-default">
  50. <div class="panel-heading">
  51. <h3 class="panel-title">介绍</h3>
  52. </div>
  53. <div class="list-group">
  54. <a href="../../" class="list-group-item ">
  55. 关于本文档
  56. </a>
  57. </div>
  58. </div>
  59. <div class="panel panel-default">
  60. <div class="panel-heading">
  61. <h3 class="panel-title">JavaScript</h3>
  62. </div>
  63. <div class="list-group">
  64. <a href="../principle/" class="list-group-item ">
  65. <i class="octicon octicon-chevron-right"></i>
  66. 原理解析
  67. </a>
  68. <a href="./" class="list-group-item ">
  69. <i class="octicon octicon-chevron-down"></i>
  70. 案例解析
  71. </a>
  72. <a href="0.html" class="list-group-item ">
  73. <i class="octicon octicon-chevron-down" style="opacity: 0"></i>
  74. 动态替换图片
  75. </a>
  76. <a href="01.html" class="list-group-item ">
  77. <i class="octicon octicon-chevron-down" style="opacity: 0"></i>
  78. 原生Ajax学习
  79. </a>
  80. <a href="02.html" class="list-group-item ">
  81. <i class="octicon octicon-chevron-down" style="opacity: 0"></i>
  82. React/React Native 的ES5 ES6写法对照表
  83. </a>
  84. <a href="03.html" class="list-group-item ">
  85. <i class="octicon octicon-chevron-down" style="opacity: 0"></i>
  86. 战舰游戏
  87. </a>
  88. <a href="04.html" class="list-group-item ">
  89. <i class="octicon octicon-chevron-down" style="opacity: 0"></i>
  90. 正则截取指定字符串
  91. </a>
  92. <a href="05.html" class="list-group-item active">
  93. <i class="octicon octicon-chevron-down" style="opacity: 0"></i>
  94. 常用功能收集
  95. </a>
  96. </div>
  97. </div>
  98. <div class="panel panel-default">
  99. <div class="panel-heading">
  100. <h3 class="panel-title">angular</h3>
  101. </div>
  102. <div class="list-group">
  103. <a href="../../angular/study_notes/" class="list-group-item ">
  104. <i class="octicon octicon-chevron-right"></i>
  105. Study notes
  106. </a>
  107. <a href="../../angular/ng.html" class="list-group-item ">
  108. ng
  109. </a>
  110. </div>
  111. </div>
  112. <div class="panel panel-default">
  113. <div class="panel-heading">
  114. <h3 class="panel-title">css</h3>
  115. </div>
  116. <div class="list-group">
  117. <a href="../../css/principle/" class="list-group-item ">
  118. 原理解析
  119. </a>
  120. <a href="../../css/cases/" class="list-group-item ">
  121. <i class="octicon octicon-chevron-right"></i>
  122. 案例收集
  123. </a>
  124. </div>
  125. </div>
  126. <div class="panel panel-default">
  127. <div class="panel-heading">
  128. <h3 class="panel-title">vue</h3>
  129. </div>
  130. <div class="list-group">
  131. <a href="../../vue/components/" class="list-group-item ">
  132. <i class="octicon octicon-chevron-right"></i>
  133. components
  134. </a>
  135. <a href="../../vue/router/" class="list-group-item ">
  136. <i class="octicon octicon-chevron-right"></i>
  137. router
  138. </a>
  139. <a href="../../vue/vuex/" class="list-group-item ">
  140. VUE
  141. </a>
  142. </div>
  143. </div>
  144. <div class="panel panel-default">
  145. <div class="panel-heading">
  146. <h3 class="panel-title">ubuntu</h3>
  147. </div>
  148. <div class="list-group">
  149. <a href="../../ubuntu/serves/" class="list-group-item ">
  150. <i class="octicon octicon-chevron-right"></i>
  151. 服务器生存指南
  152. </a>
  153. <a href="../../ubuntu/instruction.html" class="list-group-item ">
  154. 常用指令
  155. </a>
  156. <a href="../../ubuntu/software/" class="list-group-item ">
  157. 常用软件安装
  158. </a>
  159. </div>
  160. </div>
  161. <div class="panel panel-default">
  162. <div class="panel-heading">
  163. <h3 class="panel-title">GIT</h3>
  164. </div>
  165. <div class="list-group">
  166. <a href="../../git/git.html" class="list-group-item ">
  167. git 命令
  168. </a>
  169. <a href="../../git/push.html" class="list-group-item ">
  170. git~push
  171. </a>
  172. <a href="../../git/faq.html" class="list-group-item ">
  173. git~F.A.Q
  174. </a>
  175. </div>
  176. </div>
  177. <div class="panel panel-default">
  178. <div class="panel-heading">
  179. <h3 class="panel-title">NODE&NPM</h3>
  180. </div>
  181. <div class="list-group">
  182. <a href="../../node/0.html" class="list-group-item ">
  183. <i class="octicon octicon-chevron-right"></i>
  184. node
  185. </a>
  186. <a href="../../node/npm/0.html" class="list-group-item ">
  187. npm
  188. </a>
  189. </div>
  190. </div>
  191. <div class="panel panel-default">
  192. <div class="list-group">
  193. <a href="../../other/faq.html" class="list-group-item ">
  194. FAQ
  195. </a>
  196. <a href="../../other/examples.html" class="list-group-item ">
  197. Examples
  198. </a>
  199. </div>
  200. </div>
  201. </div>
  202. <div class="col-md-9">
  203. <div id="book-search-results">
  204. <div class="search-noresults">
  205. <div class="gb-markdown book-page-inner">
  206. <h1 id="&#x5E38;&#x7528;&#x529F;&#x80FD;&#x6536;&#x96C6;">&#x5E38;&#x7528;&#x529F;&#x80FD;&#x6536;&#x96C6;</h1>
  207. <h4 id="&#x6D4F;&#x89C8;&#x5668;&#x57FA;&#x672C;&#x4FE1;&#x606F;&#x5224;&#x65AD;">&#x6D4F;&#x89C8;&#x5668;&#x57FA;&#x672C;&#x4FE1;&#x606F;&#x5224;&#x65AD;</h4>
  208. <pre><code class="lang-javascript"> <span class="hljs-comment">/*
  209. * &#x667A;&#x80FD;&#x673A;&#x6D4F;&#x89C8;&#x5668;&#x7248;&#x672C;&#x4FE1;&#x606F;:
  210. *
  211. */</span>
  212. <span class="hljs-keyword">var</span> browser = {
  213. versions: <span class="hljs-function"><span class="hljs-keyword">function</span> (<span class="hljs-params"></span>) </span>{
  214. <span class="hljs-keyword">var</span> u = navigator.userAgent, app = navigator.appVersion;
  215. <span class="hljs-built_in">console</span>.log(u);
  216. <span class="hljs-keyword">return</span> {<span class="hljs-comment">//&#x79FB;&#x52A8;&#x7EC8;&#x7AEF;&#x6D4F;&#x89C8;&#x5668;&#x7248;&#x672C;&#x4FE1;&#x606F;</span>
  217. trident: u.indexOf(<span class="hljs-string">&apos;Trident&apos;</span>) &gt; <span class="hljs-number">-1</span>, <span class="hljs-comment">//IE&#x5185;&#x6838;</span>
  218. presto: u.indexOf(<span class="hljs-string">&apos;Presto&apos;</span>) &gt; <span class="hljs-number">-1</span>, <span class="hljs-comment">//opera&#x5185;&#x6838;</span>
  219. webKit: u.indexOf(<span class="hljs-string">&apos;AppleWebKit&apos;</span>) &gt; <span class="hljs-number">-1</span>, <span class="hljs-comment">//&#x82F9;&#x679C;&#x3001;&#x8C37;&#x6B4C;&#x5185;&#x6838;</span>
  220. gecko: u.indexOf(<span class="hljs-string">&apos;Gecko&apos;</span>) &gt; <span class="hljs-number">-1</span> &amp;&amp; u.indexOf(<span class="hljs-string">&apos;KHTML&apos;</span>) == <span class="hljs-number">-1</span>, <span class="hljs-comment">//&#x706B;&#x72D0;&#x5185;&#x6838;</span>
  221. mobile: !!u.match(<span class="hljs-regexp">/Mobile/g</span>), <span class="hljs-comment">//&#x53BB;&#x6389;&#x6D4F;&#x89C8;&#x5668;&#x5185;&#x6838;&#x5224;&#x65AD;</span>
  222. <span class="hljs-comment">// mobile: !!u.match(/AppleWebKit.*Mobile.*/) || !!u.match(/AppleWebKit/), //&#x662F;&#x5426;&#x4E3A;&#x79FB;&#x52A8;&#x7EC8;&#x7AEF;</span>
  223. ios: !!u.match(<span class="hljs-regexp">/\(i[^;]+;( U;)? CPU.+Mac OS X/</span>), <span class="hljs-comment">//ios&#x7EC8;&#x7AEF;</span>
  224. android: u.indexOf(<span class="hljs-string">&apos;Android&apos;</span>) &gt; <span class="hljs-number">-1</span> || u.indexOf(<span class="hljs-string">&apos;Linux&apos;</span>) &gt; <span class="hljs-number">-1</span>, <span class="hljs-comment">//android&#x7EC8;&#x7AEF;&#x6216;&#x8005;uc&#x6D4F;&#x89C8;&#x5668;</span>
  225. iPhone: u.indexOf(<span class="hljs-string">&apos;iPhone&apos;</span>) &gt; <span class="hljs-number">-1</span> || u.indexOf(<span class="hljs-string">&apos;Mac&apos;</span>) &gt; <span class="hljs-number">-1</span>, <span class="hljs-comment">//&#x662F;&#x5426;&#x4E3A;iPhone&#x6216;&#x8005;QQHD&#x6D4F;&#x89C8;&#x5668;</span>
  226. iPad: u.indexOf(<span class="hljs-string">&apos;iPad&apos;</span>) &gt; <span class="hljs-number">-1</span>, <span class="hljs-comment">//&#x662F;&#x5426;iPad</span>
  227. webApp: u.indexOf(<span class="hljs-string">&apos;Safari&apos;</span>) == <span class="hljs-number">-1</span> <span class="hljs-comment">//&#x662F;&#x5426;web&#x5E94;&#x8BE5;&#x7A0B;&#x5E8F;&#xFF0C;&#x6CA1;&#x6709;&#x5934;&#x90E8;&#x4E0E;&#x5E95;&#x90E8;</span>
  228. };
  229. }(),
  230. language: (navigator.browserLanguage || navigator.language).toLowerCase()
  231. }
  232. <span class="hljs-built_in">document</span>.writeln(<span class="hljs-string">&quot;&#x8BED;&#x8A00;&#x7248;&#x672C;: &quot;</span> + browser.language);
  233. <span class="hljs-built_in">document</span>.writeln(<span class="hljs-string">&quot; &#x662F;&#x5426;&#x4E3A;&#x79FB;&#x52A8;&#x7EC8;&#x7AEF;: &quot;</span> + browser.versions.mobile);
  234. <span class="hljs-built_in">document</span>.writeln(<span class="hljs-string">&quot; &#x662F;&#x5426;&#x4E3A;webKit: &quot;</span> + browser.versions.webKit);
  235. <span class="hljs-built_in">document</span>.writeln(<span class="hljs-string">&quot; ios&#x7EC8;&#x7AEF;: &quot;</span> + browser.versions.ios);
  236. <span class="hljs-built_in">document</span>.writeln(<span class="hljs-string">&quot; android&#x7EC8;&#x7AEF;: &quot;</span> + browser.versions.android);
  237. <span class="hljs-built_in">document</span>.writeln(<span class="hljs-string">&quot; &#x662F;&#x5426;&#x4E3A;iPhone: &quot;</span> + browser.versions.iPhone);
  238. <span class="hljs-built_in">document</span>.writeln(<span class="hljs-string">&quot; &#x662F;&#x5426;iPad: &quot;</span> + browser.versions.iPad);
  239. <span class="hljs-built_in">document</span>.writeln(navigator.userAgent);
  240. </code></pre>
  241. <h4 id="javascriptjquery&#x5224;&#x65AD;&#x5143;&#x7D20;&#x5373;&#x5C06;&#x51FA;&#x73B0;&#x5728;&#x6587;&#x6863;&#x53EF;&#x89C6;&#x533A;&#x57DF;&#x6216;&#x6587;&#x6863;&#x53EF;&#x89C6;&#x533A;&#x57DF;&#x7684;&#x9876;&#x90E8;">JavaScript|jQuery&#x5224;&#x65AD;&#x5143;&#x7D20;&#x5373;&#x5C06;&#x51FA;&#x73B0;&#x5728;&#x6587;&#x6863;&#x53EF;&#x89C6;&#x533A;&#x57DF;&#x6216;&#x6587;&#x6863;&#x53EF;&#x89C6;&#x533A;&#x57DF;&#x7684;&#x9876;&#x90E8;</h4>
  242. <pre><code class="lang-javascript"><span class="hljs-comment">/* JavaScript&#x5224;&#x65AD;&#x5143;&#x7D20;&#x5373;&#x5C06;&#x51FA;&#x73B0;&#x5728;&#x6587;&#x6863;&#x53EF;&#x89C6;&#x533A;&#x57DF;&#x6216;&#x79BB;&#x5F00;&#x6587;&#x6863;&#x53EF;&#x89C6;&#x533A;&#x57DF;.
  243. &#x4E00;&#x3001;&#x5224;&#x65AD;&#x5143;&#x7D20;&#x662F;&#x5426;&#x5904;&#x4E8E;&#x53EF;&#x89C6;&#x6587;&#x6863;&#x533A;&#x57DF;&#x9876;&#x90E8;
  244. &#x5224;&#x65AD;&#x6761;&#x4EF6;:DOMTop.offsetTop + clientHeight - 10 &lt; clientHeight + scrollTop
  245. &#x89E3;&#x6790;:
  246. &#x83B7;&#x53D6;&#x5143;&#x7D20;&#x8DDD;&#x79BB;&#x6587;&#x6863;&#x9876;&#x7AEF;&#x7684;&#x957F;&#x5EA6;,&#x7136;&#x540E;&#x4E0E;&#x7A97;&#x53E3;&#x7684;&#x9AD8;&#x5EA6;&#x76F8;&#x52A0;;
  247. &#x63A5;&#x7740;,&#x518D;&#x901A;&#x8FC7;&#x83B7;&#x53D6;&#x7A97;&#x53E3;&#x6EDA;&#x52A8;&#x6761;&#x9876;&#x7AEF;&#x4E0E;&#x6587;&#x6863;&#x9876;&#x7AEF;&#x7684;&#x8DDD;&#x79BB;;
  248. &#x5E76;&#x901A;&#x8FC7;&#x5224;&#x65AD;&#x5F97;&#x5230;&#x5143;&#x7D20;&#x662F;&#x5426;&#x5904;&#x4E8E;,&#x8DDD;&#x79BB;&#x53EF;&#x89C6;&#x6587;&#x6863;&#x533A;&#x57DF;&#x7684;&#x9876;&#x90E8;10&#x4E2A;&#x5355;&#x4F4D;&#x7684;&#x4F4D;&#x7F6E;.
  249. &#x4E8C;&#x3001;&#x5224;&#x65AD;&#x5143;&#x7D20;&#x662F;&#x5426;&#x5373;&#x5C06;&#x51FA;&#x73B0;&#x5728;&#x53EF;&#x89C6;&#x7A97;&#x53E3;&#x7684;&#x5E95;&#x90E8;
  250. &#x5224;&#x65AD;&#x6761;&#x4EF6;:DOMTop.offsetTop -10 &lt; clientHeight + scrollTop
  251. &#x89E3;&#x6790;:&#x57FA;&#x672C;&#x601D;&#x8DEF;&#x540C;&#x4E0A;&#x4E00;&#x81F4;.
  252. */</span>
  253. <span class="hljs-function"><span class="hljs-keyword">function</span> <span class="hljs-title">init</span>(<span class="hljs-params"></span>) </span>{
  254. <span class="hljs-keyword">var</span> DOMTop = <span class="hljs-built_in">document</span>.getElementById(<span class="hljs-string">&apos;box&apos;</span>);
  255. <span class="hljs-built_in">document</span>.addEventListener(<span class="hljs-string">&apos;scroll&apos;</span>, <span class="hljs-function"><span class="hljs-keyword">function</span> (<span class="hljs-params"></span>) </span>{
  256. <span class="hljs-keyword">var</span> clientHeight = <span class="hljs-built_in">document</span>.documentElement.clientHeight;
  257. <span class="hljs-keyword">var</span> scrollTop = <span class="hljs-built_in">document</span>.documentElement.scrollTop;
  258. <span class="hljs-keyword">if</span> (DOMTop.offsetTop + clientHeight - <span class="hljs-number">10</span> &lt; clientHeight + scrollTop) {
  259. <span class="hljs-built_in">console</span>.log(<span class="hljs-string">&apos;&#x53D1;&#x73B0;&#x5143;&#x7D20;&apos;</span>)
  260. }
  261. })
  262. }
  263. <span class="hljs-built_in">window</span>.onload = init;
  264. <span class="hljs-comment">// delete init();</span>
  265. <span class="hljs-comment">/*jQuery&#x5224;&#x65AD;&#x5143;&#x7D20;&#x5373;&#x5C06;&#x51FA;&#x73B0;&#x5728;&#x6587;&#x6863;&#x53EF;&#x89C6;&#x533A;&#x57DF;&#x6216;&#x79BB;&#x5F00;&#x6587;&#x6863;&#x53EF;&#x89C6;&#x533A;&#x57DF;.
  266. &#x601D;&#x8DEF;&#x540C;&#x4E0A;&#x4E00;&#x81F4;,&#x8868;&#x8FBE;&#x65B9;&#x5F0F;&#x4E0D;&#x540C;
  267. &#x5F53;&#x5143;&#x7D20;&#x8DDD;&#x79BB;&#x53EF;&#x89C6;&#x533A;&#x57DF;&#x8FD8;&#x6709;10&#x7684;&#x957F;&#x5EA6;&#x65F6;,&#x6267;&#x884C;&#x76F8;&#x5173;&#x7A0B;&#x5E8F;*/</span>
  268. <span class="hljs-comment">/*$(document).ready(function () {
  269. $(window).scroll(function () {
  270. // console.log($(window).scrollTop() + $(window).height())
  271. // &#x6587;&#x6863;&#x8DDD;&#x79BB;&#x5C4F;&#x5E55;&#x53EF;&#x89C6;&#x533A;&#x57DF;&#x7684;&#x8DDD;&#x79BB;
  272. var DOMTop = $(&apos;.box&apos;).offset().top + 10;
  273. // &#x6587;&#x6863;&#x5DF2;&#x7ECF;&#x6ED1;&#x52A8;&#x7684;&#x8DDD;&#x79BB; + &#x7A97;&#x53E3;&#x7684;&#x9AD8;&#x5EA6;
  274. var DOMScrollHeight = $(window).scrollTop() + $(window).height();
  275. // &#x5143;&#x7D20;&#x8DDD;&#x79BB;&#x53EF;&#x89C6;&#x533A;&#x57DF;&#x9876;&#x90E8;&#x8DDD;&#x79BB;&#x4E3A;10&#x7684;&#x65F6;&#x5019;&#x89E6;&#x53D1;
  276. if (DOMTop &lt; DOMScrollHeight) {
  277. console.log(&apos;DOMTop&apos; + DOMTop);
  278. console.log(&apos;DOMScrollHeight&apos; + DOMScrollHeight);
  279. }
  280. });
  281. });*/</span>
  282. </code></pre>
  283. <h4 id="&#x5BFC;&#x822A;&#x6761;&#x52A8;&#x753B;&#xFF0C;&#x8BBE;&#x5B9A;">&#x5BFC;&#x822A;&#x6761;&#x52A8;&#x753B;&#xFF0C;&#x8BBE;&#x5B9A;</h4>
  284. <pre><code class="lang-javascript"><span class="hljs-function"><span class="hljs-keyword">function</span> <span class="hljs-title">navAnimation</span>(<span class="hljs-params"></span>) </span>{
  285. <span class="hljs-keyword">let</span> DOMTop = <span class="hljs-built_in">document</span>.getElementById(<span class="hljs-string">&apos;nav&apos;</span>), <span class="hljs-comment">// &#x83B7;&#x53D6;&#x5BFC;&#x822A;&#x5BF9;&#x8C61;</span>
  286. clientHeight = <span class="hljs-built_in">document</span>.documentElement.clientHeight, <span class="hljs-comment">// &#x83B7;&#x53D6;&#x7A97;&#x53E3;&#x53EF;&#x89C6;&#x533A;&#x57DF;&#x9AD8;&#x5EA6;</span>
  287. tru = <span class="hljs-literal">true</span>, <span class="hljs-comment">// &#x662F;&#x5426;&#x66FF;&#x6362;&#x7C7B;&#x540D;&#x7684;&#x4F9D;&#x636E;</span>
  288. clientHeightScrollTop = clientHeight + DOMTop.offsetTop + DOMTop.clientHeight; <span class="hljs-comment">// &#x662F;&#x5426;&#x66FF;&#x6362;&#x7C7B;&#x540D;&#x7684;&#x4F9D;&#x636E;</span>
  289. <span class="hljs-comment">// &#x76D1;&#x542C;&#x6587;&#x6863;&#x6EDA;&#x52A8;&#x6761;&#x4E8B;&#x4EF6;&#xFF0C;&#x7ED1;&#x5B9A;&#x52A8;&#x753B;</span>
  290. <span class="hljs-built_in">document</span>.addEventListener(<span class="hljs-string">&apos;scroll&apos;</span>, <span class="hljs-function"><span class="hljs-keyword">function</span> (<span class="hljs-params"></span>) </span>{
  291. <span class="hljs-keyword">let</span> scrollTop = <span class="hljs-literal">null</span>;
  292. <span class="hljs-keyword">if</span> (<span class="hljs-built_in">document</span>.body.scrollTop !== <span class="hljs-number">0</span>) {
  293. scrollTop = <span class="hljs-built_in">document</span>.body.scrollTop
  294. } <span class="hljs-keyword">else</span> {
  295. scrollTop = <span class="hljs-built_in">document</span>.documentElement.scrollTop
  296. }
  297. <span class="hljs-keyword">if</span> (tru &amp;&amp; clientHeightScrollTop &lt; clientHeight + scrollTop) {
  298. DOMTop.setAttribute(<span class="hljs-string">&apos;class&apos;</span>, <span class="hljs-string">&apos;page-nav top&apos;</span>);
  299. tru = <span class="hljs-literal">false</span>
  300. }
  301. <span class="hljs-keyword">if</span> (clientHeightScrollTop &gt; clientHeight + scrollTop) {
  302. DOMTop.setAttribute(<span class="hljs-string">&apos;class&apos;</span>, <span class="hljs-string">&apos;page-nav&apos;</span>);
  303. tru = <span class="hljs-literal">true</span>
  304. }
  305. }, <span class="hljs-literal">false</span>);
  306. }
  307. </code></pre>
  308. <h4 id="&#x951A;&#x94FE;&#x63A5;&#x8DF3;&#x8F6C;&#x8FC7;&#x6E21;">&#x951A;&#x94FE;&#x63A5;&#x8DF3;&#x8F6C;&#x8FC7;&#x6E21;</h4>
  309. <pre><code class="lang-javascript"><span class="hljs-comment">/*
  310. # &#x951A;&#x94FE;&#x63A5;&#x8DF3;&#x8F6C;&#x8FC7;&#x5EA6;
  311. &#x6761;&#x4EF6;&#xFF1A;
  312. 1.&#x76EE;&#x6807;&#x4F4D;&#x7F6E; &amp; &#x6EDA;&#x52A8;&#x6761;&#x4F4D;&#x7F6E; &#x8DDD;&#x79BB;&#x8FC7;&#x8FD1;
  313. 2.&#x76EE;&#x6807;&#x4F4D;&#x7F6E; &gt; &#x6EDA;&#x52A8;&#x6761;&#x4F4D;&#x7F6E;
  314. 3.&#x76EE;&#x6807;&#x4F4D;&#x7F6E; &lt; &#x6EDA;&#x52A8;&#x6761;&#x4F4D;&#x7F6E;
  315. &#x7B56;&#x7565;&#xFF1A;
  316. 1.&#x83B7;&#x53D6;&#x9700;&#x8981;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#x7684;&#x5BF9;&#x8C61;&#xFF1B;
  317. 2.&#x4F7F;&#x7528;for&#x5FAA;&#x73AF;&#x8BED;&#x53E5;&#xFF0C;&#x7ED9;&#x83B7;&#x53D6;&#x5230;&#x7684;&#x5BF9;&#x8C61;&#x96C6;&#x5408;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#xFF1B;
  318. 3.window.scrollTo(X,Y); &#x5907;&#x6CE8;&#xFF1A;X=window&#x6C34;&#x5E73;&#x65B9;&#x5411;&#x7684;&#x6EDA;&#x52A8;&#x6761;&#x79FB;&#x52A8;&#x4F4D;&#x7F6E;&#xFF1B;Y=window&#x6C34;&#x5E73;&#x65B9;&#x5411;&#x7684;&#x6EDA;&#x52A8;&#x6761;&#x79FB;&#x52A8;&#x4F4D;&#x7F6E;;
  319. 4.&#x6839;&#x636E;&#x6761;&#x4EF6;&#xFF0C;&#x6267;&#x884C;&#x4E0D;&#x540C;&#x4E8B;&#x4EF6;&#x3002;
  320. 5.&#x83B7;&#x53D6;`&#x76EE;&#x6807;&#x4F4D;&#x7F6E; &amp; &#x6EDA;&#x52A8;&#x6761;&#x4F4D;&#x7F6E;`&#x7684;&#x95F4;&#x8DDD;&#xFF0C;&#x9664;&#x4EE5;25&#x3002;&#x7136;&#x540E;&#x7528;&#x8BE5;&#x6570;&#x503C;&#x4E0E;`&#x6EDA;&#x52A8;&#x6761;&#x4F4D;&#x7F6E;`&#x76F8;&#x52A0;&#x6216;&#x76F8;&#x51CF;&#x3002;&#x800C;&#x7D2F;&#x52A0;&#x6216;&#x7D2F;&#x51CF;&#x7684;&#x8FC7;&#x7A0B;&#x901A;&#x8FC7;setInterval()&#x5B9A;&#x65F6;&#x5668;&#x65B9;&#x6CD5;&#x6765;&#x63A7;&#x5236;&#x3002;
  321. 6.&#x7A0B;&#x5E8F;&#x6267;&#x884C;&#x5B8C;&#x6BD5;&#x4E4B;&#x540E;&#xFF0C;&#x7528;clearInterval()&#x65B9;&#x6CD5;&#x6E05;&#x9664;&#x5B9A;&#x65F6;&#x5668;&#x3002;
  322. */</span>
  323. anchorLinkJumpTransition();
  324. <span class="hljs-function"><span class="hljs-keyword">function</span> <span class="hljs-title">anchorLinkJumpTransition</span>(<span class="hljs-params"></span>) </span>{
  325. <span class="hljs-keyword">let</span> aTag = <span class="hljs-built_in">document</span>.querySelectorAll(<span class="hljs-string">&apos;.animation-top a&apos;</span>);
  326. <span class="hljs-keyword">for</span> (<span class="hljs-keyword">let</span> i = <span class="hljs-number">0</span>; i &lt; aTag.length; i++) {
  327. aTag[i].addEventListener(<span class="hljs-string">&apos;click&apos;</span>, <span class="hljs-function"><span class="hljs-keyword">function</span> (<span class="hljs-params"></span>) </span>{
  328. <span class="hljs-keyword">var</span> $target = <span class="hljs-built_in">document</span>.getElementById(<span class="hljs-keyword">this</span>.hash.slice(<span class="hljs-number">1</span>));
  329. scrollToTop($target.offsetTop);
  330. <span class="hljs-function"><span class="hljs-keyword">function</span> <span class="hljs-title">scrollToTop</span>(<span class="hljs-params">scrollDuration</span>) </span>{
  331. <span class="hljs-keyword">let</span> scrollTop = <span class="hljs-literal">null</span>, <span class="hljs-comment">// &#x6EDA;&#x52A8;&#x6761;&#x5F53;&#x524D;&#x4F4D;&#x7F6E;</span>
  332. scrollStep = <span class="hljs-literal">null</span>, <span class="hljs-comment">// &#x6EDA;&#x52A8;&#x6761;&#x7D2F;&#x52A0;&#x524D;&#x7684;&#x4F4D;&#x7F6E;</span>
  333. s = <span class="hljs-number">0</span>; <span class="hljs-comment">// &#x5173;&#x95ED;&#x8BA1;&#x65F6;&#x5668;&#x7684;&#x6761;&#x4EF6; s = 25&#x65F6;</span>
  334. <span class="hljs-keyword">if</span> (<span class="hljs-built_in">document</span>.body.scrollTop !== <span class="hljs-number">0</span>) {
  335. scrollTop = <span class="hljs-built_in">document</span>.body.scrollTop
  336. } <span class="hljs-keyword">else</span> {
  337. scrollTop = <span class="hljs-built_in">document</span>.documentElement.scrollTop
  338. }
  339. scrollStep = scrollTop = <span class="hljs-built_in">Number</span>.parseInt(scrollTop);
  340. <span class="hljs-built_in">console</span>.log(<span class="hljs-string">&apos;&#x6EDA;&#x52A8;&#x524D;&#xFF0C;&#x6EDA;&#x52A8;&#x6761;&#x4F4D;&#x7F6E;:&apos;</span> + scrollTop);
  341. <span class="hljs-built_in">console</span>.log(<span class="hljs-string">&apos;&#x76EE;&#x6807;&#x4F4D;&#x7F6E;&#xFF1A;&apos;</span> + scrollDuration);
  342. <span class="hljs-comment">// &#x76EE;&#x6807;&#x4F4D;&#x7F6E; &amp; &#x6EDA;&#x52A8;&#x6761;&#x4F4D;&#x7F6E; &#x8DDD;&#x79BB;&#x8FC7;&#x8FD1;</span>
  343. <span class="hljs-built_in">console</span>.log(<span class="hljs-built_in">Math</span>.abs(scrollTop - scrollDuration))
  344. <span class="hljs-keyword">if</span> (<span class="hljs-built_in">Math</span>.abs(scrollTop - scrollDuration) &gt; <span class="hljs-number">21</span>) {
  345. <span class="hljs-keyword">let</span> scrollInterval = setInterval(<span class="hljs-function"><span class="hljs-keyword">function</span> (<span class="hljs-params"></span>) </span>{
  346. <span class="hljs-keyword">if</span> (s &lt; <span class="hljs-number">26</span>) {
  347. <span class="hljs-comment">// s &#x662F;&#x7D2F;&#x52A0;&#x7684;&#xFF0C;&#x6240;&#x4EE5;&#x7528;&#x6765;&#x8DDF;`&#x76EE;&#x6807;&#x4F4D;&#x7F6E; &amp; &#x6EDA;&#x52A8;&#x6761;&#x4F4D;&#x7F6E;`&#x7684;&#x95F4;&#x8DDD;&#xFF0C;&#x76F8;&#x4E58;&#xFF0C;&#x83B7;&#x5F97;&#x8FC7;&#x6E21;&#x6548;&#x679C;&#x3002;</span>
  348. <span class="hljs-built_in">window</span>.scrollTo(<span class="hljs-number">0</span>, scrollStep + (scrollDuration - scrollTop) / <span class="hljs-number">25</span> * s);
  349. s++;
  350. }
  351. <span class="hljs-keyword">else</span> {
  352. clearInterval(scrollInterval);
  353. scrollStep = <span class="hljs-literal">null</span>;
  354. }
  355. }, <span class="hljs-number">10</span>);
  356. }
  357. }
  358. }, <span class="hljs-literal">false</span>);
  359. }
  360. }
  361. </code></pre>
  362. <h4 id="&#x6587;&#x7AE0;&#x6807;&#x9898;&#x7684;&#x52A8;&#x753B;">&#x6587;&#x7AE0;&#x6807;&#x9898;&#x7684;&#x52A8;&#x753B;</h4>
  363. <pre><code class="lang-Javascript"><span class="hljs-function"><span class="hljs-keyword">function</span> <span class="hljs-title">animateIn</span>(<span class="hljs-params"></span>) </span>{
  364. <span class="hljs-keyword">let</span> animateIn = <span class="hljs-built_in">document</span>.querySelectorAll(<span class="hljs-string">&apos;.container .title strong&apos;</span>);
  365. <span class="hljs-comment">// console.log(animateIn.getAttribute(&apos;class&apos;))</span>
  366. <span class="hljs-comment">// console.log(animateIn)</span>
  367. <span class="hljs-keyword">let</span> that = <span class="hljs-literal">null</span>;
  368. <span class="hljs-keyword">for</span> (<span class="hljs-keyword">let</span> i = <span class="hljs-number">0</span>; i &lt; animateIn.length; i++) {
  369. animateIn[i].addEventListener(<span class="hljs-string">&apos;click&apos;</span>, <span class="hljs-function"><span class="hljs-keyword">function</span> (<span class="hljs-params"></span>) </span>{
  370. <span class="hljs-keyword">if</span> (that !== <span class="hljs-literal">null</span>) {
  371. that.removeAttribute(<span class="hljs-string">&apos;class&apos;</span>);
  372. <span class="hljs-keyword">if</span> (that === <span class="hljs-keyword">this</span>) {
  373. <span class="hljs-keyword">this</span>.removeAttribute(<span class="hljs-string">&apos;class&apos;</span>);
  374. that = <span class="hljs-literal">null</span>;
  375. <span class="hljs-keyword">return</span>;
  376. }
  377. }
  378. <span class="hljs-keyword">this</span>.setAttribute(<span class="hljs-string">&apos;class&apos;</span>, <span class="hljs-string">&apos;animate-in&apos;</span>);
  379. that = <span class="hljs-keyword">this</span>;
  380. })
  381. }
  382. }
  383. </code></pre>
  384. </div>
  385. <hr>
  386. <div class="btn-group btn-group-justified">
  387. <a class="btn" href="04.html"><b>上一页:</b> 正则截取指定字符串</a>
  388. <a class="btn" href="../../angular/study_notes/"><b>下一页:</b> Study notes</a>
  389. </div>
  390. </div>
  391. <div class="search-results">
  392. <div class="has-results">
  393. <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
  394. <ul class="search-results-list"></ul>
  395. </div>
  396. <div class="no-results">
  397. <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
  398. </div>
  399. </div>
  400. </div>
  401. </div>
  402. </div>
  403. </div>
  404. </div>
  405. </div>
  406. <footer class="gb-page-footer">
  407. <div class="container">
  408. <ul class="menu">
  409. <li class="pull-right">
  410. <span class="service-info">Copyright GitBook 2018</span>
  411. </li>
  412. <li>
  413. <a href="#">Return to the top</a>
  414. </li>
  415. <li>
  416. <a href="#">Updated May 30th 18</a>
  417. </li>
  418. </ul>
  419. </div>
  420. </footer>
  421. </div>
  422. <script src="../../gitbook/gitbook.js"></script>
  423. <script src="../../gitbook/gitbook-plugin-search-pro/jquery.mark.min.js"></script>
  424. <script src="../../gitbook/gitbook-plugin-search-pro/search.js"></script>
  425. <script src="../../gitbook/gitbook-plugin-lunr/lunr.min.js"></script>
  426. <script src="../../gitbook/gitbook-plugin-lunr/search-lunr.js"></script>
  427. <script>
  428. (function() {
  429. gitbook.page.hasChanged({"page":{"title":"常用功能收集","level":"2.2.6","depth":2,"next":{"title":"Study notes","level":"3.1","depth":1,"path":"angular/study_notes/README.md","ref":"angular/study_notes/README.md","articles":[{"title":"项目依赖","level":"3.1.1","depth":2,"path":"angular/study_notes/0_depend.md","ref":"angular/study_notes/0_depend.md","articles":[]},{"title":"内置指令","level":"3.1.2","depth":2,"path":"angular/study_notes/01_built-in_instructions.md","ref":"angular/study_notes/01_built-in_instructions.md","articles":[]},{"title":"表单","level":"3.1.3","depth":2,"path":"angular/study_notes/from/README.md","ref":"angular/study_notes/from/README.md","articles":[{"title":"模板案例","level":"3.1.3.1","depth":3,"path":"angular/study_notes/from/0_template_case.md","ref":"angular/study_notes/from/0_template_case.md","articles":[]},{"title":"formControl","level":"3.1.3.2","depth":3,"path":"angular/study_notes/from/01_formControl.md","ref":"angular/study_notes/from/01_formControl.md","articles":[]},{"title":"directives_源码解析","level":"3.1.3.3","depth":3,"path":"angular/study_notes/from/02_directives.md","ref":"angular/study_notes/from/02_directives.md","articles":[]},{"title":"ngModel","level":"3.1.3.4","depth":3,"path":"angular/study_notes/from/03_ng_model.md","ref":"angular/study_notes/from/03_ng_model.md","articles":[]},{"title":"表单验证&自定义验证器","level":"3.1.3.5","depth":3,"path":"angular/study_notes/from/04_Form-Validation_&_Custom-Validator.md","ref":"angular/study_notes/from/04_Form-Validation_&_Custom-Validator.md","articles":[]},{"title":"监听表单数据变化","level":"3.1.3.6","depth":3,"path":"angular/study_notes/from/05_Listen_to_form_data_changes.md","ref":"angular/study_notes/from/05_Listen_to_form_data_changes.md","articles":[]},{"title":"问题收集","level":"3.1.3.7","depth":3,"path":"angular/study_notes/from/06_Problem_collection.md","ref":"angular/study_notes/from/06_Problem_collection.md","articles":[]}]}]},"previous":{"title":"正则截取指定字符串","level":"2.2.5","depth":2,"path":"JavaScript/cases/04.md","ref":"JavaScript/cases/04.md","articles":[]},"dir":"ltr"},"config":{"plugins":["theme-official@2.1.1","-sharing","-fontsettings","sitemap","-search","search-pro"],"root":"./docs/","styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"pluginsConfig":{"sitemap":{"hostname":"https://blog.honghaitao.net/"},"search-pro":{"cutWordLib":"nodejieba","defineWord":["小需求","基础建设"]},"highlight":{},"lunr":{"maxIndexSize":1000000,"ignoreSpecialCharacters":false},"theme-official":{},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false}},"theme":"default","pdf":{"pageNumbers":true,"fontSize":12,"fontFamily":"Arial","paperSize":"a4","chapterMark":"pagebreak","pageBreaksBefore":"/","margin":{"right":62,"left":62,"top":56,"bottom":56}},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"variables":{"version":"0.0.1"},"title":"代码收集","gitbook":"3.1.1"},"file":{"path":"JavaScript/cases/05.md","mtime":"2018-05-30T08:23:34.364Z","type":"markdown"},"gitbook":{"version":"3.1.1","time":"2018-05-31T08:39:58.544Z"},"basePath":"../..","book":{"language":""}});
  430. })();
  431. </script>
  432. </body>
  433. </html>