首页
学习
活动
专区
圈层
工具
发布

前端框架「React」 VS 「Svelte」

诸如 React 和 Vue 这类传统的框架,它们的大部分工作都在浏览器上执行,而 Svelte 在构建应用的过程做就了大量的工作。 ‎...「状态向上传递」 为了让这个应用正常工作,每次点击按钮时,必须让 App 组件的 count 状态值增1。因此需要一个机制来将数据从子组件传递给父组件。...这样就可以在 Heading 组件的 HTML 模板中直接显示 count 这个属性。 这个写法稍微有点点奇怪,但在文件顶部直接声明属性的方式看起来不错,而且可以直接使用这个属性。...请注意第 6 行代码的语法,忽略掉下一节要介绍的样式部分,直接看按钮点击的事件侦听器,它跟以往使用的习惯不同。 Svelte 使用一个 on: 指令来给 DOM 元素添加事件侦听器。...handleClick() 函数在 handleClick 属性上定义,可以在 JSX 上使用一个标准的 onClick 事件来触发。

4.3K30

前端框架 React 和 Svelte 的基础比较

诸如 React 和 Vue 这类传统的框架,它们的大部分工作都在浏览器上执行,而 Svelte 在构建应用的过程做就了大量的工作。 ‎...状态向上传递 为了让这个应用正常工作,每次点击按钮时,必须让 App 组件的 count 状态值增1。因此需要一个机制来将数据从子组件传递给父组件。...这样就可以在 Heading 组件的 HTML 模板中直接显示 count 这个属性。 这个写法稍微有点点奇怪,但在文件顶部直接声明属性的方式看起来不错,而且可以直接使用这个属性。...请注意第 6 行代码的语法,忽略掉下一节要介绍的样式部分,直接看按钮点击的事件侦听器,它跟以往使用的习惯不同。 Svelte 使用一个 on: 指令来给 DOM 元素添加事件侦听器。...handleClick() 函数在 handleClick 属性上定义,可以在 JSX 上使用一个标准的 onClick 事件来触发。

2.8K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    React vs Svelte

    诸如 React 和 Vue 这类传统的框架,它们的大部分工作都在浏览器上执行,而 Svelte 在构建应用的过程做就了大量的工作。 ‎...「状态向上传递」 为了让这个应用正常工作,每次点击按钮时,必须让 App 组件的 count 状态值增1。因此需要一个机制来将数据从子组件传递给父组件。...这样就可以在 Heading 组件的 HTML 模板中直接显示 count 这个属性。 这个写法稍微有点点奇怪,但在文件顶部直接声明属性的方式看起来不错,而且可以直接使用这个属性。...请注意第 6 行代码的语法,忽略掉下一节要介绍的样式部分,直接看按钮点击的事件侦听器,它跟以往使用的习惯不同。 Svelte 使用一个 on: 指令来给 DOM 元素添加事件侦听器。...handleClick() 函数在 handleClick 属性上定义,可以在 JSX 上使用一个标准的 onClick 事件来触发。

    3.6K30

    怎样修复 Web 程序中的内存泄漏

    正文共:4737 字 预计阅读时间:10 分钟 从服务器端渲染的网站切换到客户端渲染的 SPA 时,我们突然不得不更加注意用户设备上的资源,必须做很多工作:不要阻塞 UI 线程,不要使笔记本电脑的风扇疯狂旋转...其中许多只是正常用法——某些对象被取消分配,而另一个对象被优先分配,某些对象以某种方式被缓存,以便稍后进行清理,等等。 消除噪音 我发现消除噪音的最好方法是多次重复泄漏情况。...大猩猩吃香蕉 让我们回到上面的 addEventListener 的例子。泄漏的来源是事件侦听器,该事件侦听器引用一个函数,该函数引用一个组件,该组件可能引用大量的东西,例如数组、字符串和对象。...在上面的示例中,有一个名为 someObject 的变量,该变量由闭包(也称为“上下文”)引用,并由事件侦听器引用。...总结 在 Web 应用中查找和修复内存泄漏的状态仍然很初级。在本文中,我介绍了一些对我有用的技术,但是请记住,这仍然是一个困难且耗时的过程。 与大多数性能问题一样,少量预防胜过大量的治疗。

    4.3K30

    React v17有什么新功能?

    React 团队承诺 v17 版本的发布对未来非常重要,但也提到没有添加新特性。你可能想知道它为什么会被发布。 在本文中,我将列出最新版本中所做的更改。 正文 为什么没有新功能?...尽管在这次更新中没有直接面向开发人员的功能是很不寻常的,但这次发布的主要目标是确保将一个版本的React管理的树嵌入到另一个版本的React管理的树中是安全的。...当 React v18 和以下版本推出时,您可以通过升级应用程序的某些部分来逐步迁移,同时仍然让其他部分在 React v17 上运行。...//来自调用e.stopPropagation()的React组件的点击 }); 要解决此问题,请 capture 通过将 { capture: true }选项作为第三个参数传递,将事件侦听器转换为使用阶段...中,此代码可以按您期望的那样工作。

    3.3K31

    22 个让 React 开发更高效更有趣的工具

    /src/components,如下所示: 以下是在示例中我们使用组件之一的例子: React-Proto 在 GitHub 上获得了 2,000 个星标。...这是 react-testing-library 解决的一个问题,因为理想情况下,我们只希望我们的用户界面能够正常工作并最终正确显示。...Bit 在使用诸如 material-ui 或 semantic-ui-react 之类的组件库时,Bit 是一个很好的替代方案。它可以让我们探索数千个开源组件,并使用它们来构建项目。...我很想写一篇完整的文章,介绍我们今天在 codeandbox 上可以使用的所有功能,不过,现在看起来工作已经完成了。 14. ...我不知道为什么提到这个网站的人不多,但在这个页面我发现了几乎所有我需要的信息,它快捷、方便,并不断更新,总是能为我所有的项目提供所需的结果。

    2.8K31

    22 个让 React 开发更高效更有趣的工具

    /src/components,如下所示: 以下是在示例中我们使用组件之一的例子: React-Proto 在 GitHub 上获得了 2,000 个星标。...这是 react-testing-library 解决的一个问题,因为理想情况下,我们只希望我们的用户界面能够正常工作并最终正确显示。...Bit 在使用诸如 material-ui 或 semantic-ui-react 之类的组件库时,Bit 是一个很好的替代方案。它可以让我们探索数千个开源组件,并使用它们来构建项目。...我很想写一篇完整的文章,介绍我们今天在 codeandbox 上可以使用的所有功能,不过,现在看起来工作已经完成了。 14. ...我不知道为什么提到这个网站的人不多,但在这个页面我发现了几乎所有我需要的信息,它快捷、方便,并不断更新,总是能为我所有的项目提供所需的结果。

    10.9K31

    我用 React 和 Vue 构建了同款应用,来看看哪里不一样(2020 版)

    在 React 中,我们的输入字段有一个名为 value 的属性。每次通过 onChange 事件侦听器 更改它的值时,都会自动更新此值。...简而言之,React 中的子组件可以通过 props 来访问父函数(前提是你要向下传递 props,这是相当标准的做法,其他 React 工作中也非常常见);而在 Vue 中,你需要从子级发射事件,这些事件通常会在父组件内部回收...Vue 事件侦听器很好用的是你还可以绑定很多东西,例如.once,它可以防止事件侦听器被多次触发。在编写处理按键的特定事件侦听器时还有许多捷径。...我发现在 React 中创建一个事件侦听器,做到每当按下 enter 键就创建新的 ToDo 项目,写起来比较麻烦。...然后将触发位于父组件中的函数。我们可以在“如何从列表中删除项目”部分中查看全过程。 Vue: 在子组件中,我们只需要编写一个将值返回给父函数的函数即可。

    6.1K30

    JS 和 Node.js 中的“事件驱动”是什么意思?

    实际上,浏览器中的 JavaScript 可以与 HTML 元素进行交互,这些 HTML 元素是事件发送器(event emitters),即能够发送事件的对象。...浏览器中的主题和观察者 如果 HTML 元素是主题,那么谁是观察者?任何注册为侦听器的 JavaScript 函数都可以对浏览器中的事件做出反应。...回顾一下: HTML 元素是事件发送器。 JavaScript 中注册为侦听器的函数是观察者。 所有这些组件构成了“一个小小的事件驱动的体系结构。...你在 Node.js 中所做的大部分工作都是基于事件的。总会有一个发送器对象,一些观察者在监听消息。...; }); 这段代码创建了一个监听本地主机端口 8081 的服务器。在 server 对象上,我们调用 on 方法来注册两个侦听器函数。

    9.8K20

    2019年,React 开发者应该掌握的 22 种神奇工具

    以下是在示例中我们使用组件之一的例子: ? React-Proto 在 GitHub 上获得了 2,000 个星标。 3....这是 react-testing-library 解决的一个问题,因为理想情况下,我们只希望我们的用户界面能够正常工作并最终正确显示。...Bit 在使用诸如 material-ui 或 semantic-ui-react 之类的组件库时,Bit (https://bit.dev/)是一个很好的替代方案。...该工具启动了支持热重载的实时开发服务器,让我们可以在其中独立地实时开发 React 组件。 另一个很棒的事情是,我们可以使用现有的开源插件,将我们的开发经验提升到一个全新的水平。...我不确定为什么提到这个网站的人不多,但在这个页面我发现了几乎所有我需要的信息,它快捷、方便,并不断更新,总是能为我所有的项目提供所需的结果。

    3.1K21

    【React】653- 22 个让 React 开发更高效更有趣的工具

    /src/components,如下所示: 以下是在示例中我们使用组件之一的例子: React-Proto 在 GitHub 上获得了 2,000 个星标。...这是 react-testing-library 解决的一个问题,因为理想情况下,我们只希望我们的用户界面能够正常工作并最终正确显示。...Bit 在使用诸如 material-ui 或 semantic-ui-react 之类的组件库时,Bit 是一个很好的替代方案。它可以让我们探索数千个开源组件,并使用它们来构建项目。...我很想写一篇完整的文章,介绍我们今天在 codeandbox 上可以使用的所有功能,不过,现在看起来工作已经完成了。 14....我不知道为什么提到这个网站的人不多,但在这个页面我发现了几乎所有我需要的信息,它快捷、方便,并不断更新,总是能为我所有的项目提供所需的结果。

    2.7K20

    使用React和Node构建实时协作的白板应用

    对于用户界面,我们将创建一个 WhiteBoard 组件,用户可以在我们的 React 应用程序中操作图形元素。...使用React构建一个Canvas组件 在深入研究 RoughJS 和绘图功能之前,让我们先创建我们的 WhiteBoard 组件。...在Canvas组件中集成RoughJS RoughJS 是一个轻量级的库,可以让我们在画布上创建手绘、草图般的图形。...: 让我们来测试我们的应用程序:上面的视频显示我们的代码可以工作,并且可以使用鼠标坐标在我们的白板上绘制线条。...在我们的情况下,我们将使用它来确保我们的客户端应用程序(运行在不同的源上)可以与服务器进行交互。 Socket.io :一个实时通信库,方便客户端和服务器之间的双向通信。

    1.8K20

    从Lisp到Vue、React再到 Qwit:响应式编程的发展历程

    这种方法的好处是,任何 JavaScript 对象都可以在模板中用作数据绑定源,更新也能正常工作。...但是 Knockout 有一个有趣的创新 —— 计算属性,它可能已经存在过,但这是我第一次听说。它们会自动在输入上创建订阅。...它的工作方式非常类似于 Knockout,但在语法上类似于 Vue/MobX。 假设我们想要绑定到一个常量作为组件的用户,则会出现 DX 问题。...响应性即使开发人员将Accessor转换为原始类型也能正常工作。 我们还能在此基础上做出什么改进吗? 响应性和渲染 让我们想象一个产品页面,有一个购买按钮和一个购物车。...好吧,Qwik 利用了组件在 SSR/SSG 期间已经在服务器上执行的事实。Qwik 可以将这个图形序列化为 HTML。这使得客户端完全可以跳过最初的“执行世界以了解反应图”的步骤。

    2.5K20

    如何设计可视化搭建平台的组件商店?

    按照我一向的写作风格,我会在下面列出文章的大纲,以便大家有选择且高效率的阅读和学习: 什么是组件商店,为什么要设计组件商店 组件商店工作流设计 组件商店工作流具体方案实现 实现在线代码编辑器 组件提交方案设计...组件审批方案设计 组件上架更新方案 可视化搭建平台组件商店总结及后期规划 文章视图如下,大家在平时在工作中也可以通过思维导图的方式来整理思路。...什么是组件商店, 为什么要设计组件商店 “商店”大家也许并不陌生,对用户而言,其基本用途是满足正常的消费需求;对供应商而言,商店提供了一种销售自身产品的营销推广渠道;对商店自身而言,一方面获得了客流和利润...目前我的做法是将用户提交的完整的组件数据存在库中,以便审核转化为可视化平台可以消费的组件,当然大家也可以用更智能的方式,自动对组件代码信息进行提取转化,其缺点就是误差率无法控制,以及无法对组件进行准确的描述...那么这里我介绍一下我的线上自动化上架的方案,这里还是需要借助上面介绍的 socket.io 和 nodejs。

    34510

    如何设计可视化搭建平台的组件商店?

    按照我一向的写作风格,我会在下面列出文章的大纲,以便大家有选择且高效率的阅读和学习: 什么是组件商店,为什么要设计组件商店 组件商店工作流设计 组件商店工作流具体方案实现 实现在线代码编辑器 组件提交方案设计...组件审批方案设计 组件上架更新方案 可视化搭建平台组件商店总结及后期规划 文章视图如下,大家在平时在工作中也可以通过思维导图的方式来整理思路。...什么是组件商店, 为什么要设计组件商店 “商店”大家也许并不陌生,对用户而言,其基本用途是满足正常的消费需求;对供应商而言,商店提供了一种销售自身产品的营销推广渠道;对商店自身而言,一方面获得了客流和利润...目前我的做法是将用户提交的完整的组件数据存在库中,以便审核转化为可视化平台可以消费的组件,当然大家也可以用更智能的方式,自动对组件代码信息进行提取转化,其缺点就是误差率无法控制,以及无法对组件进行准确的描述...那么这里我介绍一下我的线上自动化上架的方案,这里还是需要借助上面介绍的 socket.io 和 nodejs。

    1.3K20

    【愚公系列】2023年03月 其他-Web前端基础面试题(react专项_35道)

    这些综合事件具有与您惯用的本机事件相同的界面,除了它们在所有浏览器中的工作方式相同. React实际上并未将事件附加到子节点本身。...React将使用单个事件侦听器在顶层侦听所有事件 8、React如何创建refs Refs 是使用 React.createRef() 方法创建的,并通过 ref 属性添加到 React 元素上...React在不使用JSX的情况下一样可以工作,然而使用JSX可以提高组件的可读性,因此推荐使用JSX 10、为什么不直接更新state状态 如果直接更新state状态,那么它将不会重新渲染组件,而是使用...高阶组件是重用组件逻辑的高级方法。基本上,这是从React的组成性质衍生的模式。HOC是自定义组件,在其中包裹了另一个组件。他们可以接受任何动态提供的子组件,但不会修改或复制其输入组件中的任何行为。...在回调中你可以使用箭头函数,但问题是每次组件渲染时都会创建一个新的回调。

    10.4K10

    vue面试题八股文简答大全 让你更加轻松的回答面试官的vue面试题

    了解这些知识点可以让我们更好地编写Vue.js应用程序,并深入了解Vue.js的工作原理计算属性和侦听器Vue.js提供了计算属性和侦听器来处理数据的变化。...组件组件是Vue.js的另一个核心概念,它允许你构建可重用和可组合的UI组件。在Vue.js中,每个组件都是一个Vue实例,并且可以包含其他组件。...生命周期钩子可以在Vue实例的选项对象中定义。在Vue.js中有7个生命周期钩子:created: 在Vue实例创建后调用,但在模板渲染之前。mounted: 在Vue实例挂载到DOM上后调用。...事件处理程序可以接收一个事件对象作为参数。在Vue.js的事件处理中,事件是经过封装的。在组件内部使用$emit方法触发事件,在组件之间使用$on来监听事件。...并处理输入事件我做过测试,输出包含v-model模板的组件渲染函数,发现它会被转换为value属性的绑定以及一个事件监听,事件回调函数中会做相应变量更新操作,这说明神奇魔法实际上是vue的编译器完成的。

    3.5K51

    【面试题】412- 35 道必须清楚的 React 面试题

    比较有趣的是,React 实际上并不将事件附加到子节点本身。React 使用单个事件侦听器侦听顶层的所有事件。这对性能有好处,也意味着 React 在更新 DOM 时不需要跟踪事件监听器。...基本上,这是一个模式,是从 React 的组合特性中衍生出来的,称其为纯组件,因为它们可以接受任何动态提供的子组件,但不会修改或复制输入组件中的任何行为。...主题: React 难度: ⭐⭐⭐ 在构建 React 应用程序时,在多层嵌套组件来使用另一个嵌套组件提供的数据。...主题: React 难度: ⭐⭐⭐ 传统的 MVC 模式在分离数据(Model)、UI(View和逻辑(Controller)方面工作得很好,但是 MVC 架构经常遇到两个主要问题: 数据流不够清晰:跨视图发生的级联更新常常会导致混乱的事件网络...但在大多数情况下,Hooks 就足够了,可以帮助减少树中的嵌套。 问题 32:如何避免组件的重新渲染? 主题: React 难度: ⭐⭐⭐⭐ React 中最常见的问题之一是组件不必要地重新渲染。

    5.4K30

    把 React 作为 UI 运行时来使用

    这是很有道理的,因为 React 本身就是一个 UI 库。就像官网上所说的那样。 ? 我曾经写过关于构建用户界面中遇到的挑战的文章。...本文面向有经验的程序员,还有使用过其他 UI 库,但在项目中权衡利弊之后最终选择了 React 的人,我希望它会对你有所帮助! 一些人用了很多年 React 却从没有考虑过接下来我要讲述的主题。...也就是说,在 React 组件中不允许有用户可以直接看到的副作用。换句话说,仅调用函数式组件时不应该在屏幕上产生任何变化。 递归 我们该如何在组件中使用组件?...例如,渲染一棵很深的树(在每次页面转换的时候发生)而不阻塞浏览器。改变跟踪并不会让它变得更快 — 这样只会让其变得更慢因为我们执行了额外的订阅工作。另一个问题是我们需要等待返回的数据在渲染视图之前。...有很多关于这种设计选择的激烈争论,但在实践中我并没有看到它让人困惑。我还写了关于为什么通常提出的替代方案不起作用的文章。 Hooks 的内部实现其实是链表 。

    3.4K40

    【19】进大厂必须掌握的面试题-50个React面试

    组件是React应用程序UI的构建块。这些组件将整个UI分成独立且可重用的小块。然后,它使这些组件中的每个组件彼此独立,而不会影响UI的其余部分。 12.解释React中render()的目的。...高阶组件是重用组件逻辑的高级方法。基本上,这是从React的组成性质衍生的模式。HOC是自定义组件,在其中包裹了另一个组件。他们可以接受任何动态提供的子组件,但不会修改或复制其输入组件中的任何行为。...React Router – React面试问题 46.什么是React Router? React Router是一个强大的路由库,建立在React的基础上,可以帮助向应用程序添加新的屏幕和流程。...47.为什么 在React Router v4中使用switch关键字? 尽管 用于在路由器内部封装多个路由。当您只想显示几个定义的路径中要渲染的单个路径时,可以使用 “ switch”关键字 。...所述 标签在使用时匹配以在顺序次序中的定义的路由类型化URL。找到第一个匹配项后,它将呈现指定的路线。从而绕过其余 路线。 48.为什么我们在React中需要一个Router?

    15.1K30
    领券