谷歌浏览器看react(谷歌浏览器看视频怎么倍速)

大家好,今天来为大家分享谷歌浏览器看react的一些知识点,和谷歌浏览器看视频怎么倍速的问题解析,大家要是都明白,那么可以忽略,如果不太清楚的话可以看看本篇文章,相信很大概率可以解决您的问题,接下来我们就一起来看看吧!

谷歌浏览器看react(谷歌浏览器看视频怎么倍速)

本文目录

  1. 2021年的前端框架选择 Angular vs React vs Vue
  2. React如何实现浏览器打印部分内容详析
  3. 打开chrome浏览器开发者工具的方式

一、2021年的前端框架选择 Angular vs React vs Vue

每个前端开发人员都听说过三个用于构建 Web应用程序的框架:React、Vue.js和Angular。

React是一个 UI库,Angular是一个成熟的前端框架,而 Vue.js是一个渐进式框架。

它们几乎可以互换使用来构建前端应用程序,但它们并非 100%相同,因此比较它们并了解它们的差异是有意义的。

每个框架都是基于组件的,并允许快速创建 UI功能。

然而,它们都有不同的结构和架构——所以首先,我们将研究它们的架构差异以了解它们背后的哲学。

React不强制执行特定的项目结构,正如您从下面的官方“Hello World”示例中看到的那样,您只需几行代码即可开始使用 React。

React可以用作 UI库来渲染元素,而无需强制执行特定的项目结构,这就是它不是严格意义上的框架的原因。

React Elements是 React应用程序的最小构建块。它们比 DOM元素更强大,因为 React DOM确保在发生变化时有效地更新它们。

组件是更大的构建块,定义了在整个应用程序中使用的独立且可重用的部分。它们接受称为 props的输入并生成元素,然后显示给用户。

React基于 JavaScript,但它主要与JSX(JavaScript XML)结合,这是一种语法扩展,允许您创建同时包含 HTML和 JavaScript的元素。

您使用 JSX创建的任何内容也可以使用 React JavaScript API创建,但大多数开发人员更喜欢 JSX,因为它更直观。

Vue.js核心库只关注视图层。之所以称为渐进式框架,是因为您可以使用官方和第三方包(例如Vue Router或Vuex)扩展其功能,将其转变为实际框架。

虽然 Vue与 MVVM(Model-View-ViewModel)模式没有严格关联,但它的设计部分受到了它的启发。使用 Vue,您将主要在 ViewModel层上工作,以确保以允许框架呈现最新视图的方式处理应用程序数据。

Vue的模板语法让您可以创建 View组件,并将熟悉的 HTML与特殊指令和功能相结合。这种模板语法是首选,即使原始 JavaScript和 JSX也受支持。

Vue中的组件很小,是自包含的,并且可以在整个应用程序中重复使用。带有扩展名的单文件组件(SFC).vue包含 HTML、CSS和 JavaScript,因此所有相关代码都位于一个文件中。

SFC是在 Vue.js项目中组织代码的推荐方式,尤其是大型项目。需要使用 Webpack或 Browserify等工具将 SFC转换为可用的 JavaScript代码。

在本文中,我讨论的是 Angular 2,而不是现在称为 AngularJS的框架的第一个版本。

AngularJS,原始框架,是一个MVC(模型-视图-控制器)框架。但是在Angular 2中,与 MV*-patterns没有严格的关联,因为它也是基于组件的。

Angular中的项目被组织成模块、组件和服务。每个 Angular应用程序至少有一个根组件和一个根模块。

Angular中的每个组件都包含一个模板、一个定义应用程序逻辑的类和元数据(装饰器)。组件的元数据告诉 Angular在哪里可以找到创建和呈现其视图所需的构建块。

Angular模板是用 HTML编写的,但也可以包含带有特殊指令的Angular模板语法,以输出反应性数据和呈现多个元素等。

组件使用 Angular中的服务来委托业务逻辑任务,例如获取数据或验证输入。它们是 Angular应用程序的独特部分。虽然 Angular不强制使用它们,但强烈建议将应用程序构建为一组可以重用的不同服务。

Angular内置于 TypeScript中,因此建议使用它以获得最无缝的体验,但也支持纯 JavaScript。

React是最受欢迎的 JavaScript项目之一,在 GitHub上拥有 16万颗星。它由 Facebook开发和维护,并在他们的许多项目内部使用。此外,根据BuiltWith的使用统计数据,它为超过 200万个网站提供支持。

在三个框架中,Vue在 GitHub上的 star数最多,有 176k。该项目由前 Google员工 Evan You开发和领导。据BuiltWith称,这是开源社区中一个非常强大的独立项目,被超过 100万个网站使用。

Angular是由 Google开发的,但令人惊讶的是它并没有用于他们的一些旗舰产品,例如搜索或 Youtube。它经常用于企业项目,并基于BuiltWith的数据为超过 97,000个网站提供支持。

它是三个框架中星数最少的,在 GitHub上有 68k星。然而,当从 Angular 1切换到 Angular 2时,他们创建了一个全新的代码库,而不是继续AngularJS项目,该项目也有 59k星。

在开发应用程序时,开源包可以为您节省宝贵的时间。不仅如此,它们通常比定制组件和封装更好,因为它们经过了实战测试。

查看可帮助您更轻松地创建新功能的现成组件、主题和其他工具的可用性非常重要。

许多前端应用程序依赖全局状态管理来存储信息,例如谁登录和其他用户设置。

最流行的 JavaScript状态管理项目是Redux。大多数开发人员使用Redux的官方 React绑定,这些绑定由 Redux团队维护。

由于 React的流行,查找输入组件和现成的元素非常容易。它们都只是在 Google或 GitHub上搜索即可。

React生态系统还包括React Native,它允许您从用 React编写的单个代码库构建原生 iOS和 Android应用程序。因此,React也可以成为使用 Web技术构建移动应用程序的绝佳选择。

React是 MERN堆栈的一部分,其中包含 MongoDB、ExpressJS、React和 NodeJS。这种组合的伟大之处在于,单一语言——JavaScript——为整个应用程序提供动力。

尽管 Redux可以在 Vue中使用,但没有官方绑定。但这不应该让您担心,因为Vuex是专门为 Vue应用程序制作的官方状态管理库。除了与 Vue很好地集成之外,使用 Vue的开发人员工具进行调试也很容易。

在 Vue的早期,很难找到现成的组件。随着社区的发展,您可以使用各种输入组件和高级元素来加快开发速度。

对于移动应用程序开发,有一个名为Weex的新兴项目。Weex由阿里巴巴开发和使用,但不如 React Native成熟和强大。更重要的是,由于该项目在中国开发和使用较多,因此很难找到英文文档和解决问题的方法。

Vue与 Laravel集成得很好,这就是为什么它们经常一起使用。Laravel提供完整的JavaScript和 CSS脚手架,以支持在新项目中使用 Vue。

对于 Angular中的状态管理,您可以使用NgRx项目。它的灵感来自 Redux,但它是专门为 Angular创建的。

与 Vue和 React的情况一样,您可以将许多现成的组件导入到您的项目中。与 Angular略有不同的是,Angular Material项目中有许多官方组件。这是 Google的一个官方项目,为 Angular应用程序提供 Material Design组件。

您可以使用NativeScript在 Angular中构建跨平台移动应用程序。它也支持 Vue,但 Angular支持更成熟。

Angular是著名的 MEAN堆栈的一部分,它将 Angular与 MongoDB、ExpressJS和 NodeJS相结合。与 MERN堆栈类似,它的前端和后端都完全依赖 JavaScript。

Angular、React和 Vue都可用于开发渐进式 Web应用程序,也称为 PWA。

PWA不是移动应用程序,而是 Web应用程序,智能手机用户可以将其添加为主屏幕的快捷方式,并提供类似于原生移动应用程序的外观和感觉。

您还可以为每个框架找到高级模板和预制应用程序,但 Angular和 React比 Vue提供更多高级选项。

在选择框架或库时,您还需要考虑性能。

在许多情况下,您不必担心性能,尤其是在构建小型项目时。然而,项目的范围和复杂性越大,性能就会(并且将会)成为一个问题。

重要的是要注意,在 Web性能方面,开发质量和遵循最佳实践比框架的选择更重要。

但由于存在一些性能指标和差异,我将研究它们并解释每个指标如何影响您的开发工作。

JS框架基准测试的结果表明,它们在大多数基准测试中都表现得相当好,例如在表中创建或附加行。

正如你在上面看到的,Vue在选择行时比 Angular和 React慢得多。另一方面,Angular和 React在交换行方面效率不高。

这些是渲染基准中唯一的实质性差异-在大多数情况下,不会产生明显的结果。由于选择行是比交换行更常见的功能,我想说这个基准测试将 Vue排在第三位,仅次于 Angular和 React并列第一。

在内存和启动时间方面,React和 Vue得分很好,但 Angular稍慢。Angular启动一个基本脚本可能需要 150毫秒,并且需要更多内存才能运行。

谷歌 Chrome实验室的Perf Track显示了来自数千个网站的生产数据。这些统计数据受许多其他因素的影响,而不仅仅是选择的框架,让我们看看数字。

与 Angular相比,Vue和 React网站在这个指标上的排名更高,Angular需要更多时间来启动并向用户呈现内容。

在渲染完整页面的三个框架中,Angular也是最慢的,只有 27%的 Angular网站得分在可接受的范围内。

对于所有三个框架,超过 80%的网站都在第一次输入延迟的可接受范围内,这显示了用户可以与页面交互所需的时间。

迄今为止,最轻量级的应用程序是使用 Vue开发的应用程序,68%的 Vue应用程序加载的 JavaScript不到 1MB。另一方面,Angular和 React应用程序往往具有更大的代码大小。

您可以从这些数字中看到趋势,但您不应该太快得出结论。例如,对于最后一张图,可以解释为 Vue用于开发更轻量级的应用程序,而 Angular用于更大的项目。

统计数据可以帮助指导您做出正确的决定,但您不能使用它们来证明一个框架比另一个更快或更好。

对于更高级的应用程序,使用的前端框架应该能够执行一些提高性能并且可以更好地扩展的任务。

两项关键技术是服务器端渲染(SSR)和虚拟化。

React支持使用官方ReactDOMServer包进行服务器端渲染。对于虚拟化,您可以使用名为React Virtualized的流行第三方工具。

Vue中也支持服务器端渲染以及官方的SSR包。此外,您还可以使用基于 Vue构建并支持 SSR的Nuxt.js框架。

不幸的是,Vue中的虚拟化选项并不是那么强大。在我看来,Vue Virtual Scroll List是虚拟滚动的最佳解决方案,但它有点问题,不如 React和 Angular的选项稳定。

Angular拥有SSR的官方Angular Universal包,以及用于虚拟滚动和高效渲染大型列表的官方组件。

要回答这个问题,我们需要查看每个框架的复杂性及其引入的概念。

在最基本的用例中,React是三个框架中最不复杂的。那是因为你只需要导入库,然后你就可以用几行代码开始编写你的 React应用程序。

但是除了 Hello World示例之外,大多数 React应用程序都是基于组件的,而不仅仅是在页面上呈现一些元素。

一些开发人员对 React感到奇怪或困难的一件事是,学习 JSX是一条单行道。您也可以使用原始 JavaScript,但由于大多数 React开发人员使用 JSX,学习它几乎是不可避免的。

这是使 React的学习曲线变得更陡峭的主要因素,但除此之外,对于了解 JavaScript并理解 Web开发概念的开发人员来说,它是一个易于学习的库。

Vue的设置比 React稍微复杂一些。你可以将它用作一个库来定义你可以在整个 HTML中使用的组件——但与 React类似,这不是大多数项目的构建方式。

大多数 Vue项目都有一个命名的根组件App.vue和一些用于显示各种内容的子组件。

说到语法,你唯一需要学习的新东西就是 Vue的模板语法,如果你了解 HTML,这很容易掌握。基本的指令,如v-if和v-for有条件的渲染和列表的渲染,很容易理解即使是初学者。

此外,Vue的单文件组件将所有前端代码保存在一个地方,便于组织新项目。

在我看来,Vue是最容易学习的,因为它的简单和直观的语法。

Angular拥有三者中最复杂的项目结构,而且由于它是一个成熟的前端框架,因此它依赖的概念更多。

除了组件,Angular还支持模块和服务。它希望您以特定的方式编写和设计代码库,从而使您的项目在扩展时更易于维护。

至于语法,由于 Angular最适合与 TypeScript配合使用,因此在构建 Angular项目时了解 TypeScript非常重要。

与 Vue一样,您还必须熟悉类似 HTML的语法,以便您可以开始使用 Angular编写新的 UI功能。

在我看来,Angular对于普通开发者来说是最难学的,因为它更复杂并且依赖于 TypeScript。

许多开源项目和框架逐渐被遗忘并无人维护。您是否应该担心我们在这里讨论的任何框架?

尽管我们无法完全预测会发生什么,但正在进行的开发工作是这些项目健康状况的良好指标。人气和增长也是预测项目寿命的重要指标,所以让我们来看看每个框架。

React v17.0已经发布,但令人惊讶的是,它没有为开发人员提供任何新功能。

主要的变化是这个新版本可以更容易地升级 React本身。您可以将 React的某些部分从旧版本升级到新版本,而无需升级整个项目。

如果您的应用程序依赖于随新版本更改或弃用的功能,您可以保留旧版本以保持此功能有效。此更新使 React成为一个很好的长期选择,因为它可以更轻松地与新版本保持同步。

React的每周 npm下载量自去年以来增长了 44%。从绝对数量来看,它仍然是三个项目中下载量最大的。

Vue 3已于2020年 9月发布,它解决了 Vue 2在大型项目中存在的许多严重问题。它引入了受React Hooks启发的Composition API,可以更轻松地跨组件重用逻辑。

整个项目用 TypeScript重写,提高了新 Vue项目对 TypeScript的支持,同时也使项目更易于维护。

Vue 3是一个急需的升级,使 Vue更适合大型项目。

Vue的每周下载量自去年以来增长了 87%,使 Vue成为相对而言增长最快的框架。如果 Vue能够保持这种增长速度,那么它肯定会很快超过 Angular。

Angular最近推出了Ivy编译器。它减少了构建时间,优化了资产,允许更快的测试,并总体上改善了开发人员的体验。

Angular团队每年发布两次重大更新,其中可能包含新功能,或者只是让框架跟上新浏览器版本的速度。

自去年以来,Angular的每周下载量增长了约 50%,因此它仍然是一个受欢迎的项目。

Angular、React和 Vue都处于非常活跃的开发阶段。他们定期发布新版本并维护现有版本。由于在每种情况下当前的支持水平都很高,因此您可以安全地使用这些框架中的任何一个。

需要注意的是,Angular的增长没有以前那么快,而 Vue——尽管它是最近开始的——似乎增长了很多。

如前所述,我们无法预测哪些框架会长期保持相关性,但每个项目背后都有一个伟大的社区,并且在不断发展。

我这篇文章的目标是解释架构差异,分解每个框架的优点和缺点,并在适用的地方进行比较。

在进入一个新框架之前,有几件事情需要考虑。

首先,在选择新技术时,您团队的经验可能是一个决定性因素。

同样,您必须考虑您所在地区可用的人才,以便您可以为您的项目聘请开发人员。

最后,当涉及到项目本身时,复杂性和范围也会影响您对框架的选择。

通过考虑所有关键差异,我希望您可以决定哪个是最适合您的目标和需求的前端框架。

(本文由闻数起舞翻译自Aris Pattakos的文章《Angular vs React vs Vue 2021》,转载请注明出处,原文链接:)

二、React如何实现浏览器打印部分内容详析

近期着手项目任务的打印功能,在此作个记录,本文介绍基于React的一种调用浏览器打印页面指定内容的方法。

整体思路:通过构建一个隐藏的元素(该元素包裹需打印的内容),当打印行为触发时,将页面其他的一些不需要打印的元素隐藏,然后将需打印的元素追加到body中,打印完成后,再恢复初始状态即可。浏览器打印的本质还是将web页面中的元素打印出来而已。

在页面中构建一个display为none的元素,里面的内容为你需要打印的内容。我们还需要设置包裹打印内容的元素的ref属性,以便于后面获取到元素。

<div style={{ display:'none'}}>

<div ref={el=>(this.printRef= el)}>

预览界面关闭后,将待打印元素从body中移除,将原始页面恢复。

let printView= this.state.printRef//获取待打印元素

document.querySelector('#root').className='print-hide'//将根元素隐藏

document.body.appendChild(printView)//将待打印元素追加到body中

window.print()//调用浏览器的打印预览

document.body.removeChild(printView)//将待打印元素从body中移除

document.querySelector('#root').className=''//将原始页面恢复

visibility: hidden!important;

其中,@page中的size可以自己设置纸张的大小,如果是A4纸可以直接设置值为A4,媒体查询@media print中设置的是打印时的样式,因为打印设备知道其输出区域的物理大小,所以使用厘米(cm)、毫米(mm)、英寸(in)等作为打印设计的单位完全可行。

直接替换body的内容为要打印的内容,之后再重新刷新页面。

const old= window.document.body.innerHTML//备份原来的页面

window.document.body.innerHTML=''

window.document.body.appendChild(/*将你要打印的内容附加到这*/)

window.print()//调用print()函数时,会跳出打印预览的界面,以下的代码被阻塞,关闭预览界面后继续执行

window.document.body.innerHTML= old

window.location.reload()//重新加载旧页面

打开一个新窗口,将打印内容放到新窗口打印,打印结束后关闭新窗口

const newWindow= window.open("打印窗口","_blank")

const docStr='<div>test</div>'//需要打印的内容

newWindow.document.write(docStr)

const styles= document.createElement("style")

styles.setAttribute('type','text/css')//media="print"

newWindow.document.getElementsByTagName('head')[0].appendChild(styles)

以上两种方法可能会造成CSS样式应用无效的问题。

第二小节的步骤2中的意思是:将页面中所有不需要打印的元素隐藏,特别注意像模态窗Model这些元素,也要为它们加上'print-hide'className属性。

如果需要在特定位置强制分页打印,可以尝试在对应元素上设置page-break-before:always!important、page-break-after:always!importantCSS属性,该属性只对块级元素有效。

进入打印预览后,我们无法获知用户最终是选择了打印,还是选择了取消。这里若有人知道解决方法的话,欢迎留言。

三、打开chrome浏览器开发者工具的方式

1、Chrome提供的一些调试功能,在排查代码故障时非常有帮助。事实上,由于谷歌浏览器提供的调试工具太多,很多都被隐藏了起来,等待你去探索。

2、声明:本文已获作者Ferenc Almasi翻译授权。

3、Chrome DevTools(开发者工具)团队每月(

4、 )都会在他们的网站上发布更新,你也可以在他们的官方 Twitter账户(

5、 )上找到一些很棒的提示。如果你想了解更多关于 Chrome提供的工具的信息,我强烈推荐查看这两个信息来源。

6、在这篇文章中,我收集了 10个我经常使用但是别人可能不知道的功能。它们帮助我简化了工作流程,可以在更短的时间内完成更多的工作。

7、这里先从在控制台中保持日志说起。假设在重新加载页面之前或导航发生时出现了问题,你会尝试登录控制台,但所有内容都被清除了。解决方法很简单,但我很久以前就不知道了:

8、通常,当用户交互发生时会出现问题。捕捉这些事件来检查在交互中运行的位置和内容非常有帮助。幸运的是,我们可以通过访问 Sources选项卡,用 Ctrl P打开一个 js文件,并检查其中的相关事件:

9、对于 DOM操作也可以添加断点。通常可以断点在某节点接收到属性更改上,例如添加了某个 class。在一个大型代码仓库中搜索相关代码将耗费大量时间,其实你可以简单地为元素添加一个断点,然后剩下的交给 DevTools处理。

10、有时候我们对代码进行性能优化,会导致很多代码没有用了但是还没及时清除。在覆盖工具的帮助下,你可以分析资源并查看哪些行没有执行。如果你关注的不是所有交互,只执行你所关注的交互操作有助于你获取准确的覆盖率。你可以点击 Ctrl Shift P打开工具面板,然后点击重新加载图标开始记录,所有以红色显示的内容都不会被执行。

11、不必要的重绘也会导致性能问题。假设你的页面上有一个倒计时,每次更新都会导致整个页面重新绘制。你可以通过在 Render选项卡中启用 paint flashing来解决这些问题,并查看哪些元素触发了这些问题。

12、同样,Ctrl Shift P会弹出工具栏。

13、在 Rendering选项卡上启用重新绘制

14、既然上面讨论了渲染,那么让我们来看看如何调试 CSS动画。用 Ctrl Shift P打开工具菜单,输入“ animation”它将为你打开动画标签,这将记录任何发生在网站上的动画。你可以重播它们,看看它们的宽松程度,然后根据时间或持续时间调整:

15、我们经常需要与其他人分享截图来验证更改。如果你不得不重复多个步骤,这个任务可能会消耗时间:

16、这可以在 DevTools内部完成。你可以从整个页面、单个节点(被选中的节点)或视图中创建图像:

17、假设你正在调试一个问题,并且你的代码中有两个断点。你正在进行堆栈跟踪,你会发现堆栈信息中大多数来自核心框架文件,如 React或 jQuery。为了避免在调试器中包含这些核心文件,你可以对它们进行黑盒处理,这意味着 DevTools将跳过这些文件,以便你可以专注于自己的代码。

18、本地覆盖是我最喜欢的一个,我发现自己使用它越来越频繁。它是一个强大的工具,使你能够加载生产文件的本地副本,并使用它们来替代捆绑的副本。当一个问题只发生在特定的环境中而不能在本地复现时,这一点尤其有用。

19、你可以在“Source”选项卡下启用 Overrides(重写)。如果你没有看到 Overrides链接,点击 Page右侧的锯齿图标。你可以将漂亮的打印文件复制到你本地文件并对其进行扩展。重写将通过页面重新加载保持。

20、我发现自己一直在使用 Lighthouse面板,这是为了审计你的网站在各种指标:性能,PWA,可访问性,或搜索引擎优化。你还可以选择审计不同的设备以及模拟网络连接,它为你提供了哪些可以改进以及如何改进的参考。你可以在“Audits”选项卡下进入“灯塔”,如果你没有看到标签,只需点击锯齿符号来显示隐藏的标签。

21、生成报告后,可以将结果保存为 JSON文件,稍后导入以进行比较。

22、上面是必须知道的 10个 Chrome开发工具特性,它们帮助我简化了工作流程,并且在更短的时间内完成了更多的工作。

23、你每天使用的 Chrome开发者工具的功能是什么?请在评论中告诉我们。

24、 

25、作者简介:Ferenc Almasi,匈牙利前端开发者,热衷于开发和设计新的交互式应用程序。他还喜欢尝试新技术,创造简单而有吸引力的东西。

26、译者:明明如月,知名互联网公司 Java高级开发工程师,CSDN博客专家。

好了,文章到此结束,希望可以帮助到大家。

声明:信息资讯网所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流,版权归原作者东方体育日报所有。若您的权利被侵害,请联系 删除。

本文链接:http://www.gdxhedu.com/news/168952.html