2013-11-04 16:03:51 -08:00
<!-- GENERATED FROM SOURCE -->
# vjs.CaptionsTrack
__EXTENDS__: [vjs.TextTrack ](vjs.TextTrack.md )
2014-12-04 13:29:40 -08:00
__DEFINED IN__: [src/js/tracks.js#L676 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L676 )
2013-11-04 16:03:51 -08:00
The track component for managing the hiding and showing of captions
---
## INDEX
- [METHODS ](#methods )
- [activate ](#activate ) _`inherited`_
- [activeCues ](#activecues ) _`inherited`_
- [addChild ](#addchild-child-options- ) _`inherited`_
- [addClass ](#addclass-classtoadd- ) _`inherited`_
- [buildCSSClass ](#buildcssclass ) _`inherited`_
- [children ](#children ) _`inherited`_
2014-12-04 13:29:40 -08:00
- [clearInterval ](#clearinterval-intervalid- ) _`inherited`_
- [clearTimeout ](#cleartimeout-timeoutid- ) _`inherited`_
2013-11-04 16:03:51 -08:00
- [contentEl ](#contentel ) _`inherited`_
- [createEl ](#createel ) _`inherited`_
- [cues ](#cues ) _`inherited`_
- [deactivate ](#deactivate ) _`inherited`_
- [dflt ](#dflt ) _`inherited`_
- [dimensions ](#dimensions-width-height- ) _`inherited`_
- [disable ](#disable ) _`inherited`_
- [dispose ](#dispose ) _`inherited`_
- [el ](#el ) _`inherited`_
2014-02-18 13:43:40 -08:00
- [enableTouchActivity ](#enabletouchactivity ) _`inherited`_
2013-11-04 16:03:51 -08:00
- [getChild ](#getchild-name- ) _`inherited`_
- [getChildById ](#getchildbyid-id- ) _`inherited`_
2014-09-30 18:51:46 -07:00
- [hasClass ](#hasclass-classtocheck- ) _`inherited`_
2013-11-04 16:03:51 -08:00
- [height ](#height-num-skiplisteners- ) _`inherited`_
- [hide ](#hide ) _`inherited`_
- [id ](#id ) _`inherited`_
- [init ](#init-player-options- ) _`inherited`_
- [initChildren ](#initchildren ) _`inherited`_
- [kind ](#kind ) _`inherited`_
- [label ](#label ) _`inherited`_
- [language ](#language ) _`inherited`_
- [mode ](#mode ) _`inherited`_
- [name ](#name ) _`inherited`_
2014-10-28 17:28:25 -07:00
- [off ](#off-first-second-third- ) _`inherited`_
- [on ](#on-first-second-third- ) _`inherited`_
- [one ](#one-first-second-third- ) _`inherited`_
2013-11-04 16:03:51 -08:00
- [options ](#options-obj- ) _`inherited`_
- [player ](#player ) _`inherited`_
- [ready ](#ready-fn- ) _`inherited`_
- [readyState ](#readystate ) _`inherited`_
- [removeChild ](#removechild-component- ) _`inherited`_
- [removeClass ](#removeclass-classtoremove- ) _`inherited`_
2014-12-04 13:29:40 -08:00
- [setInterval ](#setinterval-fn-interval- ) _`inherited`_
- [setTimeout ](#settimeout-fn-timeout- ) _`inherited`_
2013-11-04 16:03:51 -08:00
- [show ](#show ) _`inherited`_
- [src ](#src ) _`inherited`_
- [title ](#title ) _`inherited`_
2014-08-05 18:05:38 -07:00
- [trigger ](#trigger-event- ) _`inherited`_
2013-11-04 16:03:51 -08:00
- [triggerReady ](#triggerready ) _`inherited`_
- [width ](#width-num-skiplisteners- ) _`inherited`_
- [EVENTS ](#events )
- [resize ](#resize-event ) _`inherited`_
---
## METHODS
### activate()
> Turn on cue tracking. Tracks that are showing OR hidden are active.
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L375 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L375 )
2013-11-04 16:03:51 -08:00
---
### activeCues()
> Get the track active cues
##### RETURNS:
* `Array`
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L270 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L270 )
2013-11-04 16:03:51 -08:00
---
### addChild( child, [options] )
> Adds a child component inside this component
>
> myComponent.el();
> // -> <div class='my-component'></div>
> myComonent.children();
> // [empty array]
>
> var myButton = myComponent.addChild('MyButton');
> // -> <div class='my-component'><div class="my-button">myButton<div></div>
> // -> myButton === myComonent.children()[0];
>
> Pass in options for child constructors and options for children of the child
>
2013-11-05 17:12:20 -08:00
> var myButton = myComponent.addChild('MyButton', {
> text: 'Press Me',
> children: {
> buttonChildExample: {
> buttonChildOption: true
> }
> }
> });
2013-11-04 16:03:51 -08:00
##### PARAMETERS:
* __child__ `String|vjs.Component` The class name or instance of a child to add
* __options__ `Object` _(OPTIONAL)_ Options, including options to be passed to children of the child.
##### RETURNS:
* `vjs.Component` The child component (created by this process if a string was used)
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L362 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L362 )
2013-11-04 16:03:51 -08:00
---
### addClass( classToAdd )
> Add a CSS class name to the component's element
##### PARAMETERS:
* __classToAdd__ `String` Classname to add
##### RETURNS:
* `vjs.Component`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L826 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L826 )
2013-11-04 16:03:51 -08:00
---
### buildCSSClass()
> Allows sub components to stack CSS class names
##### RETURNS:
* `String` The constructed class name
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L536 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L536 )
2013-11-04 16:03:51 -08:00
---
### children()
> Get an array of all child components
>
> var kids = myComponent.children();
##### RETURNS:
* `Array` The children
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L296 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L296 )
2013-11-04 16:03:51 -08:00
---
2014-12-04 13:29:40 -08:00
### clearInterval( intervalId )
> Clears an interval and removes the associated dispose listener
##### PARAMETERS:
* __intervalId__ `Number` The id of the interval to clear
##### RETURNS:
* `Number` Returns the interval ID
_inherited from_: [src/js/component.js#L1219 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L1219 )
---
### clearTimeout( timeoutId )
> Clears a timeout and removes the associated dispose listener
##### PARAMETERS:
* __timeoutId__ `Number` The id of the timeout to clear
##### RETURNS:
* `Number` Returns the timeout ID
_inherited from_: [src/js/component.js#L1181 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L1181 )
---
2013-11-04 16:03:51 -08:00
### contentEl()
> Return the component's DOM element for embedding content.
> Will either be el_ or a new element defined in createEl.
##### RETURNS:
* `Element`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L239 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L239 )
2013-11-04 16:03:51 -08:00
---
### createEl()
> Create basic div to hold cue text
##### RETURNS:
* `Element`
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L315 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L315 )
2013-11-04 16:03:51 -08:00
---
### cues()
> Get the track cues
##### RETURNS:
* `Array`
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L255 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L255 )
2013-11-04 16:03:51 -08:00
---
### deactivate()
> Turn off cue tracking.
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L398 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L398 )
2013-11-04 16:03:51 -08:00
---
### dflt()
> Get the track default value. ('default' is a reserved keyword)
##### RETURNS:
* `Boolean`
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L196 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L196 )
2013-11-04 16:03:51 -08:00
---
### dimensions( width, height )
> Set both width and height at the same time
##### PARAMETERS:
* __width__ `Number|String`
* __height__ `Number|String`
##### RETURNS:
* `vjs.Component` The component
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L938 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L938 )
2013-11-04 16:03:51 -08:00
---
### disable()
> Disable: Mode Off/Disable (0)
> Indicates that the text track is not active. Other than for the purposes of exposing the track in the DOM, the user agent is ignoring the text track.
> No cues are active, no events are fired, and the user agent will not attempt to obtain the track's cues.
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L361 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L361 )
2013-11-04 16:03:51 -08:00
---
### dispose()
> Dispose of the component and all child components
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L84 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L84 )
2013-11-04 16:03:51 -08:00
---
### el()
> Get the component's DOM element
>
> var domEl = myComponent.el();
##### RETURNS:
* `Element`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L220 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L220 )
2014-02-18 13:43:40 -08:00
---
### enableTouchActivity()
> Report user touch activity when touch events occur
>
> User activity is used to determine when controls should show/hide. It's
> relatively simple when it comes to mouse events, because any mouse event
> should show the controls. So we capture mouse events that bubble up to the
> player and report activity when that happens.
>
> With touch events it isn't as easy. We can't rely on touch events at the
> player level, because a tap (touchstart + touchend) on the video itself on
> mobile devices is meant to turn controls off (and on). User activity is
> checked asynchronously, so what could happen is a tap event on the video
> turns the controls off, then the touchend event bubbles up to the player,
> which if it reported user activity, would turn the controls right back on.
> (We also don't want to completely block touch events from bubbling up)
>
> Also a touchmove, touch+hold, and anything other than a tap is not supposed
> to turn the controls back on on a mobile device.
>
> Here we're setting the default component behavior to report user activity
> whenever touch events happen, and this can be turned off by components that
> want touch events to act differently.
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L1120 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L1120 )
2013-11-04 16:03:51 -08:00
---
### getChild( name )
2013-11-05 17:12:20 -08:00
> Returns a child component with the provided name
2013-11-04 16:03:51 -08:00
##### PARAMETERS:
* __name__
##### RETURNS:
* `vjs.Component`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L330 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L330 )
2013-11-04 16:03:51 -08:00
---
### getChildById( id )
> Returns a child component with the provided ID
##### PARAMETERS:
* __id__
##### RETURNS:
* `vjs.Component`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L313 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L313 )
2013-11-04 16:03:51 -08:00
---
2014-09-30 18:51:46 -07:00
### hasClass( classToCheck )
> Check if a component's element has a CSS class name
##### PARAMETERS:
* __classToCheck__ `String` Classname to check
##### RETURNS:
* `vjs.Component`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L816 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L816 )
2014-09-30 18:51:46 -07:00
---
2013-11-04 16:03:51 -08:00
### height( [num], [skipListeners] )
> Get or set the height of the component (CSS values)
2013-11-05 17:12:20 -08:00
>
> Setting the video tag dimension values only works with values in pixels.
> Percent values will not work.
> Some percents can be used, but width()/height() will return the number + %,
> not the actual computed width/height.
2013-11-04 16:03:51 -08:00
##### PARAMETERS:
* __num__ `Number|String` _(OPTIONAL)_ New component height
* __skipListeners__ `Boolean` _(OPTIONAL)_ Skip the resize event trigger
##### RETURNS:
2013-11-05 17:12:20 -08:00
* `vjs.Component` This component, when setting the height
* `Number|String` The height, when getting
2013-11-04 16:03:51 -08:00
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L927 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L927 )
2013-11-04 16:03:51 -08:00
---
### hide()
> Hide: Mode Hidden (1)
> Indicates that the text track is active, but that the user agent is not actively displaying the cues.
> If no attempt has yet been made to obtain the track's cues, the user agent will perform such an attempt momentarily.
> The user agent is maintaining a list of which cues are active, and events are being fired accordingly.
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L346 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L346 )
2013-11-04 16:03:51 -08:00
---
### id()
> Get the component's ID
>
> var id = myComponent.id();
##### RETURNS:
* `String`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L258 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L258 )
2013-11-04 16:03:51 -08:00
---
### init( player, options )
##### PARAMETERS:
* __player__
* __options__
2014-05-20 10:42:01 -07:00
_inherited from_: [src/js/tracks.js#L134 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L134 )
2013-11-04 16:03:51 -08:00
---
### initChildren()
> Add and initialize default child components from options
>
> // when an instance of MyComponent is created, all children in options
> // will be added to the instance by their name strings and options
> MyComponent.prototype.options_.children = {
> myChildComponent: {
> myChildOption: true
> }
> }
2014-05-20 10:42:01 -07:00
>
> // Or when creating the component
> var myComp = new MyComponent(player, {
> children: {
> myChildComponent: {
> myChildOption: true
> }
> }
> });
>
> The children option can also be an Array of child names or
> child options objects (that also include a 'name' key).
>
> var myComp = new MyComponent(player, {
> children: [
> 'button',
> {
> name: 'button',
> someOtherOption: true
> }
> ]
> });
2013-11-04 16:03:51 -08:00
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L481 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L481 )
2013-11-04 16:03:51 -08:00
---
### kind()
> Get the track kind value
##### RETURNS:
* `String`
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L167 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L167 )
2013-11-04 16:03:51 -08:00
---
### label()
> Get the track label value
##### RETURNS:
* `String`
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L240 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L240 )
2013-11-04 16:03:51 -08:00
---
### language()
> Get the track language value
##### RETURNS:
* `String`
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L225 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L225 )
2013-11-04 16:03:51 -08:00
---
### mode()
> Get the track mode
##### RETURNS:
* `Number`
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L307 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L307 )
2013-11-04 16:03:51 -08:00
---
### name()
> Get the component's name. The name is often used to reference the component.
>
> var name = myComponent.name();
##### RETURNS:
* `String`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L277 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L277 )
2013-11-04 16:03:51 -08:00
---
2014-10-28 17:28:25 -07:00
### off( [first], [second], [third] )
> Remove an event listener from this component's element
2013-11-04 16:03:51 -08:00
>
2014-10-28 17:28:25 -07:00
> myComponent.off('eventType', myFunc);
>
> If myFunc is excluded, ALL listeners for the event type will be removed.
> If eventType is excluded, ALL listeners will be removed from the component.
>
> Alternatively you can use `off` to remove listeners that were added to other
> elements or components using `myComponent.on(otherComponent...`.
> In this case both the event type and listener function are REQUIRED.
>
> myComponent.off(otherElement, 'eventType', myFunc);
> myComponent.off(otherComponent, 'eventType', myFunc);
2013-11-04 16:03:51 -08:00
##### PARAMETERS:
2014-10-28 17:28:25 -07:00
* __first__ `String|vjs.Component` _(OPTIONAL)_ The event type or other component
* __second__ `Function|String` _(OPTIONAL)_ The listener function or event type
* __third__ `Function` _(OPTIONAL)_ The listener for other component
2013-11-04 16:03:51 -08:00
##### RETURNS:
* `vjs.Component`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L646 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L646 )
2013-11-04 16:03:51 -08:00
---
2014-10-28 17:28:25 -07:00
### on( first, second, third )
2013-11-04 16:03:51 -08:00
> Add an event listener to this component's element
>
> var myFunc = function(){
2014-10-28 17:28:25 -07:00
> var myComponent = this;
2013-11-04 16:03:51 -08:00
> // Do something when the event is fired
> };
>
2014-10-28 17:28:25 -07:00
> myComponent.on('eventType', myFunc);
>
> The context of myFunc will be myComponent unless previously bound.
>
> Alternatively, you can add a listener to another element or component.
2013-11-04 16:03:51 -08:00
>
2014-10-28 17:28:25 -07:00
> myComponent.on(otherElement, 'eventName', myFunc);
> myComponent.on(otherComponent, 'eventName', myFunc);
>
> The benefit of using this over `vjs.on(otherElement, 'eventName', myFunc)`
> and `otherComponent.on('eventName', myFunc)` is that this way the listeners
2014-12-04 13:29:40 -08:00
> will be automatically cleaned up when either component is disposed.
2014-10-28 17:28:25 -07:00
> It will also bind myComponent as the context of myFunc.
>
> **NOTE**: When using this on elements in the page other than window
> and document (both permanent), if you remove the element from the DOM
> you need to call `vjs.trigger(el, 'dispose')` on it to clean up
> references to it and allow the browser to garbage collect it.
2013-11-04 16:03:51 -08:00
##### PARAMETERS:
2014-10-28 17:28:25 -07:00
* __first__ `String|vjs.Component` The event type or other component
* __second__ `Function|String` The event handler or event type
* __third__ `Function` The event handler
2013-11-04 16:03:51 -08:00
##### RETURNS:
* `vjs.Component` self
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L577 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L577 )
2013-11-04 16:03:51 -08:00
---
2014-10-28 17:28:25 -07:00
### one( first, second, [third] )
2013-11-04 16:03:51 -08:00
> Add an event listener to be triggered only once and then removed
2014-10-28 17:28:25 -07:00
>
> myComponent.one('eventName', myFunc);
>
> Alternatively you can add a listener to another element or component
> that will be triggered only once.
>
> myComponent.one(otherElement, 'eventName', myFunc);
> myComponent.one(otherComponent, 'eventName', myFunc);
2013-11-04 16:03:51 -08:00
##### PARAMETERS:
2014-10-28 17:28:25 -07:00
* __first__ `String|vjs.Component` The event type or other component
* __second__ `Function|String` The listener function or event type
* __third__ `Function` _(OPTIONAL)_ The listener function for other component
2013-11-04 16:03:51 -08:00
##### RETURNS:
* `vjs.Component`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L691 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L691 )
2013-11-04 16:03:51 -08:00
---
### options( obj )
> Deep merge of options objects
>
> Whenever a property is an object on both options objects
> the two properties will be merged using vjs.obj.deepMerge.
>
> This is used for merging options for child components. We
> want it to be easy to override individual options on a child
> component without having to rewrite all the other default options.
>
> Parent.prototype.options_ = {
> children: {
> 'childOne': { 'foo': 'bar', 'asdf': 'fdsa' },
> 'childTwo': {},
> 'childThree': {}
> }
> }
> newOptions = {
> children: {
> 'childOne': { 'foo': 'baz', 'abc': '123' }
> 'childTwo': null,
> 'childFour': {}
> }
> }
>
> this.options(newOptions);
>
> RESULT
>
> {
> children: {
> 'childOne': { 'foo': 'baz', 'asdf': 'fdsa', 'abc': '123' },
> 'childTwo': null, // Disabled. Won't be initialized.
> 'childThree': {},
> 'childFour': {}
> }
> }
##### PARAMETERS:
2013-11-05 17:12:20 -08:00
* __obj__ `Object` Object of new option values
2013-11-04 16:03:51 -08:00
##### RETURNS:
2013-11-05 17:12:20 -08:00
* `Object` A NEW object of this.options_ and obj merged
2013-11-04 16:03:51 -08:00
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L179 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L179 )
2013-11-04 16:03:51 -08:00
---
### player()
> Return the component's player
##### RETURNS:
* `vjs.Player`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L126 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L126 )
2013-11-04 16:03:51 -08:00
---
### ready( fn )
> Bind a listener to the component's ready state
>
2014-12-04 13:29:40 -08:00
> Different from event listeners in that if the ready event has already happened
2013-11-04 16:03:51 -08:00
> it will trigger the function immediately.
##### PARAMETERS:
* __fn__ `Function` Ready listener
##### RETURNS:
* `vjs.Component`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L769 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L769 )
2013-11-04 16:03:51 -08:00
---
### readyState()
> Get the track readyState
##### RETURNS:
* `Number`
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L289 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L289 )
2013-11-04 16:03:51 -08:00
---
### removeChild( component )
> Remove a child component from this component's list of children, and the
> child component's element from this component's element
##### PARAMETERS:
* __component__ `vjs.Component` Component to remove
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L420 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L420 )
2013-11-04 16:03:51 -08:00
---
### removeClass( classToRemove )
> Remove a CSS class name from the component's element
##### PARAMETERS:
* __classToRemove__ `String` Classname to remove
##### RETURNS:
* `vjs.Component`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L837 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L837 )
2013-11-04 16:03:51 -08:00
---
2014-12-04 13:29:40 -08:00
### setInterval( fn, interval )
> Creates an interval and sets up disposal automatically.
##### PARAMETERS:
* __fn__ `Function` The function to run every N seconds.
* __interval__ `Number` Number of ms to delay before executing specified function.
##### RETURNS:
* `Number` Returns the interval ID
_inherited from_: [src/js/component.js#L1198 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L1198 )
---
### setTimeout( fn, timeout )
> Creates timeout and sets up disposal automatically.
##### PARAMETERS:
* __fn__ `Function` The function to run after the timeout.
* __timeout__ `Number` Number of ms to delay before executing specified function.
##### RETURNS:
* `Number` Returns the timeout ID
_inherited from_: [src/js/component.js#L1158 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L1158 )
---
2013-11-04 16:03:51 -08:00
### show()
> Show: Mode Showing (2)
> Indicates that the text track is active. If no attempt has yet been made to obtain the track's cues, the user agent will perform such an attempt momentarily.
> The user agent is maintaining a list of which cues are active, and events are being fired accordingly.
> In addition, for text tracks whose kind is subtitles or captions, the cues are being displayed over the video as appropriate;
> for text tracks whose kind is descriptions, the user agent is making the cues available to the user in a non-visual fashion;
> and for text tracks whose kind is chapters, the user agent is making available to the user a mechanism by which the user can navigate to any point in the media resource by selecting a cue.
> The showing by default state is used in conjunction with the default attribute on track elements to indicate that the text track was enabled due to that attribute.
> This allows the user agent to override the state if a later track is discovered that is more appropriate per the user's preferences.
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L331 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L331 )
2013-11-04 16:03:51 -08:00
---
### src()
> Get the track src value
##### RETURNS:
* `String`
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L181 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L181 )
2013-11-04 16:03:51 -08:00
---
### title()
> Get the track title value
##### RETURNS:
* `String`
2014-12-04 13:29:40 -08:00
_inherited from_: [src/js/tracks.js#L210 ](https://github.com/videojs/video.js/blob/master/src/js/tracks.js#L210 )
2013-11-04 16:03:51 -08:00
---
2014-08-05 18:05:38 -07:00
### trigger( event )
2013-11-04 16:03:51 -08:00
> Trigger an event on an element
>
> myComponent.trigger('eventName');
2014-08-05 18:05:38 -07:00
> myComponent.trigger({'type':'eventName'});
2013-11-04 16:03:51 -08:00
##### PARAMETERS:
2014-08-05 18:05:38 -07:00
* __event__ `Event|Object|String` A string (the type) or an event object with a type attribute
2013-11-04 16:03:51 -08:00
##### RETURNS:
* `vjs.Component` self
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L724 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L724 )
2013-11-04 16:03:51 -08:00
---
### triggerReady()
> Trigger the ready listeners
##### RETURNS:
* `vjs.Component`
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L788 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L788 )
2013-11-04 16:03:51 -08:00
---
### width( [num], skipListeners )
> Set or get the width of the component (CSS values)
>
2013-11-05 17:12:20 -08:00
> Setting the video tag dimension values only works with values in pixels.
> Percent values will not work.
> Some percents can be used, but width()/height() will return the number + %,
> not the actual computed width/height.
2013-11-04 16:03:51 -08:00
##### PARAMETERS:
* __num__ `Number|String` _(OPTIONAL)_ Optional width number
* __skipListeners__ `Boolean` Skip the 'resize' event trigger
##### RETURNS:
2013-11-05 17:12:20 -08:00
* `vjs.Component` This component, when setting the width
* `Number|String` The width, when getting
2013-11-04 16:03:51 -08:00
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L910 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L910 )
2013-11-04 16:03:51 -08:00
---
## EVENTS
### resize `EVENT`
> Fired when the width and/or height of the component changes
2014-10-28 17:28:25 -07:00
_inherited from_: [src/js/component.js#L1020 ](https://github.com/videojs/video.js/blob/master/src/js/component.js#L1020 )
2013-11-04 16:03:51 -08:00
---