1
0
mirror of https://github.com/videojs/video.js.git synced 2025-01-08 07:00:10 +02:00
video.js/docs/legacy-docs/guides/removing-players.html
Gary Katsevman 4dd000c809
docs: deploy docs using netlify (#4774)
This adds in the legacy docs into the repo and enables automatic deployment via netlify. The netlify-docs.js script will error out the build on netlify on master if we're not on a tagged commit so that it won't redeploy the docs unless there's a new release. If we're not on master or on master with a tagged commit, it will process with the deploy.
Also, this removes the API docs from being published with npm, fixes #4609.
2017-12-04 17:42:07 -05:00

42 lines
2.9 KiB
HTML

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<link rel="stylesheet" type="text/css" href="../css/guides.css">
<link href='https://fonts.googleapis.com/css?family=Open+Sans:400,700,700italic,600,600italic' rel='stylesheet' type='text/css'><link rel="stylesheet" type="text/css" href="//cdnjs.cloudflare.com/ajax/libs/highlight.js/8.8.0/styles/solarized_light.min.css" />
<script type="text/javascript" src="//use.edgefonts.net/source-code-pro.js"></script>
</head>
<body>
<div id="sidenav" class="sidenav"></div>
<div id="main" class="main">
<h1 id="removing-players">Removing Players</h1>
<p>Sometimes, you want to remove players after page load (in single page apps or modals, for instance). It&#39;s easy to manage, but there are some simple rules you need to follow.</p>
<h2 id="call-dispose-">Call <code>.dispose()</code></h2>
<p>To remove the html associated with your videojs player from the page always call the player&#39;s <a href="http://docs.videojs.com/docs/api/player.html#Methodsdispose"><code>dispose()</code></a> method:</p>
<pre><code class="lang-js">var oldPlayer = document.getElementById(&#39;my-player&#39;);
videojs(oldPlayer).dispose();
</code></pre>
<p>This method will:</p>
<ol>
<li>reset the internal state of videojs</li>
<li>remove the player&#39;s dom from the page</li>
</ol>
<h2 id="showing-hiding-a-player">Showing / Hiding a Player</h2>
<p>For instance, if you have a modal that a player appears in, you should create the player when the modal pops up. When the modal hides, dispose the player. If you try to hide the Flash tech, things will go poorly. Even with other tech, calling <code>dispose()</code> on a player that&#39;s not needed will free up resources for the browser.</p>
<h2 id="why-is-this-needed-">Why Is This Needed?</h2>
<p>VideoJS internally tracks all players and their associated data by html id attribute. If you plan to create new players with the same id as previously created players, you&#39;ll need to call the player&#39;s dispose() method to clear VideoJS&#39;s internal state before creating the new player.</p>
<h2 id="signs-you-did-it-wrong">Signs You Did It Wrong</h2>
<pre><code>TypeError: this.el_.vjs_getProperty is not a function
&quot;VIDEOJS:&quot; &quot;Video.js: buffered unavailable on Hls playback technology element.&quot; TypeError: this.el_.vjs_getProperty is not a function
Stack trace:
...
</code></pre><p>If you encounter a console error in the browser similar to the above, you&#39;ve probably forgotten to <code>dispose()</code> a player before removing it from the dom. This would happen when using the <a href="https://github.com/videojs/videojs-contrib-hls">contrib-hls</a> plugin.</p>
<script src="//cdnjs.cloudflare.com/ajax/libs/highlight.js/8.8.0/highlight.min.js"></script>
<script src="../js/guides.js"></script>
<script>hljs.initHighlightingOnLoad();</script>
</body>
</html>