首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

从其他组件访问react组件中的videojs播放器

从其他组件访问React组件中的video.js播放器可以通过以下步骤实现:

  1. 在React组件中引入video.js库和相关样式文件:
代码语言:txt
复制
import videojs from 'video.js';
import 'video.js/dist/video-js.css';
  1. 在React组件的生命周期方法中初始化和销毁video.js播放器:
代码语言:txt
复制
componentDidMount() {
  this.player = videojs(this.videoNode, this.props.options, function onPlayerReady() {
    console.log('Player is ready');
  });
}

componentWillUnmount() {
  if (this.player) {
    this.player.dispose();
  }
}
  1. 在React组件的render方法中创建video元素的引用:
代码语言:txt
复制
render() {
  return (
    <div>
      <div data-vjs-player>
        <video ref={node => (this.videoNode = node)} className="video-js" />
      </div>
    </div>
  );
}
  1. 在其他组件中通过ref访问React组件中的video.js播放器:
代码语言:txt
复制
class OtherComponent extends React.Component {
  handlePlay() {
    if (this.videoPlayer) {
      this.videoPlayer.play();
    }
  }

  render() {
    return (
      <div>
        <button onClick={this.handlePlay.bind(this)}>Play</button>
        <VideoPlayer ref={node => (this.videoPlayer = node)} />
      </div>
    );
  }
}

在上述代码中,通过ref属性将React组件中的video.js播放器实例赋值给其他组件的实例变量this.videoPlayer。然后,可以通过this.videoPlayer来调用video.js播放器的方法,例如play()来播放视频。

推荐的腾讯云相关产品:腾讯云点播(云点播是腾讯云提供的一站式音视频点播解决方案,支持存储、转码、加密、播放等功能)

产品介绍链接地址:https://cloud.tencent.com/product/vod

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

React dumb 组件和 smart 组件

原文:https://medium.com/@thejasonfile/dumb-components-and-smart-components-e7b33a698d43 当你开始起步学习 React,...很快就会接触到组件(Component)概念,正是这一概念让 React 脱颖而出。...这种组件本身只有一个 render() 方法(他们也用不到其他),并且总是表现为 Javascript 函数。不用维护内部 state,不用知道当收到请求时如何改变其展现数据 - 无知便是福。...容器组件需要管理自身繁复生命周期,并负责将数据作为 props,向下传递给展示型组件。 smart 组件是基于类,并在 constructor() 函数定义自身 state。...App extends Component { constructor(props){ super(props); this.state = {pictures : []}; } } 此类组件也经常包含其他回调函数

2.5K10

React高阶组件

React高阶组件 高阶组件HOC即Higher Order Component是React中用于复用组件逻辑一种高级技巧,HOC自身不是React API一部分,它是一种基于React组合特性而形成设计模式...描述 高阶组件名字上就透漏出高级气息,实际上这个概念应该是源自于JavaScript高阶函数,高阶函数就是接受函数作为输入或者输出函数,可以想到柯里化就是一种高阶函数,同样在React文档上也给出了高阶组件定义...注意 不要改变原始组件 不要试图在HOC修改组件原型,或以其他方式改变它。...修改传入组件HOC是一种糟糕抽象方式,调用者必须知道他们是如何实现,以避免与其他HOC发生冲突。HOC不应该修改传入组件,而应该使用组合方式,通过将组件包装在容器组件实现功能。...diff算法使用组件标识来确定它是应该更新现有子树还是将其丢弃并挂载新子树,如果render返回组件与前一个渲染组件相同===,则React通过将子树与新子树进行区分来递归更新子树,如果它们不相等

3.7K10

3、React组件this

React组件this是什么 通过编写一个简单组件,并渲染出来,分别打印出自定义函数和renderthis: import React from 'react'; const STR = '被调用...这段代码形象验证了,JavaScript函数this不是在函数声明时候,而是在函数运行时候定义; 同样,React组件也遵循JavaScript这种特性,所以组件方法‘调用者’不同会导致...1. render()以及componentDIdMount()、componentDIdUpdate()等其他生命周期函数this都是组件实例; 2. this.handler()调用者,为render...,可以自动绑定所用方法,使得其this指向组件实例化对象,但是其他JavaScript类并没有这种特性; 所以React团队决定不再React组件实现自动绑定,把上下文转换自由权交给开发者;...,即onClick={this.handler}打印出来组件实例; 总结: React组件生命周期函数this指向组件实例; 自定义组件方法this会因调用者不同而不同; 为了在组件自定义方法获取组件实例

2.9K10

React 受控组件和非受控组件

React 应用之所以需要受控组件和非受控组件,起因于、 和 这类特定 DOM 元素默认在 DOM 层维持状态(用户输入)。...受控组件用来在 React 也保存该状态,比如同步到渲染输入元素组件、树结构某个父组件,或者一个 flux store 。 而这种模式可以被扩展至特定非 DOM 状态相关用例。...比如,在最近一个应用,我需要创建一个可嵌套 Collapsible 折叠组件,支持两种操作模式:某些情况下需要使其被外界可控(当应用其他区域发生用户交互时扩展开),其他时候它能简单自己管理状态就可以了...React Inputs 对于 React Inputs,是这样工作: 要创建一个非受控 input,要设置一个 defaultValue 属性。...这种情况下 React 组件会使用底层 DOM 节点并借助节点组件本身 state 管理该 value。

2.7K20

组件分享之前端组件——用于 JSON Schema 构建 Web 表单 React 组件react-jsonschema-form

组件分享之前端组件——用于 JSON Schema 构建 Web 表单 React 组件react-jsonschema-form 背景 近期正在探索前端、后端、系统端各类常用组件与工具,对其一些常见组件进行再次整理一下...,形成标准化组件专题,后续该专题将包含各类语言中一些常用组件。...组件基本信息 组件react-jsonschema-form 开源协议: Apache-2.0 license 内容 本次分享组件是用于 JSON Schema 构建 Web 表单 React...组件react-jsonschema-form,它能够使用JSON Schema以声明方式构建和自定义 Web 表单。... 更多使用方式可以查看其官网提供各个组件详细使用说明

5.1K30

React基础(5)-React组件数据-props

[React学习(5)-React组件数据-props.png] 前言 开发一个React应用,更多是在编写组件,而React组件最小单位就是React元素,编写组件最大好处,就是实现代码复用...(property简写),props就是组件定义属性集合,它是组件对外接口,由外部通过JSX属性传入设置(也就是外部传递给内部组件数据) 一个React组件通过定义自己能够接收prop,就定义了自己对外提供公共接口...constructor构造器函数,调用super(),以及参数props,它是会报错组件实例被构造之后,该组件所有成员函数都无法通过this.props访问到父组件传递过来props值,错误如下所示...,虽然bind使用会创建一个新函数,但是它在constructor只会调用一次 而利用箭头函数,箭头函数没有this绑定,性能上讲,它是会重复调用,进行额外渲染,不如在构造器函数中进行this...(props),如果不进行该设置,该组件下定义成员私有方法(函数)将无法通过this.props访问到父组件传递过来prop值 当然,在React,规定了不能直接更改外部世界传过来prop值,这个

6.6K00

React基础(6)-React组件数据-state

React学习(6)-React组件数据-state.png 前言 组件state具体是什么?怎么更改state数据? setState函数分别接收对象以及函数有什么区别?...要知道 定义: setState方法是ReactReact.Component组件所提供一个内置方法,当你调用这个setState方法时候,React会更新组件状态state,并且重新调用render...其实它是会批量延迟更新 也就是props,state值并不会立马映射更新,它是把这个state对象放到一个更新队列里面,然后队列当中把新状态提出来合并到state,最后在触发render函数组件更新...传递一个函数可以让你在函数内访问到当前state值,因为setState调用是异步,this.state.以及this.props不会立即更新,它会被放置到一个队列延迟合并处理 只有当state...,可以通过setState函数修改state 结语 本文主要讲述了React组件数据属性-state,它是组件内部状态,是一私有的变量,用于记录组件内部状态,由于props不可修改,通过React

6K00

聊聊React权限组件设计

这又分为了两部分: 侧边栏菜单 路由权限 在很多人理解,前端权限控制就是左侧菜单可见与否,其实这是不对。...举一个例子,假设用户guest没有路由/setting访问权限,但是他知道/setting完整路径,直接通过输入路径方式访问,此时仍然是可以访问。这显然是不合理。...component代表路由对应组件: import React, { createElement } from "react" import Loadable from "react-loadable...直接在组件判断显然不太合适,我们把这部分逻辑抽离出来: /** * 通用权限检查方法 * Common check permissions method * @param { 菜单访问需要权限...这个是在页面初始化时接口读取,然后存到 store 有了这块逻辑,我们对刚刚AuthorizedRoute做一下改造。

2.7K11

React组件通信几种方式

context是一个全局变量,像是一个大容器,在任何地方都可以访问到,我们可以把要通信信息放在context上,然后在其他组件可以随意取到; 但是React官方不建议使用大量context,尽管他可以减少逐层传递...,但是当组件结构复杂时候,我们并不知道context是哪里传过来;而且context是一个全局变量,全局变量正是导致应用走向混乱罪魁祸首....使用context 下面例子组件关系: ListItem是List组件,List是app组件 ListItem.jsx import React, { Component } from 'react...没有嵌套关系组件通信 使用自定义事件机制 在componentDidMount事件,如果组件挂载完成,再订阅事件;在组件卸载时候,在componentWillUnmount事件取消事件订阅;...React组件间通信几种方式

2.3K30

React学习(五)-React组件数据-props

(property简写),props就是组件定义属性集合,它是组件对外接口,由外部通过JSX属性传入设置(也就是外部传递给内部组件数据) 一个React组件通过定义自己能够接收prop,就定义了自己对外提供公共接口...每个定义React组件应该都是独立存在模块,组件之外一切都是外部世界(组件),外部世界(组件)就是通过prop来和组件进行对话数据传递React,你可以将prop类似于HTML标签元素属性...在组件实例被构造之后,该组件所有成员函数都无法通过this.props访问到父组件传递过来props值,错误如下所示 ReferenceError: Must call super constructor...,虽然bind使用会创建一个新函数,但是它在constructor只会调用一次 而利用箭头函数,箭头函数没有this绑定,性能上讲,它是会重复调用,进行额外渲染,不如在构造器函数中进行this...(props),如果不进行该设置,该组件下定义成员私有方法(函数)将无法通过this.props访问到父组件传递过来prop值 当然,在React,规定了不能直接更改外部世界传过来prop值,这个

3.4K30

React学习(六)-React组件数据-state

如何划分组件状态数据,进行自我灵魂拷问,以及props与state灵魂对比 那么本节就是你想要知道 Reactstate 一个组件最终渲染数据结果,除了prop还有state,state代表是当前组件内部状态...,你可以把组件看成一个'状态机",它是能够随着时间变化数据,更多是应当在实现交互时使用,根据状态state改变呈现不同UI展示 在React,因为不能直接修改外部组件传入prop值 当需要记录组件自身数据变化时...其实它是会批量延迟更新 也就是props,state值并不会立马映射更新,它是把这个state对象放到一个更新队列里面,然后队列当中把新状态提出来合并到state,最后在触发render函数组件更新...传递一个函数可以让你在函数内访问到当前state值,因为setState调用是异步,this.state.以及this.props不会立即更新,它会被放置到一个队列延迟合并处理 只有当state...结语 本文主要讲述了React组件数据属性-state,它是组件内部状态,是一私有的变量,用于记录组件内部状态,由于props不可修改,通过React内置提供setState方法修改state

3.6K20

React组件间通信方式

React组件间通信方式 React组件间通信包括父子组件、兄弟组件、隔代组件、非嵌套组件之间通信。...实际上如果传入一个基本数据类型给子组件,在子组件修改这个值的话React中会抛出异常,如果对于子组件传入一个引用类型对象的话,在子组件修改是不会出现任何提示,但这两种情况都属于改变了父子组件单向数据流...我们通常会有需要更改父组件需求,对此我们可以在父组件自定义一个处理接受变化状态逻辑,然后在子组件如若相关状态改变时,就触发父组件逻辑处理事件,在Reactprops是能够接受任意入参,此时我们通过...,Refs提供了一种方式,允许我们访问DOM节点或在render方法创建React元素,在典型React数据流,props是父组件与子组件交互唯一方式,要修改一个子组件,你需要使用新props...,Redux中提出了单一数据源Store用来存储状态数据,所有的组件都可以通过Action修改Store,也可以Store获取最新状态,使用了redux就可以解决多个组件共享状态管理以及组件之间通信问题

2.4K30

React基础(8)-React组件生命周期

,做着不同事情 在React编写组件,每个组件在网页中都有被创建,更新,删除这么一过程,就像有机生命体一样 理解生命周期函数对于编写React组件代码是非常重要 如果你不清楚生命周期,以及生命周期应用场景...该函数返回值会作为参数传递给componentDidUpdate componentWillUnmount: 当组件对应 DOM 元素页面删除之前调用 组件更新(update): 当组件被重新渲染过程...(unmount): 组件DOM删除过程 componentWillUnmount: 组件页面销毁时,会触发该函数,当需要对数据进行清理时,例如定时器清理,放到该函数里面去做 三种不同过程,...一般使用constructor构造函数有如下两种情况 组件内部初始化state,因为生命周期内任何函数都可能要访问state,取它值,进行相应逻辑处理,它是该组件一个私有的对象变量 在对JSX元素上绑定事件监听处理函数时...,进行业务处理,发送网络请求 注意:在处理业务或发送网络请求时,一定要做好条件比较,否则容易造成死循环 组件卸载 React组件页面移除时,在卸载过程,只涉及一个生命周期函数componentWillUnmount

2.1K20

React学习(八)-React组件生命周期

,一个人生,老,病,死.在每个特殊年龄阶段,做着不同事情 在React编写组件,每个组件在网页中都有被创建,更新,删除这么一过程,就像有机生命体一样 理解生命周期函数对于编写React组件代码是非常重要...componentWillUnmount: 当组件对应 DOM 元素页面删除之前调用 组件更新(update): 当组件被重新渲染过程(state与props发生改变都会引起渲染) componentWillReceiveProps...: 组件页面销毁时,会触发该函数,当需要对数据进行清理时,例如定时器清理,放到该函数里面去做 三种不同过程,React库会依次调用组件一些成员函数(生命周期函数) 组件装载过程 当组件第一次被渲染时候...因为生命周期内任何函数都可能要访问state,取它值,进行相应逻辑处理,它是该组件一个私有的对象变量 在对JSX元素上绑定事件监听处理函数时,也就是组件内部成员函数(方法)this环境绑定,因为在...,进行业务处理,发送网络请求 注意:在处理业务或发送网络请求时,一定要做好条件比较,否则容易造成死循环 组件卸载 React组件页面移除时,在卸载过程,只涉及一个生命周期函数componentWillUnmount

1.6K20

React创建组件3种方式

return mycomponent } }) es6class类方式(有状态组件) 注意:无论使用哪种方式创建组件组件名称首字母都必须大小,因为我们写是...这里说明一个问题,很多时候同一种效果往往有很多种实现方式,所以我们在学习过程要避免章节化思维,要对技术进行横向比较,这样能帮你更 加深入理解各种方式优缺点。...1.函数式定义和类定义对比        函数式定义组件没有state和生命周期函数且不能访问this,而类定义这些都可以有。...mixins前世今生 3.如何选择哪种方式创建组件       由于React团队已经声明React.createClass最终会被React.Component类形式所取代。...但是在找到Mixins替代方案之前是不会废弃掉React.createClass形式。所以: 能用React.Component创建组件就尽量不用React.createClass形式创建组件

2K30

React传入组件props改变时更新组件几种实现方法

我们使用react时候常常需要在一个组件传入props更新时重新渲染该组件,常用方法是在componentWillReceiveProps中将新props更新到组件state(这种state...React 16.3还引入了一个新钩子函数getDerivedStateFromProps来专门实现这一需求。...受控数据指的是组件通过props传入数据,受到父组件影响;不受控数据指的是完全由组件自己管理状态,即内部状态(internal state)。...现在FullyControlledUserInput所有的数据都来源于父组件,由此解决数据冲突和被篡改问题。...在父组件调用子组件方法设置state 如果某些情况下没有合适属性作为key,那么可以传入一个随机数或者自增数字作为key,或者我们可以在组件定义一个设置state方法并通过ref暴露给父组件使用

4.9K30

React 高阶组件及其应用场景

,并返回一个继承了 React.Component 组件类,且在该类 render() 方法返回被传入 WrappedComponent 组件。...因为属性代理类型高阶组件返回是一个标准 React.Component 组件,所以在 React 标准组件可以做什么,那在属性代理类型高阶组件中就也可以做什么,比如: 操作 props 抽离...state 通过 ref 访问组件实例 用其他元素包裹传入组件 WrappedComponent 2....: 有条件地展示元素树(element tree) 操作由 render() 输出 React 元素树 在任何由 render() 输出 React 元素操作 props 用其他元素包裹传入组件...高阶组件 不是组件,是 一个把某个组件转换成另一个组件 函数 高阶组件主要作用是 代码复用 高阶组件是 装饰器模式在 React 实现

1.3K30
领券