一、H5自帶進度條
1 <div id="d1"> 2 <p id="pgv">進度:0%</p> 3 <progress id="pg" max="100" value="0"></progress> 4 </div>
運用progress標簽,設置好min和max數值就好。可以用value獲取其中的進度值
1 function staticProgress () { 2 var pg = document.getElementById('pg') 3 var pgv = document.getElementById('pgv') 4 var timer = setInterval(function () { 5 if (pg.value !== 100) { 6 pg.value++ 7 pgv.innerHTML = '進度:' + pg.value + '%' 8 } else { 9 pgv.innerHTML = '加載完成' 10 clearInterval(timer) 11 } 12 }, 100) 13 }
最終效果如下:
這個顯示效果是chrome瀏覽器的,IE和FireFox的是另外的樣式!
樣式更改:
1 progress{ 2 -webkit-appearance: none; 3 } 4 ::-webkit-progress-bar{ 5 /* 獲取progress */ 6 background-color: orange; 7 /* 進度條未被填充的背景顏色 */ 8 } 9 ::-webkit-progress-value { 10 background-color: rgb(43, 255, 0); 11 /* 進度條被填充部分的背景顏色 */ 12 } 13 ::-webkit-progress-inner-element { 14 border: 2px solid black; 15 /* 進度條的內邊框,注意跟outline區分 */ 16 }
這里的樣式全部是針對webkit內核的,其他的不支持~~~ 效果如下:
二、H5自帶滑塊
將input的type設置為range。但是這個屬性不是所有瀏覽器都支持,如果不支持,會返回默認屬性,就是<input type="text">
(詳情參考https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range)
默認樣式:
1 <div id="d3"> 2 <p>H5可拖動滑塊:</p> 3 <input type="range" name="points" min="0" max="100" id="h5pro"/> 4 </div>
1、自帶屬性:
(1)、defaultValue = (rangeElem.max < rangeElem.min) ? rangeElem.min
: rangeElem.min + (rangeElem.max - rangeElem.min)/2;
默認值 = (設置最大值 < 設置最小值)?設置最小值 : 設置最小值 + ( 設置最大值 - 設置最小值 ) / 2 ———————— 其實就是取中間值
我們可以用value="7"
設置滑塊的值。
(2)、<input type="range" min="-10" max="10">
min: 設置最小值; max: 設置最大值
(3)、<input type="range" min="5" max="10" step="0.01">
step: 設置步進值,默認是1。如果min或者max設置了小數點,比如:max="3.14",這個小數點就取不到了,那么可以將step設置為: step="any"。
(4)、hash marks和label:
注意:目前沒有哪個瀏覽器完全支持hash marks和label這兩個屬性,比如Firefox兩個都不支持,Chrome支持hash marks但是不支持label.
a) hash marks:
1 <input type="range" name="points" min="0" max="100" step="any" id="h5pro" list="tickmarks"/> 2 <datalist id="tickmarks"> 3 <option value="0"> 4 <option value="10"> 5 <option value="20"> 6 <option value="30"> 7 <option value="40"> 8 <option value="50"> 9 <option value="60"> 10 <option value="70"> 11 <option value="80"> 12 <option value="90"> 13 <option value="100"> 14 </datalist>
b) label :
1 <input type="range" name="points" min="0" max="100" step="any" id="h5pro" list="tickmarks"/> 2 <datalist id="tickmarks"> 3 <option value="0" label="0%"> 4 <option value="10"> 5 <option value="20"> 6 <option value="30"> 7 <option value="40"> 8 <option value="50" label="50%"> 9 <option value="60"> 10 <option value="70"> 11 <option value="80"> 12 <option value="90"> 13 <option value="100" label="100%"> 14 </datalist>
(5)、autofocus可以設置或返回滑塊是否自動獲得焦點,設置為true后,進入網頁會自動鎖定滑塊,在鍵盤上按上下左右都可以控制
2、外觀美化:
1 input[type=range] { 2 outline: none; 3 -webkit-appearance: none; 4 /* 去除系統默認appearance的樣式,常用於IOS下移除原生樣式 */ 5 border-radius: 10px; 6 }
-webkit-appearance: none; 去除默認樣式
1 input[type=range]::-webkit-slider-runnable-track { 2 height: 15px; 3 border-radius: 10px; 4 box-shadow: 0 1px 1px #def3f8, inset 0 .125em .125em #0d1112; 5 }
::-webkit-slider-runnable-track 是個CSS偽類元素,不是所有瀏覽器都支持。可以獲取<input type="range">的軌道
詳情參考:https://developer.mozilla.org/en-US/docs/Web/CSS/::-webkit-slider-runnable-track
1 input[type=range]::-webkit-slider-thumb { 2 -webkit-appearance: none; /* 去除滑塊的默認樣式 */ 3 height: 25px; 4 width: 25px; 5 margin-top: -5px; 6 background:#7B05E0; 7 border-radius: 50%; 8 border: solid 0.125em rgba(205, 224, 230, 0.5); 9 box-shadow: 0 .125em .125em #3b4547; 10 }
::-webkit-slider-thumb 可以獲取<input type="range">的軌道