<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • Javascrpit之打字機效果

          2018-6-25    seo達人

          如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里

          今天來看看怎么實現炫酷的打字機效果。即把一段話一個字一個字的顯示出來。

          效果圖:

          實現思路:

          首先規定好顯示字數的速度即settimeout執行間隔用來控制每個字之間輸出速度。再把判斷段落的總字數,循環段落總字數來實現一個字一個字的輸出。

          js代碼:

          
              
          1. var theNewsNum;
          2. var theAddNum;
          3. var totalNum;
          4. var CurrentPosion=0;
          5. var theCurrentNews;
          6. var theCurrentLength;
          7. var theNewsText;
          8. var theTargetLink;
          9. var theCharacterTimeout;
          10. var theNewsTimeout;
          11. var theBrowserVersion;
          12. var theWidgetOne;
          13. var theWidgetTwo;
          14. var theSpaceFiller;
          15. var theLeadString;
          16. var theNewsState;
          17. function startTicker(){
          18. // ------ 設置初始數值
          19. theCharacterTimeout = 50;//字符間隔時間
          20. theNewsTimeout = 2000;//新聞間隔時間
          21. theWidgetOne = "_";//新聞前面下標符1
          22. theWidgetTwo = "-";//新聞前面下標符
          23. theNewsState = 1;
          24. theNewsNum = document.getElementById("incoming").children.AllNews.children.length;//新聞總條數
          25. theAddNum = document.getElementById("incoming").children.AddNews.children.length;//補充條數
          26. totalNum =theNewsNum+theAddNum;
          27. theCurrentNews = 0;
          28. theCurrentLength = 0;
          29. theLeadString = " ";
          30. theSpaceFiller = " ";
          31. runTheTicker();
          32. }
          33. // --- 基礎函數
          34. function runTheTicker(){
          35. if(theNewsState == 1){
          36. if(CurrentPosion<theNewsNum){
          37. setupNextNews();
          38. }
          39. else{
          40. setupAddNews();
          41. }
          42. CurrentPosion++;
          43. if(CurrentPosion>=totalNum||CurrentPosion>=1){
          44. CurrentPosion=0;//最多條數不超過num_gun條
          45. }
          46. }
          47. if(theCurrentLength != theNewsText.length){
          48. drawNews();
          49. }
          50. else{
          51. closeOutNews();
          52. }
          53. }
          54. // --- 跳轉下一條新聞
          55. function setupNextNews(){
          56. theNewsState = 0;
          57. theCurrentNews = theCurrentNews % theNewsNum;
          58. theNewsText = document.getElementById("AllNews").children[theCurrentNews].children.Summary.innerText;
          59. theTargetLink = document.getElementById("AllNews").children[theCurrentNews].children.Summary.children[0].href;
          60. theCurrentLength = 0;
          61. document.all.hottext.href = theTargetLink;
          62. theCurrentNews++;
          63. }
          64. function setupAddNews() {
          65. theNewsState = 0;
          66. theCurrentNews = theCurrentNews % theAddNum;
          67. theNewsText = document.getElementById("AllNews").children[theCurrentNews].children.Summary.innerText;
          68. theTargetLink = document.getElementById("AllNews").children[theCurrentNews].children.Summary.children[0].href;
          69. theCurrentLength = 0;
          70. document.all.hottext.href = theTargetLink;
          71. theCurrentNews++;
          72. }
          73. // --- 滾動新聞
          74. function drawNews(){
          75. var myWidget;
          76. if((theCurrentLength % 2) == 1){
          77. myWidget = theWidgetOne;
          78. }
          79. else{
          80. myWidget = theWidgetTwo;
          81. }
          82. document.all.hottext.innerHTML = theLeadString + theNewsText.substring(0,theCurrentLength) + myWidget + theSpaceFiller;
          83. theCurrentLength++;
          84. setTimeout("runTheTicker()", theCharacterTimeout);
          85. }
          86. // --- 結束新聞循環
          87. function closeOutNews(){
          88. document.all.hottext.innerHTML = theLeadString + theNewsText + theSpaceFiller;
          89. theNewsState = 1;
          90. setTimeout("runTheTicker()", theNewsTimeout);
          91. }
          92. window.onload=startTicker;
          藍藍設計m.sdgs6788.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務

          日歷

          鏈接

          個人資料

          藍藍設計的小編 http://m.sdgs6788.com

          存檔

          无码国内精品久久人妻麻豆按摩| 久久精品中文字幕有码| 热RE99久久精品国产66热| 久久这里只有精品首页| 久久精品国产亚洲av影院| 热99RE久久精品这里都是精品免费 | 麻豆AV一区二区三区久久| 国产人久久人人人人爽| 国产精品亚洲美女久久久| 狠狠色狠狠色综合久久| 久久香蕉国产线看观看乱码| 久久A级毛片免费观看| 老司机国内精品久久久久| 波多野结衣AV无码久久一区| 久久精品一区二区三区AV| 中文精品久久久久人妻不卡| 国产精品99久久久久久宅男小说| 国产精品成人久久久| 久久久精品2019免费观看| 久久福利青草精品资源站免费 | 久久精品视频91| 久久久久亚洲AV成人网| 久久久久国产精品麻豆AR影院| 伊人久久五月天| 乱亲女H秽乱长久久久| 91久久精品电影| 亚洲人成网站999久久久综合| 日韩人妻无码一区二区三区久久99| 久久人人爽人人人人爽AV| AV狠狠色丁香婷婷综合久久| 欧美精品一本久久男人的天堂| 久久久久97国产精华液好用吗| 亚洲精品无码专区久久久| 99久久精品费精品国产一区二区| 久久精品国产第一区二区| 久久久久亚洲av综合波多野结衣| 99久久精品费精品国产一区二区| 久久综合色区| 热99re久久国超精品首页| 久久精品国产亚洲av麻豆蜜芽 | 无码人妻久久一区二区三区免费丨 |