html播放本地音樂

本地有多個音樂文件,想用 html 逐個播放,或循環播放,并設置初始音量。

audio

在 html 中播放音樂文件用 audio 標簽:

  • controls 啟用控制按鈕,如進度條、播放、音量、速度等。不加不顯示任何 widget。
  • autoplay 理應啟用自動播放,但瀏覽器似乎禁止自動播放,故目前沒什么用。
  • muted 靜音。
<!DOCTYPE html>
<html>
<body><audio controls autoplay><source src="C:/Users/tom/Music/Wonderful U - 張含韻.mp3" type="audio/mpeg">Failed.
</audio><br/><audio controls muted><source src="C:/Users/tom/Music/Sacred Play Secret Place - Matryoshka.m4a" type="audio/x-m4a">Failed.
</audio></body>
</html>

Set Volume Automatically

想在打開 html 文件時,自動設置某個音量,如 20%,而不是默認的最大聲、或 muted 靜音。用到 javascript:

  • class 標記需要調音量的 audio;
  • script 內用 javascript 選中這些 audio,并設置其音量。
<!DOCTYPE html>
<body>
<!-- 用 `a` 標記需要自動校音量的 audio -->
<audio class="a" controls><source src="C:/Users/tom/Music/Wonderful U - 張含韻.mp3" type="audio/mpeg">Failed.
</audio>
<br/>
<audio class="a" controls><source src="C:/Users/tom/Music/Sacred Play Secret Place - Matryoshka.m4a" type="audio/x-m4a">Failed.
</audio><script>// 添加事件:加載時自動執行document.addEventListener("DOMContentLoaded", function() {var audioPlayers = document.querySelectorAll('.a'); // 根據 `a` 選 audio 元素audioPlayers.forEach(function(player) {player.volume = 0.2; // set initial volume});});
</script>
</body>
</html>

Play a List

有多個音樂文件,想順序或循環播放它們,同樣用 javascript 函數控制。

  • 瀏覽器可能禁止未有交互就自動播放,故一開頭要手動點播放,但后面可連播。
<!DOCTYPE html>
<body>
<!-- 放一個空 audio 元素 -->
<audio id="auto-audio" controls autoplay></audio><script>const path = 'C:/Users/tom/Music/'; // 音樂文件都在這個目錄下const playlist = ['嗵嗵 - DOUDOU.mp3','我拿什么留住你 - FloruitShow 福祿壽.mp3','琢磨 - 許靖韻.mp3'];let currentTrack = 0; // 目前播放的文件下標const audioPlayer = document.getElementById('auto-audio');// 播放函數function playTrack(index) {audioPlayer.src = path + playlist[index]; // 完整路徑audioPlayer.volume = 0.2; // 校音量audioPlayer.play().catch(error => {console.log("%cAutoplay prevented:", "color: red;", error);});}// 加載時執行document.addEventListener("DOMContentLoaded", function() {// 播放第一首(可能被瀏覽器阻止自動播放而失敗)playTrack(currentTrack);// 添加事件:播放結束后自動放下一首audioPlayer.addEventListener('ended', function () {// 順序播放if (currentTrack < playlist.length) {playTrack(currentTrack);}// 循環播放// currentTrack = (currentTrack + 1) % playlist.length;// playTrack(currentTrack);});});
</script>
</body>
</html>

References

  1. html用css grid實現自適應四宮格放視頻

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/72762.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/72762.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/72762.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

DeepSeek-Manus精品課合集【附下載】

AI消息不斷&#xff0c;繼DeepSeek之后&#xff0c;又出了一個顛覆性的AI產品Manus&#xff0c;號稱全球第一個通用型AI。相比與DeepSeek&#xff0c; Manus擁有更強的自主性和執行力。 如果說DeepDeek是一個最強大腦&#xff0c;那么Manus就是一個完整的人&#xff01; DeepS…

MySQL復習筆記

MySQL復習筆記 1.MySQL 1.1什么是數據庫 數據庫(DB, DataBase) 概念&#xff1a;數據倉庫&#xff0c;軟件&#xff0c;安裝在操作系統&#xff08;window、linux、mac…&#xff09;之上 作用&#xff1a;存儲數據&#xff0c;管理數據 1.2 數據庫分類 關系型數據庫&#…

從源到目標:深度學習中的遷移學習與領域自適應實踐

引言&#xff1a;數據驅動的智能時代與遷移挑戰 在深度學習快速發展的今天&#xff0c;模型訓練對數據量和質量的依賴成為核心瓶頸。面對新場景時&#xff0c;標注數據不足、數據分布差異等問題常導致模型性能驟降。遷移學習&#xff08;Transfer Learning&#xff09;與領域自…

【網絡】HTTP協議、HTTPS協議

HTTP與HTTPS HTTP協議概述 HTTP&#xff08;超文本傳輸協議&#xff09;&#xff1a;工作在OSI頂層應用層&#xff0c;用于客戶端&#xff08;瀏覽器&#xff09;與服務器之間的通信,B/S模式 無狀態&#xff1a;每次請求獨立&#xff0c;服務器不保存客戶端狀態&#xff08;通…

Jmeter使用介紹

文章目錄 前言Jmeter簡介安裝與配置JDK安裝與配置JMeter安裝與配置 打開JMeter方式一方式二 設置Jmeter語言為中文方法一&#xff08;僅一次性&#xff09;方法二(永久設置成中文) Jmeter文件常用目錄 元件與組件元件組件元件的作用域元件的執行順序第一個案例添加線程組添加 H…

【NLP 32、文本匹配任務 —— 深度學習】

大劫大難以后&#xff0c;人不該失去銳氣&#xff0c;不該失去熱度&#xff0c;你鎮定了卻依舊燃燒&#xff0c;你平靜了卻依舊浩蕩&#xff0c;致那個從絕望中走出來的自己&#xff0c;共勉 —— 25.1.31 使用深度學習在文本匹配任務上主要有兩種方式&#xff1a;① 表示型 ②…

發展史 | 深度學習 / 云計算

注&#xff1a;本文為來自 csdn 不錯的“深度學習 / 云計算發展史 ” 相關文章合輯。 對原文&#xff0c;略作重排。 深度學習發展史&#xff08;1943-2024 編年體&#xff09;&#xff08;The History of Deep Learning&#xff09; Hefin_H 已于 2024-05-23 15:54:45 修改 …

通領科技沖刺北交所

高質量增長奔赴產業新征程 日前&#xff0c;通領科技已正式啟動在北交所的 IPO 進程&#xff0c;期望借助資本市場的力量&#xff0c;加速技術升級&#xff0c;推動全球化戰略布局。這一舉措不僅展現了中國汽車零部件企業的強大實力&#xff0c;也預示著行業轉型升級的新突破。…

TCP/IP 5層協議簇:網絡層(ICMP協議)

1. TCP/IP 5層協議簇 如下&#xff1a; 和ip協議有關的才有ip頭 2. ICMP 協議 ICMP協議沒有端口號&#xff0c;因為不去上層&#xff0c;上層協議采用端口號

RISC-V匯編學習(三)—— RV指令集

有了前兩節對于RISC-V匯編、寄存器、匯編語法等的認識&#xff0c;本節開始介紹RISC-V指令集和偽指令。 前面說了RISC-V的模塊化特點&#xff0c;是以RV32I為作為ISA的核心模塊&#xff0c;其他都是要基于此為基礎&#xff0c;可以這樣認為&#xff1a;RISC-V ISA 基本整數指…

C語言 —— 愿此世如黃金般輝煌 - 進制轉換與操作符詳解

目錄 1. 操作符的分類 2. ?進制和進制轉換 2.1 2進制轉10進制 2.2 10進制轉2進制 2.3 2進制轉8進制 2.4 2進制轉16進制 3. 原碼、反碼、補碼 4. 移位操作符 4.1 左移操作符 4.2 右移操作符 5. 位操作符&#xff1a;&、|、^、~ 5.1 & 按位與 5.2 | 按位或 …

docker1

前言 技術架構 單機架構 應用數據分離架構 應用服務集群架構 讀寫分離/主從分離架構 寫入主的時候&#xff0c;要同步Mysql從的數據才可以 冷熱分離架構 寫的時候要寫入主和緩存數據庫 讀的時候先去緩存看有沒有&#xff0c;沒有的話就去從數據庫讀數據 主要就是看這個數據是…

Spring Boot整合ArangoDB教程

精心整理了最新的面試資料和簡歷模板&#xff0c;有需要的可以自行獲取 點擊前往百度網盤獲取 點擊前往夸克網盤獲取 一、環境準備 JDK 17Maven 3.8Spring Boot 3.2ArangoDB 3.11&#xff08;本地安裝或Docker運行&#xff09; Docker啟動ArangoDB docker run -d --name ar…

從離散迭代到連續 常微分方程(Ordinary Differential Equation, ODE):梯度流

從離散迭代到連續 ODE&#xff1a;梯度下降與梯度流的奇妙聯系 在機器學習和優化領域&#xff0c;我們常常使用離散的迭代算法&#xff08;如梯度下降&#xff09;來求解目標函數的最優解。然而&#xff0c;你是否想過這些離散步驟背后可能隱藏著連續的動態&#xff1f;常微分…

常見的 Git 命令

基礎配置和信息查詢 (Setup and Information) git config --global user.name “Your Name”: 配置全局用戶名&#xff0c;用于 Git 提交記錄。 git config --global user.email “your.emailexample.com”: 配置全局用戶郵箱&#xff0c;同樣用于 Git 提交記錄。 git confi…

深度解析:視頻軟編碼與硬編碼的優劣對比

視頻編碼 一、基本原理與核心技術 壓縮原理 通過時空冗余消除實現數據壓縮&#xff1a; 空間冗余&#xff1a;利用幀內預測&#xff08;如DC/角度預測&#xff09;消除單幀內相鄰像素相似性。時間冗余&#xff1a;運動估計與補償技術&#xff08;ME/MC&#xff09;減少連續幀間…

藍耘智算 + 通義萬相 2.1:為 AIGC 裝上 “智能翅膀”,翱翔創作新天空

1. 引言&#xff1a;AIGC 的崛起與挑戰 在過去幾年中&#xff0c;人工智能生成內容&#xff08;AIGC&#xff09;技術突飛猛進。AIGC 涉及了文本生成、圖像創作、音樂創作、視頻制作等多個領域&#xff0c;并逐漸滲透到日常生活的方方面面。傳統的內容創作方式已經被許多人類創…

行為模式---中介者模式

概念 中介者模式是一種行為模式&#xff0c; 他的核心思想是通過引入一個中介者對象&#xff0c;將多個對象之間的復雜交互邏輯統一管理。每個對象只需要與中介者通信&#xff0c;而不需要直接與其他對象交互&#xff0c;從而降低系統的耦合度。 適用場景 對象之間交互復雜&…

百度移動生態事業群聚焦UGC戰略,貼吧迎新調整

易采游戲網3月8日獨家消息&#xff1a;近日據內部消息人士透露&#xff0c;百度移動生態事業群正積極將用戶生成內容&#xff08;UGC&#xff09;作為新的戰略重點。此舉標志著百度對UGC價值的重視與重塑&#xff0c;同時也預示著其旗下重要平臺——百度貼吧將迎來一輪重大的調…

C#模擬鼠標點擊,模擬鼠標雙擊,模擬鼠標恒定速度移動,可以看到軌跡

C#模擬鼠標點擊&#xff0c;模擬鼠標雙擊&#xff0c;模擬鼠標恒定速度移動&#xff0c;可以看到軌跡 using System; using System.Collections.Generic; using System.Linq; using System.Runtime.InteropServices; using System.Text; using System.Threading.Tasks;namespa…