91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue3怎么使用Facebook嵌入式視頻播放器API

發布時間:2023-03-07 16:25:50 來源:億速云 閱讀:168 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“vue3怎么使用Facebook嵌入式視頻播放器API”,內容詳細,步驟清晰,細節處理妥當,希望這篇“vue3怎么使用Facebook嵌入式視頻播放器API”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

正文

Facebook 嵌入式視頻播放器 API是 JavaScript 版 Facebook SDK 提供的客戶端功能。可以在自己網站上播放Facebook視頻。

開始使用

先引入 Facebook SDK

<script async defer src="https://connect.facebook.net/en_US/sdk.js"></script>

封裝成組件FacebookPlayer

<script setup>
import { onMounted, onBeforeUnmount } from "vue";
const props = defineProps({
  id: { type: String, default: "" },
  src: { type: String, required: true },
  autoplay: { type: Boolean, default: false }
});
const emit = defineEmits(["onEnded", "onPlay", "onPause"]);
onMounted(() => {
  fbAsyncInit();
  loadPlayer();
});
onBeforeUnmount(() => {
  removePlay();
  removePaused();
  removeEnded();
  player = null;
});
// Load Facebook SDK for JavaScript
const fbAsyncInit = () => {
  try {
    window.FB.init({ autoLogAppEvents: true, xfbml: true, version: "v3.2" });
  } catch (error) {
    console.error("FB.init Error", error);
  }
};
// Get Embedded Video Player API Instance
let player = null;
const loadPlayer = () => {
  try {
    window.FB.Event.subscribe("xfbml.ready", (msg) => {
      if (msg.type === "video" && msg.id === `fb-${props.id}`) {
        if (!player) player = msg.instance;
        onPlay(msg.instance);
        onPaused(msg.instance);
        onEnded(msg.instance);
      }
    });
  } catch (error) {
    console.error("FB.Event Error", error);
  }
};
// 播放器方法
const play = () => player && player.play();
const pause = () => player && player.pause();
// 播放器事件
let playListener;
const onPlay = (instance) => {
  playListener = instance.subscribe("startedPlaying", () => emit("onPlay"));
};
const removePlay = () => {
  try {
    if (playListener) playListener.release("startedPlaying");
  } catch (error) {}
};
let pausedListener;
const onPaused = (instance) => {
  pausedListener = instance.subscribe("paused", () => emit("onPause"));
};
const removePaused = () => {
  try {
    if (pausedListener) pausedListener.release("paused");
  } catch (error) {}
};
let endedListener;
const onEnded = (instance) => {
  endedListener = instance.subscribe("finishedPlaying", () => emit("onEnded"));
};
const removeEnded = () => {
  try {
    if (endedListener) endedListener.release("finishedPlaying");
  } catch (error) {}
};
</script>
<template>
  <div
    :id="'fb-' + id"
    class="fb-video"
    :data-href="props.src" rel="external nofollow" 
    :data-autoplay="props.autoplay"
    :data-allowfullscreen="false"
  ></div>
</template>

使用方式

<facebook-player id="10153231379946729" src="https://www.facebook.com/facebook/videos/10153231379946729/"></facebook-player>

注意事項

class="fb-video" 該類名不能去掉。

如果在一個頁面上使用了多個播放器,一定要傳唯一id,以此識別播放器。

屬性

設置描述默認值
data-href視頻的絕對網址。n/a
data-allowfullscreen允許視頻在全屏模式下播放。可以是 false 或 true。false
data-autoplay頁面加載時自動開始播放視頻。視頻將無聲(靜音)播放。用戶可以通過視頻播放器控制選項打開聲音。此設置不適用于移動設備。可以是 false 或 true。false
data-lazytrue 表示您可通過設置 loading="lazy" iframe 屬性來使用瀏覽器的延遲加載機制。其效果是,如果插件不在視區附近,則瀏覽器不會顯示插件,且您可能始終無法看到該插件。可以是 true 或 false(默認)的其中一個。false
data-width視頻容器的寬度。最小值為 220px。auto
data-show-text如果與視頻關聯的 Facebook 帖子中有任何文本,則設置為 true 以添加該文本。僅適用于桌面端網站。false
data-show-captions設置為 true 即可默認顯示字幕(如適用)。字幕僅適用于桌面設備。false

方法

函數說明參數(類型)
play()播放視頻。
pause()暫停視頻。
seek(seconds)尋找指定位置。seconds (number)
mute()視頻設為靜音。
unmute()取消視頻靜音。
isMuted()視頻設為靜音時為 true,反之則為 false。
setVolume(volume)將音量設置為指定數字(float,范圍從 0 到 1)。volume (float)
getVolume()返回視頻的當前音量(float,范圍從 0 到 1)。
getCurrentPosition()返回當前的視頻時間位置,精確到秒。
getDuration()返回視頻時長,精確到秒。
subscribe(event, eventCallback)為指定事件添加偵聽函數。關于事件的詳細信息,請參閱事件部分。返回一個口令,其中包含 release 方法,調用此方法會再次從事件中移除偵聽程序。event (string)、eventCallback (function)

事件

事件描述
startedPlaying視頻開始播放時觸發。
paused視頻暫停時觸發。
finishedPlaying視頻播放完時觸發。
startedBuffering視頻開始緩沖時觸發。
finishedBuffering視頻從緩沖恢復時觸發。
error視頻發生錯誤時觸發。

讀到這里,這篇“vue3怎么使用Facebook嵌入式視頻播放器API”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永清县| 朝阳区| 依兰县| 尚志市| 博罗县| 阿克苏市| 淮南市| 永城市| 桦南县| 壶关县| 加查县| 古蔺县| 桂平市| 英超| 许昌县| 壶关县| 周口市| 扎赉特旗| 精河县| 河间市| 莱西市| 靖西县| 班玛县| 贡嘎县| 汉寿县| 昌乐县| 潮州市| 襄城县| 阿合奇县| 南康市| 云龙县| 大理市| 临澧县| 衡阳市| 梁山县| 蒙阴县| 巴林右旗| 伊宁县| 泽普县| 琼海市| 温州市|