H5自帶進度條&滑塊


一、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">的軌道

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM