vuetube v1.0.1
Key Features โจ
- Small ~2KBjs (minified and gzipped) and~1KBcss
- No dependencies
- Lazy load support
- Webp support, and fallback to jpgif the browser doesn't support it
- Render fast, improve your web's performance
- Built with a11y in mind
Installation โ๏ธ
npm
npm install vuetubeyarn
yarn add vuetubeInstall plugin
import Vue from 'vue'
import VueTube from 'vuetube';
import 'vuetube/vuetube.css'
Vue.use(VueTube)or
Install component
import Vue from 'vue'
import { VueTube } from 'vuetube';
import 'vuetube/vuetube.css'
Vue.component('VueTube', VueTube)Documentation ๐ค
Browse online documentation here
Props
Events
FAQ ๐ฏ๏ธ
How to get access to player API?
You need to pass enablejsapi: 1 to the playerVars props object. Then subscribe on player:ready event.
  <template>
    <vue-tube @player:ready="onPlayerReady"></vue-tube>
  </template>
  <script>
    export default {
      data() {
        return {
          playerInstance: null,
        }
      },
      
      methods: {
        onPlayerReady(event) {
          this.playerInstance = event.target
        }
      }
    }
  </script>Now you have a player instance in the playerInstance. You can do whatever you want with video. 
this.playerInstance.playVideo(), this.playerInstance.pauseVideo() etc. All methods can be found here.
How to use my play button?
You can pass your button through the icon slot.
  <template>
    <vue-tube>
      <template #icon>
        <svg
          xmlns="http://www.w3.org/2000/svg"
          width="48"
          height="48"
          viewBox="0 0 24 24"
          aria-hidden="true"
          focusable="false"
        >
          <path
            fill="#fff"
            d="M12 2c5.514 0 10 4.486 10 10s-4.486 10-10 10-10-4.486-10-10 4.486-10 10-10zm0-2c-6.627 0-12 5.373-12 12s5.373 12 12 12 12-5.373 12-12-5.373-12-12-12zm-3 17v-10l9 5.146-9 4.854z"
          />
        </svg>
      </template>
    </vue-tube>
  </template>How to use my thumbnail?
You can pass your thumbnail through the thumbnail slot.
  <template>
    <vue-tube>
      <template #thumbnail>
        <img src="#" alt="">
      </template>
    </vue-tube>
  </template>Browsers support ๐
| IE / Edge | Firefox | Chrome | Safari | iOS Safari | Samsung | Opera | Yandex | 
|---|---|---|---|---|---|---|---|
| IE11, Edge 80 | 60+ | 60+ | 10+ | 10+ | 12+ | 50+ | 14.4+ | 
License ๐
MIT
Inspiration ๐
Vuetube is a vue component version of the popular package lite-youtube-embed.
Support the project โญ
If you feel awesome and want to support me in a small way, please consider starring and sharing the repo!
Contributing ๐
Found a bug? Missing a specific feature? Your contributions are always welcome! Please have a look at the contribution guidelines first.