<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;
          藍藍設計www.sdgs6788.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務

          日歷

          鏈接

          個人資料

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

          存檔

          日本精品一区二区久久久| 99久久做夜夜爱天天做精品| 一本久久a久久精品综合香蕉| 久久精品www| 麻豆精品久久久一区二区| 99久久99这里只有免费的精品| 久久夜色精品国产噜噜亚洲AV| 亚洲精品乱码久久久久久久久久久久| 亚洲国产成人久久综合野外| 狠狠色丁香久久婷婷综合| 亚洲色大成网站www久久九| 久久亚洲欧美国产精品| 久久精品视频免费| 女同久久| 日韩精品久久无码人妻中文字幕| 无码精品久久久久久人妻中字 | 久久久无码精品亚洲日韩蜜臀浪潮| 无码人妻精品一区二区三区久久久 | 久久精品中文字幕第23页| 亚洲精品午夜国产va久久| 久久99国内精品自在现线| 激情综合色综合久久综合| 伊人久久大香线蕉综合Av| 激情综合色综合久久综合| 日韩人妻无码精品久久免费一 | 伊人久久大香线蕉精品| 久久精品国产91久久综合麻豆自制 | 手机看片久久高清国产日韩| 久久香蕉国产线看观看精品yw| 久久精品?ⅴ无码中文字幕| 久久久黄色大片| 久久午夜电影网| 久久伊人五月丁香狠狠色| 99久久综合狠狠综合久久| 一本久久a久久精品亚洲| 国产免费久久精品99久久| 色欲av伊人久久大香线蕉影院| 久久久久久久国产免费看| 久久久青草久久久青草| 亚洲国产精品无码久久98| 欧美一级久久久久久久大片|