欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Javascript+CSS3實現(xiàn)進度條效果

 更新時間:2016年10月28日 09:54:27   作者:涂根華  
本篇文章主要介紹Javascript+CSS3實現(xiàn)進度條效果,可以實現(xiàn)給用戶一個等待的過程,有需要的可以了解一下。

進度條在很多web中都能用的到,本文就是介紹了進度條效果,具體代碼如下:

一:css2 屬性clip實現(xiàn)網頁進度條;

在實現(xiàn)之前,我們先來介紹一下clip屬性,因為這個屬性在css2.1中很少使用到,所以我們有必要來了解一下;

瀏覽器支持程度:所有主流瀏覽器都支持 clip 屬性。

Clip屬性在w3c官網是這樣描述的:通過對元素進行裁剪來控制元素的可視區(qū)域,默認情況下 元素是不進行任何裁剪的。

Clip裁剪的語法如下:

 .xx {clip:rect(<top>, <right>, <bottom>, <left>)}

Rect屬性需要四個值,top,right,bottom,left;他們之間需要使用逗號隔開。遵循順時針旋轉規(guī)則,和我們的css中的margin,padding書寫順序一樣的。

在css2.1中,rect()的<top>,<bottom>指定偏移量是從元素的盒子頂部邊緣算起的,<left>,<right>指定的偏移量是從元素的盒子左邊邊緣算起的。如下:

我們可以再來看一個簡單的demo,

如下css

p#one { clip: rect(5px, 40px, 45px, 5px); }

p#two { clip: rect(5px, 55px, 45px, 5px); }

上面的例子是在50X55px的長方形盒子中是行剪切,得到虛線的長方形:

如下圖:

我們現(xiàn)在可以先來看一個進度條的demo;

HTML代碼如下:

<h2>使用clip實現(xiàn)裁剪demo</h2>
<div id="progress-box" class="progress-box">
  <div id="progress-bar" class="progress-bar"></div>
  <div id="progress-text" class="progress-text">0%</div>
</div>

CSS代碼如下:

.progress-box{position:absolute;left:0;width:300px;height:60px;border:1px solid #000;margin-left:20px;}
.progress-bar{position:absolute;left:0;top:0;width:300px;height:60px;clip:rect(0px,0px,60px,0px);background:red;}
.progress-text{position:absolute;left:0;top:0;width:300px;height:60px;color:Black;text-align:center; line-height:60px; font-family:Georgia;font-size:2em;font-weight:bold;}

這里需要解釋一下上面的HTML3個div,一個是元素容器(progress-box)基本就是想突出邊框,讓用戶知道100%應該是有多長的容量,

第二個progress-bar是表示不斷變化的元素背景色設置為紅色,

第三個是表示進度顯示的數(shù)值文本。

為了演示效果,我們需要一個簡單的JS中的setInterval代碼來演示進度條的效果;如下setInterval的代碼;

var bar = document.getElementById("progress-bar"),
   text = document.getElementById("progress-text");
var cent = 0,
   max = 300;
var timer = setInterval(progressFn, 30);
function progressFn() {
  if(cent > max) {
    cent = 0;
    timer = setInterval(arguments.callee(), 30);
  }else {
    bar.style.clip = "rect(0px," + cent + "px,60px,0px)";
    text.innerHTML = Math.ceil((cent / max) * 100) + "%";
    cent++;
  }
}

demo如下效果;使用clip實現(xiàn)裁剪demo

二:使用進度事件(progress)與服務器端交互 來實現(xiàn)網頁進度條;

進度事件(progress) : 定義了與客戶端服務器通信有關的事件,有以下6個進度事件。

  1. loadstart:在接收到相應數(shù)據的第一個字節(jié)時觸發(fā)。
  2. progress:在接收相應期間持續(xù)不斷觸發(fā)。
  3. error:在請求發(fā)生錯誤時觸發(fā)。
  4. abort:在因為調用abort()方法而終止鏈接時觸發(fā)。
  5. load:在接收到完整的相應數(shù)據時觸發(fā)。
  6. loadend:在通信完成或者觸發(fā)error、abort或load事件后觸發(fā)。

每個請求不對觸發(fā)Loadstart事件開始,接下來是一或多個progress事件,然后觸發(fā)error、abort或load事件中的一個,最后以觸發(fā)loadend事件結束。

支持前5個事件的瀏覽器有Firefox 3.5+、Safari 4+、Chrome、iOS版Safari和Android版WebKit。

這個事件會在瀏覽器接收新數(shù)據期間周期性地觸發(fā)。而onprogress事件處理程序會接收到一個event對象,其target屬性是XHR對象,但包含著三個額外的屬性:lengthComputable、position和totalSize。其中,lengthComputable是一個表示進度信息是否可用的布爾值,position表示已經接收的字節(jié)數(shù),totalSize表示根據Content-Length相應頭部確定的預期字節(jié)數(shù)。有了這些信息,我們就可以為用戶創(chuàng)建一個進度指示器了。如下截圖有上面介紹的三個參數(shù);

HTML代碼如下:

<h2>使用clip實現(xiàn)裁剪demo</h2>
<div id="progress-box" class="progress-box">
  <div id="progress-bar" class="progress-bar"></div>
  <div id="progress-text" class="progress-text">0%</div>
</div>
<div id="status"></div>

與服務器端交互的代碼如下:

var divbar = document.getElementById("progress-bar"),
  divText = document.getElementById("progress-text");
var cent = 0,
  max = 300;
function createXHR(){
   var xhr;
   if (window.XMLHttpRequest){// code for IE7+, Firefox, Chrome, Opera, Safari
     xhr=new XMLHttpRequest();
   }else{ // code for IE6, IE5
     xhr=new ActiveXObject("Microsoft.XMLHTTP");
   }
   return xhr;
 }
 var xhr = createXHR();
 xhr.onload = function() {
  if((xhr.status >= 200 && xhr.status < 300) || xhr.status == 304) {
     alert(xhr.responseText);
  }else {
     alert("Request was unsuccessful: " + xhr.status);
  }
 }
 xhr.onprogress = function(event) {
  var divStatus = document.getElementById("status");
  if (event.lengthComputable) {
      divStatus.innerHTML = "Recived" + event.position + " of " + event.totalSize + " bytes";
      console.log(event.target);
      var percentComplete = Math.round(event.loaded / event.total);
      // 其中的event.loaded表示當前加載了多少字節(jié)流,而event.total表示總共有多少字節(jié)流 得到這樣一個百分比,
      console.log(event.loaded, event.total, 300 * percentComplete);
      progressFn(300 * percentComplete, max);
   }
 }
    
 xhr.open("get", "progress.php", true);
 xhr.send(null); 
 function progressFn(cent,max) {
   if (cent < max) {
     divbar.style.clip = "rect(0px," + cent + "px,60px,0px)";
     divText.innerHTML = Math.ceil((cent / max) * 100) + "%";
   } 
 }

PHP代碼 為了隨便模擬下 隨便寫一個,當然在實際使用上肯定不是這樣的哦!我只是輸出一個內容而已;

<?php
  header("Content-Type: text/plain");
  header("Content-Length: 27");
  echo "Some data";
  flush();
  echo "Some data";
  flush();
  echo "Some data";
  flush();
?>

三: CSS3 動畫及線性漸變實現(xiàn)進度條demo;

HTML代碼如下:

<div id="loading-status">
  <div id="process"></div>
</div>

CSS代碼如下:

#loading-status {width:300px;border:1px solid #669CB8;-webkit-box-shadow: 0px 2px 2px #D0D4D6; -moz-box-shadow:0px 2px 2px #D0D4D6;border-radius: 10px;height:20px;padding: 1px;}
#process {width: 80%;height: 100%;border-radius: 10px;background: -webkit-gradient(linear, 0 0, 0 100%, from(#7BC3FF), color-stop(0.5,#42A9FF), to(#7BC3FF));-webkit-animation: load 3s ease-out infinite;}
@-webkit-keyframes load {
  0% {
    width: 0%;      
  }
  100% {
    width: 80%;    
  }
}

效果如下:

相關文章

  • 詳解webpack require.ensure與require AMD的區(qū)別

    詳解webpack require.ensure與require AMD的區(qū)別

    本篇文章主要介紹了詳解webpack require.ensure與require AMD的區(qū)別,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • Three.js加載外部模型的教程詳解

    Three.js加載外部模型的教程詳解

    這篇文章主要介紹了Three.js外部模型加載的教程詳解,在文章給大家補充介紹了three.js 外部模型加載json的方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-11-11
  • JS中JSON.stringify使用場景面試精講

    JS中JSON.stringify使用場景面試精講

    這篇文章主要為大家介紹了JS中JSON.stringify使用場景面試精講,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • JavaScript實現(xiàn)二叉搜索樹

    JavaScript實現(xiàn)二叉搜索樹

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)二叉搜索樹,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • uni-app h5端在jenkins構建報錯解決

    uni-app h5端在jenkins構建報錯解決

    這篇文章主要為大家介紹了uni-app h5端在jenkins構建報錯解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • JavaScript簡單生成 N~M 之間隨機數(shù)的方法

    JavaScript簡單生成 N~M 之間隨機數(shù)的方法

    這篇文章主要介紹了JavaScript簡單生成 N~M 之間隨機數(shù)的方法,結合自定義函數(shù)分析了JS生成固定區(qū)間內隨機數(shù)的相關操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2017-01-01
  • js限制input標簽中只能輸入中文

    js限制input標簽中只能輸入中文

    這篇文章主要介紹了js限制input標簽中只能輸入中文的的相關資料,需要的朋友可以參考下
    2015-06-06
  • 微信小程序實現(xiàn)選項卡效果

    微信小程序實現(xiàn)選項卡效果

    這篇文章主要介紹了微信小程序實現(xiàn)選項卡效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 《javascript設計模式》學習筆記五:Javascript面向對象程序設計工廠模式實例分析

    《javascript設計模式》學習筆記五:Javascript面向對象程序設計工廠模式實例分析

    這篇文章主要介紹了Javascript面向對象程序設計工廠模式,結合實例形式分析了《javascript設計模式》中Javascript面向對象工廠模式相關概念、原理、用法及操作注意事項,需要的朋友可以參考下
    2020-04-04
  • 一張Web前端的思維導圖分享

    一張Web前端的思維導圖分享

    這篇文章主要介紹了一張Web前端的思維導圖分享,本文直接給出思維導圖,圖中詳細描述了一些需要學習的知識、一些必備的知識,需要的朋友可以參考下
    2015-07-07

最新評論