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

JS實現(xiàn)簡單控制視頻播放倍速的實例代碼

 更新時間:2021年04月18日 12:02:49   作者:Treasure map  
這篇文章主要介紹了通過JS來實現(xiàn)簡單控制視頻播放倍速,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

引言

之前就發(fā)現(xiàn)一個問題:有時候看一些學習視頻,總是嫌它動作太慢,老師黑板上寫板書很浪費時間,要是控制合適倍速播放,這樣既能提升學習效率,也能讓自己看著舒服點。所以我就學著寫了下面這個網(wǎng)頁,通過Html+CSS+JavaScript實現(xiàn)。

提示:以下是本篇文章正文內(nèi)容,下面案例可供參考

一、成品效果

這是我做的成品截圖

二、具體實現(xiàn)

1.HTML+CSS實現(xiàn)簡單布局

代碼如下(示例):

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="style.css" rel="external nofollow" >
    <title>視頻播放</title>
    
</head>
<body>
    <div id="wrapper">
        <video width="765" height="430" src="http://clips.vorwaerts-gmbh.de/VfE_html5.mp4" controls class="flex"></video>
        
        <div class="speed">
            <div class="speed-bar">1x</div>
        </div>
        
    </div>
    

    <script src="./index.js"></script>
</body>
</html>
*{
    margin: 0;
    padding: 0;
}
body{
    min-height: 100vh;/*   vh相對單位,相對于瀏覽器的尺寸改變*/
    background: #4c4c4c url('https://unsplash.it/1500/900?image=1021');
    background-size: cover;/*以容器為基準,將容器覆蓋滿,哪怕圖片失真、模糊*/
    /*margin: auto;/* margin:auto和margin:0 auto    但不知道父容器寬高,不合適*/
    display: flex;/*將容器設(shè)置為彈性容器*/
    justify-content: center;    /*在X方向居中*/
    align-items: center;        /*在Y方向居中*/         /*課外拓展:將盒子在垂直方向居中的所有方式*/
}
#wrapper{
    width: 850px;
    display: flex;
}
.speed{
    flex: 1;/*等比繼承,本來應該是1:1繼承,但是vedio有固定寬度,所以speed拿剩下寬度*/
    margin: 10px;
    background-color: #fff;
    border-radius: 50px;
    display: flex;
    overflow: hidden;/*起到:規(guī)定子容器不能超出,能保持父類圓角效果*/
    align-items: flex-start;/* */

}
.speed-bar{
    width: 100%;
    height: 16.3%;
    background:linear-gradient(-170deg,#2376ae 0%,#c16ecf 100%);    /*設(shè)置漸變色樣式*/
    display: flex;              /*使得容器可以設(shè)置接下來兩個樣式*/
    justify-content: center;
    align-items: center;
    color: #fff;
    cursor: pointer;
}

HTML處的排版其實中規(guī)中矩,只是設(shè)置了一個用于包裝的id選擇器,然后通過video標簽使用H5自帶的視頻播放功能,可以通過更改src來更改播放的視頻。
css處的話大家只要注意彈性盒子的使用,通過彈性容器設(shè)置了視頻的水平垂直居中

2.JS實現(xiàn)功能

代碼如下(示例):

//1.拿到要操作的dom結(jié)構(gòu)
//2.取到鼠標在該dom上滑動的距離
//3.改變該dom的高度
//4.改變視頻的播放速度

//獲取對應的dom結(jié)構(gòu)
var speed=document.querySelector('.speed')//補充:getElementsByClassName   都是獲取class選擇器
var bar=document.querySelector('.speed-bar')
var video=document.querySelector('.flex')

speed.addEventListener('mousemove',function(e){     //簡單來說就是指向了當前發(fā)生的事件(click、mouseover等等),保存了當前事件的信息。如鼠標點擊事件,有鼠標的坐標信息。
    //console.log(e);
    var y=e.pageY-speed.offsetTop           //鼠標在右側(cè)容器中的距離        offsetTop是獲取某個dom結(jié)構(gòu)到瀏覽器頂部的距離
    var percent = y / speed.offsetHeight    //offsetHeight是獲取某個dom結(jié)構(gòu)自身的高度
    var min = 0.4           //設(shè)置倍速極限
    var max = 4
    var playbackRate = percent * (max-min)+min      //倍速計算
    var height = Math.round(percent * 100)+'%'//Math.abs()   也是取絕對值
    bar.textContent = playbackRate.toFixed(2)+'×'           //改變dom里面的文本內(nèi)容    toFixed(x)  保留x位小數(shù)

    video.playbackRate = playbackRate       //調(diào)整video的播放倍速

    bar.style.height = height       //調(diào)整倍數(shù)文本的顯示高度

})
//注:函數(shù)的倆參數(shù)作用分別為:監(jiān)聽鼠標點擊事件       函數(shù)里面定義函數(shù),成為回調(diào)函數(shù)

重點在于s處實現(xiàn)控制功能,在編寫Js版塊時,我們應該明確自己要Js幫我們干什么

1.拿到要操作的dom結(jié)構(gòu)
2.取到鼠標在該dom上滑動的距離
3.改變該dom的高度
4.改變視頻的播放速度

有了目標,我們就一個一個去實現(xiàn)它
具體實現(xiàn)可以直接看原碼,這里重點提一下回調(diào)函數(shù)和鼠標控制倍速原理??梢钥吹?br /> speed.addEventListener( " mousemove " ,function(e){)
這是個回調(diào)函數(shù),當mousemove發(fā)生的時候就會執(zhí)行函數(shù)function (e) tmousemove則是起到監(jiān)聽鼠標位置的作用

到此這篇關(guān)于通過JS來實現(xiàn)簡單控制視頻播放倍速的文章就介紹到這了,更多相關(guān)js視頻播放倍速內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JavaScript跨瀏覽器獲取頁面中相同class節(jié)點的方法

    JavaScript跨瀏覽器獲取頁面中相同class節(jié)點的方法

    這篇文章主要介紹了JavaScript跨瀏覽器獲取頁面中相同class節(jié)點的方法,本文講解使用getELementsByClassName函數(shù)解決這個需求,并給了一個開源的getELementsByClassName函數(shù)實現(xiàn),功能更加強大,需要的朋友可以參考下
    2015-03-03
  • 小程序調(diào)用微信支付的方法

    小程序調(diào)用微信支付的方法

    這篇文章主要為大家詳細介紹了小程序調(diào)用微信支付的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • 教學演示-UBB,剪貼板,textRange及其他

    教學演示-UBB,剪貼板,textRange及其他

    [紅色]教學演示-UBB,剪貼板,textRange及其他...
    2006-11-11
  • javascript網(wǎng)頁隨機點名實現(xiàn)過程解析

    javascript網(wǎng)頁隨機點名實現(xiàn)過程解析

    這篇文章主要介紹了javascript實現(xiàn)網(wǎng)頁隨機變色及實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-10-10
  • 終于解決了IE8不支持數(shù)組的indexOf方法

    終于解決了IE8不支持數(shù)組的indexOf方法

    今天,測試報過來一個js bug, 在IE8下有個js錯誤,但是在其它瀏覽器下(Firefox, Chrome, IE9)下面都很正常。后來調(diào)試發(fā)現(xiàn)原因是在IE8下,js數(shù)組沒有indexOf方法。
    2013-04-04
  • Typescript3.9 常用新特性一覽(推薦)

    Typescript3.9 常用新特性一覽(推薦)

    這篇文章主要介紹了Typescript3.9 常用新特性一覽,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • 優(yōu)雅處理前端異常的幾種方式推薦

    優(yōu)雅處理前端異常的幾種方式推薦

    前端一直是距離用戶最近的一層,隨著產(chǎn)品的日益完善,我們會更加注重用戶體驗,而前端異常卻如鯁在喉,甚是煩人,下面這篇文章主要給大家推薦介紹了關(guān)于優(yōu)雅處理前端異常的幾種方式,需要的朋友可以參考下
    2022-08-08
  • js 遍歷json返回的map內(nèi)容示例代碼

    js 遍歷json返回的map內(nèi)容示例代碼

    js 遍歷json的方法有很多,在本文為大家詳細介紹下如何返回的map內(nèi)容,感興趣的朋友可以參考下
    2013-10-10
  • 手把手教你 CKEDITOR 4 實現(xiàn)Dialog 內(nèi)嵌 IFrame操作詳解

    手把手教你 CKEDITOR 4 實現(xiàn)Dialog 內(nèi)嵌 IFrame操作詳解

    這篇文章主要介紹了手把手教你 CKEDITOR 4 實現(xiàn)Dialog 內(nèi)嵌 IFrame操作,結(jié)合實例形式分析了CKEDitor4 Dialog內(nèi)嵌IFrame具體操作步驟與相關(guān)注意事項,需要的朋友可以參考下
    2019-06-06
  • Javascript 引擎工作機制詳解

    Javascript 引擎工作機制詳解

    我們需要引入幾個相關(guān)的概念:執(zhí)行環(huán)境棧、全局對象、執(zhí)行環(huán)境、變量對象、活動對象、作用域和作用域鏈等,這些概念正是JS引擎工作的核心組件。這篇文章的目的不是孤立的為你講解每一個概念需要的朋友可以參考下
    2016-11-11

最新評論