2021.12.14 每天进步一点点: 关于静态资源如video在react中的使用和区别

本文主要是介绍2021.12.14 每天进步一点点: 关于静态资源如video在react中的使用和区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于静态资源如video在react中的使用

      • 导读
      • 静态资源的放置
      • 各自的分工和好处
        • /public
        • /src
      • 静态资源的引入和使用
      • require和import在引入时的区别
      • 在react中使用video
      • 参考文档


导读

刚仿照b站,写了一个banner位置的背景播放video 。

就是这个banner位置的背景,

在这里插入图片描述

虽然是非常简单的一个东西, 却引出了很多的知识点。

经过深扒,确实应该好好了解一下。

比如说,

1. react中,public和src都可以放置静态资源,

为什么最新版本的react却提醒我把资源放置在src中?

2.放在public和src中,两者有何区别?

3.既然react提醒资源放置在src中,有什么优势或好处?

4.react的静态资源使用方法有很多,

哪种方法比较好?为什么?

5.h5的资源标签在react中直接使用,如video

会遇到哪些问题?

6.有什么更好的解决办法吗?

本篇文章就是来解决这些问题的。


静态资源的放置

众所周知,

在react中,静态资源,如图片, 视频, 样式等,

既可以放在/public文件夹中,又可以放在/src文件夹中。

而且,react建议放在/src中。

究其原因,在于是否会被webpack编译打包的区别

放在/public下的资源,不会被webpack编译打包。而是直接复制一份,放入打包后的文件夹。

放在/src下的资源,会被webpack编译打包。

比如图片、视频等静态资源, 会被webpack编译,

当资源小于限制值时,会被编译位base64字符串,减少资源请求量,提升性能。


各自的分工和好处

/public

既然放在/public不会被编译打包,

那么,有些不会变动的资源, 就可以放在这里了。

比如jquery.min.js这种压缩好的包。

/src

把静态资源放在这里,还有其他的好处,

  1. 脚本和样式表被缩小并捆绑在一起以避免额外的网络请求
  2. 缺少文件会导致编译错误,而不是用户的404错误。换句话说, 就是让错误在上线前就处理掉,而不是等着用户去发现错误。
  3. 结果文件名包含内容哈希,因此您无需担心浏览器缓存旧版本。 静态资源文件一般会加上哈希值处理,以避免缓存带来的显示问题。

静态资源的引入和使用

在react中,使用图片或视频等静态资源,

不像三剑客那样直接引入使用,

比如有一张命名为demo.png的图片,

原生中引入方法是:

<img src="./demo.png" alt="" />

但是,这在react中是行不通的。

因为不管是相对路径,还是绝对路径,

其实都有默认的前缀的。

这个默认前缀,是和请求接口有关,

所以这样使用会导致报错,无法使用资源。

react有自己的引入和使用方式,

可分为如下两种:

1.通过require引入

<img src={require("./demo.png")} alt="" />

2.通过import引入变量,并在jsx中使用变量

import demoImg from './demo.png';<img src={demoImg} alt="" />

require和import在引入时的区别

以上两种引入和使用方法,在jsx中,都是有效的。

但是二者有很大的区别。

1. require方法,在js中引入时,webpack会把src中的引入路径当作字符串处理,

并不会当作资源去编译打包。 所以,当项目上线时,很可能出现在线上可以看到图片路径,但并不显示图片的问题。

2. import 方法,webpack会把当前引入的图片当作静态资源打包,我们可以在webpack配置文件里,对文件进行某些处理,比如设置图片加载器, 当文件小于某个值时,会被打包成base64字符串,减少请求量。

所以,我们推荐用import 引入方法


在react中使用video

这是刚刚遇到的问题。

比如autoplay属性失效。

而在react中,应该写作autoPlay

还有muted设置静音失效的问题。等等。

如果加了aotoPlay之后,还是不能自动播放,

可能还需要加上muted 。

因为新版浏览器已经默认静音视频自动播放了。

这里推荐一个react插件:

video-react

可设置的属性较多,

还有很多可加载的事件。


参考文档

  • html5标签: https://www.w3school.com.cn/tags/tag_video.asp
  • 静态资源文件夹区别:https://blog.csdn.net/weixin_39782183/article/details/104751862
  • 两种引入的问题:https://www.cnblogs.com/tu-0718/p/12530654.html
  • 插件方法:https://blog.csdn.net/xue_sunshine_girl1/article/details/83505758

这篇关于2021.12.14 每天进步一点点: 关于静态资源如video在react中的使用和区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/942276

相关文章

Mysql中RelayLog中继日志的使用

《Mysql中RelayLog中继日志的使用》MySQLRelayLog中继日志是主从复制架构中的核心组件,负责将从主库获取的Binlog事件暂存并应用到从库,本文就来详细的介绍一下RelayLog中... 目录一、什么是 Relay Log(中继日志)二、Relay Log 的工作流程三、Relay Lo

使用Redis实现会话管理的示例代码

《使用Redis实现会话管理的示例代码》文章介绍了如何使用Redis实现会话管理,包括会话的创建、读取、更新和删除操作,通过设置会话超时时间并重置,可以确保会话在用户持续活动期间不会过期,此外,展示了... 目录1. 会话管理的基本概念2. 使用Redis实现会话管理2.1 引入依赖2.2 会话管理基本操作

Springboot请求和响应相关注解及使用场景分析

《Springboot请求和响应相关注解及使用场景分析》本文介绍了SpringBoot中用于处理HTTP请求和构建HTTP响应的常用注解,包括@RequestMapping、@RequestParam... 目录1. 请求处理注解@RequestMapping@GetMapping, @PostMappin

springboot3.x使用@NacosValue无法获取配置信息的解决过程

《springboot3.x使用@NacosValue无法获取配置信息的解决过程》在SpringBoot3.x中升级Nacos依赖后,使用@NacosValue无法动态获取配置,通过引入SpringC... 目录一、python问题描述二、解决方案总结一、问题描述springboot从2android.x

Mybatis的mapper文件中#和$的区别示例解析

《Mybatis的mapper文件中#和$的区别示例解析》MyBatis的mapper文件中,#{}和${}是两种参数占位符,核心差异在于参数解析方式、SQL注入风险、适用场景,以下从底层原理、使用场... 目录MyBATis 中 mapper 文件里 #{} 与 ${} 的核心区别一、核心区别对比表二、底

SpringBoot整合AOP及使用案例实战

《SpringBoot整合AOP及使用案例实战》本文详细介绍了SpringAOP中的切入点表达式,重点讲解了execution表达式的语法和用法,通过案例实战,展示了AOP的基本使用、结合自定义注解以... 目录一、 引入依赖二、切入点表达式详解三、案例实战1. AOP基本使用2. AOP结合自定义注解3.

Python中Request的安装以及简单的使用方法图文教程

《Python中Request的安装以及简单的使用方法图文教程》python里的request库经常被用于进行网络爬虫,想要学习网络爬虫的同学必须得安装request这个第三方库,:本文主要介绍P... 目录1.Requests 安装cmd 窗口安装为pycharm安装在pycharm设置中为项目安装req

使用Python将PDF表格自动提取并写入Word文档表格

《使用Python将PDF表格自动提取并写入Word文档表格》在实际办公与数据处理场景中,PDF文件里的表格往往无法直接复制到Word中,本文将介绍如何使用Python从PDF文件中提取表格数据,并将... 目录引言1. 加载 PDF 文件并准备 Word 文档2. 提取 PDF 表格并创建 Word 表格

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

Python使用Matplotlib和Seaborn绘制常用图表的技巧

《Python使用Matplotlib和Seaborn绘制常用图表的技巧》Python作为数据科学领域的明星语言,拥有强大且丰富的可视化库,其中最著名的莫过于Matplotlib和Seaborn,本篇... 目录1. 引言:数据可视化的力量2. 前置知识与环境准备2.1. 必备知识2.2. 安装所需库2.3