詳解vue3中如何使用youtube-player
正文
youtube-player 是 YouTube IFrame Player API (YIPA) 的封裝。可以在自己網(wǎng)站上播放YouTube視頻。
開始使用
使用 npm 下載
npm i youtube-player
做成組件youtubePlayer
<script setup>
import { ref, watch, onMounted, onBeforeUnmount } from "vue";
import YouTubePlayer from "youtube-player";
const props = defineProps({
id: { type: String, default: "" },
src: { type: String, required: true },
width: { type: Number, default: 0 },
height: { type: Number, default: 0 }
});
const emit = defineEmits(["ended", "play", "pause"]);
onMounted(() => {
initPlayer();
loadPlayer();
});
onBeforeUnmount(() => {
player && player.destroy();
});
const getVideoId = () => {
try {
const url = new URL(props.src);
return url.searchParams.get("v") || "";
} catch (error) {
return "";
}
};
let player = null;
const initPlayer = () => {
try {
player = YouTubePlayer(`youtube-${props.id}`, {
host: "https://www.youtube.com",
width: props.width,
height: props.height,
videoId: getVideoId(),
playsinline: 1,
rel: 0
});
} catch (error) {
console.log(error);
}
};
const loadPlayer = () => {
try {
player.loadVideoById(getVideoId());
} catch (error) {
console.log(error);
}
};
const play = () => player && player.playVideo();
const pause = () => player && player.pauseVideo();
// -1(未開始)0(已結(jié)束)1(正在播放)2(已暫停)3(正在緩沖)5(視頻已插入)
let stateChangeListener;
const addStateChange = () => {
stateChangeListener = player?.on("stateChange", (event) => {
if (event.data === 0) emit("ended");
if (event.data === 1) emit("play");
if (event.data === 2) emit("pause");
});
};
const removeStateChange = () => {
if (stateChangeListener) player?.off(stateChangeListener);
};
watch(
() => props.src,
() => loadPlayer()
);
defineExpose({ play, pause });
</script>
<template>
<div class="youtube-video">
<div :id="'youtube-' + id"></div>
</div>
</template>
<style lang="scss" scoped>
.youtube-video {
width: 100%;
overflow: hidden;
}
</style>
使用方式
<youtube-player src="https://www.youtube.com/watch?v=uRzs2kS3Blg"></youtube-player>
注意事項
播放器有默認寬高,只能是px,需要做響應(yīng)式的要自己動態(tài)獲取寬高在重新設(shè)置。
常用參數(shù)
| 參數(shù) | |
|---|---|
| autoplay | 是否在播放器加載時自動開始播放初始視頻。支持的值為 0 或 1。默認值為 0。 |
| controls | 視頻播放器控件是否會顯示。支持的值為 0 或 1。默認值為 1。 |
| fs | 視頻播放器全屏按鈕是否會顯示。支持的值為 0 或 1。默認值為 1。 |
| loop | 視頻是否會循環(huán)播放。支持的值為 0 或 1。默認值為 0。 |
| playsinline | 此參數(shù)用于控制視頻在 iOS 設(shè)備上的 HTML5 播放器中播放時,是以內(nèi)嵌方式還是全屏模式播放。支持的值為 0 或 1。默認值為 0 全屏。 |
常用API
player.playVideo() 播放當(dāng)前已插入/已加載的視頻。
player.pauseVideo() 暫停當(dāng)前正在播放的視頻。
player.stopVideo() 停止和取消加載當(dāng)前視頻。
player.mute() 使播放器靜音。
player.unMute() 取消播放器靜音。
player.setSize(width:Number, height:Number) 設(shè)置包含播放器的<iframe>的大小。
player.destroy() 移除包含播放器的 <iframe>。
以上就是詳解vue3中如何使用youtube-player的詳細內(nèi)容,更多關(guān)于vue3使用youtube-player的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
解析vue?3.0?使用axios庫發(fā)起?post?get?的配置過程
get post 請求開發(fā)中最普通最常見的請求方式但是在vue中如何實現(xiàn)呢 這里記錄一下配置過程,對vue?使用axios發(fā)起?post?get配置過程感興趣的朋友一起看看吧2022-05-05
基于Vue中點擊組件外關(guān)閉組件的實現(xiàn)方法
下面小編就為大家分享一篇基于Vue中點擊組件外關(guān)閉組件的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03
Vue3使用ref與reactive創(chuàng)建響應(yīng)式對象的示例代碼
這篇文章主要詳細介紹了Vue3使用ref與reactive創(chuàng)建響應(yīng)式對象的方法步驟,文中通過代碼示例和圖文結(jié)合的方式給大家介紹的非常詳細,具有一定的參考價值,需要的朋友可以參考下2024-02-02
監(jiān)聽element-ui table滾動事件的方法
這篇文章主要介紹了監(jiān)聽element-ui table滾動事件的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
vue 自動檢測手機端響應(yīng)式布局的五種實現(xiàn)
本文主要介紹了vue自動檢測手機端響應(yīng)式布局,可以通過結(jié)合 CSS 媒體查詢、Vue 的動態(tài)數(shù)據(jù)綁定、適當(dāng)?shù)牡谌綆?、PostCSS 插件以及正確的視口設(shè)置實現(xiàn),感興趣的可以了解一下2024-07-07

