目前前端流行的框架总结

news/2024/11/18 22:25:59/

框架

前端框架

前端框架一般指用于简化网页设计的框架,使用广泛的前端开发套件,比如,jquery,extjs,bootstrap等等,这些框架封装了一些功能,比如html文档操作,漂亮的各种控件(按钮,表单等等),使用前端框架可以帮助快速地搭建网站。

框架是提供一套完整的解决方案,按照规定好的代码结构来做编排,使用前端框架可以降低界面开发周期和提高界面的美观性。

随着Web 越来越规范和标准的统一,Web组件化技术不断革新,移动端开发不断升华,前端框架层出不穷。

我们总说,前端三大框架是一家, 你抄我, 我抄他, 节操被野兽践踏, Google, 大神和Meta

三大框架分别是:

  • 尤雨溪团队的 Vue
  • Meta(原Facebook) 团队的 React
  • Google 团队的 Angular

但前端又不止这些框架,下面,简单介绍一下比较流行的几个前端框架。

更多详细内容,请微信搜索“前端爱好者戳我 查看

常用的前端框架

Vue

官网:https://cn.vuejs.org/

Vue.js 是由华人开发者尤雨溪于 2014 年 2 月首次发布的。在它的前身 vue.js 0.x 版本中,尤雨溪还是在 Google 工作,后来辞职成为开发者。Vue.js 在 2015 年正式发布了 1.0 版本,随着社区的快速发展,现在已经成为一个流行的前端框架。

完美的中文配套文档, 超低的入学门槛, 一度被人说是 “傻瓜式框架”, 易学易用,褒贬不一的双向数据绑定以及超级容易上手的渐进式框架模式,都是深受我们喜欢的点。

优点

  • 简单易学: Vue 的核心库非常精简,学习曲线相对较低,开发者可以快速上手使用。
  • 双向数据绑定 : Vue 支持双向数据绑定,可以使得 UI 和数据同步更新,避免了手动操作 DOM 的繁琐。
  • 组件化开发: Vue 也采用组件化开发的思想,可以让开发者更好地组织和复用代码。
  • 虚拟 DOM:Vue 也使用虚拟 DOM 技术,可以优化页面性能,提高渲染效率。
  • 社区活跃: Vue 有着庞大而活跃的社区,开发者可以轻松获取各种资源和插件,这些资源和插件可以提高开发效率。

缺点

  • 依赖第三方库: Vue 需要使用第三方库来实现一些功能,如 Vuex 管理状态、Vue Router 实现路由等,这使得开发者需要学习和使用更多的工具和库。
  • 缺乏严格的规范: Vue 缺乏严格的规范,开发者可能会使用不同的命名规则、组件结构等,这可能会导致项目的可维护性降低。
  • 市场占有率相对较低: 相比于 React 和 Angular,Vue 的市场占有率相对较低,这可能会影响一些开发者的选择。

React

官网: https://react.dev/

React 是由Meta(原Facebook) 开发的一个用于构建用户界面的 JavaScript 库。React 的第一个版本发布于 2013 年 5 月,但是在 2015 年,React 的体系结构发生了重大变化,从而推出了 React 16。React 在社区和商业领域都拥有广泛的应用。

React 的组件化开发模式, 虚拟 DOM 渲染, 可以与其他框架 库进行结合使用, 以及 “好玩又有意思” 的 JSX 语法深受大家喜爱

优点

  • 高效的虚拟 DOM:React 采用虚拟 DOM 技术,可以减少页面重绘的次数,提高页面渲染效率。
  • 组件化开发:React 采用组件化开发的思想,可以让开发者更好地组织和复用代码。
  • 单向数据流:React 采用单向数据流的架构,使得应用的状态变得可控和可预测。
  • 生态系统丰富:React 拥有庞大的生态系统,包括 Redux 状态管理、React Router 实现路由等等,可以帮助开发者更好地开发和维护应用。
  • 跨平台支持:React 还支持跨平台开发,可以用于构建 Web 应用、移动应用、桌面应用等多种平台。

缺点

  • 学习成本高: React 采用 JSX 语法,开发者需要掌握这种语法以及相关的工具和库,学习成本较高。
  • 生态系统庞杂:虽然 React 的生态系统丰富,但也存在一些庞杂的库和组件,选择合适的库和组件需要一定的技术水平和经验。
  • 组件化开发的限制:React 的组件化开发思想虽然提高了代码的复用性和可维护性,但也存在一些限制,如组件之间的通信、状态管理等,需要开发者花费一定的精力去解决。

Angular

官网:Angular

Angular 是 Google 在 2010 年发布的 AngularJS 的升级版,也称为 Angular 2。AngularJS 是由 Misko Hevery 和 Adam Abrons 在 2009 年创建的,最初被称为 “GetAngular”,并于 2010 年更名为AngularJS。

随着 AngularJS 的成功,Google 开始全面重构该框架,并于 2016 年发布了 Angular 2。目前,Angular 也是非常流行的前端框架之一。

优点

  • 完整的 MVC 框架:Angular 提供了一个完整的 MVC 框架,包括数据绑定、路由、依赖注入、指令等,这些功能可以帮助开发者更加方便地管理和维护代码。
  • 响应式编程:Angular 支持响应式编程,可以轻松处理异步数据流。这种编程方式可以提高代码的可读性、可维护性和可测试性。
  • TypeScript 支持:Angular 基于 TypeScript,提供了更好的类型检查、代码提示、重构等功能,可以降低代码出错的风险,同时提高开发效率。
  • 适用于大型应用:Angular 适用于构建大型、复杂的 Web 应用,可以帮助开发者更好地组织代码和管理模块。

缺点

  • 学习成本高:由于 Angular 提供了完整的 MVC 框架,学习成本相对较高,需要掌握的知识点较多,对于初学者来说可能会有一定的难度。
  • 性能问题:由于 Angular 提供了较多的功能和依赖,有时会导致性能问题。开发者需要谨慎使用依赖注入、数据绑定等功能,以避免影响应用的性能。
  • 版本升级问题:Angular 的版本升级较为频繁,升级过程中可能会导致一些兼容性问题。这需要开发者花费一定的时间和精力去适应新的版本。

jQuery

jQuery是 2006 年推出的最初的前端框架之一。不管它的发布日期如何,让它与众不同的是它在当今科技生态圈中的重要性。 jQuery 不仅易于使用,而且还减少了编写广泛的 JavaScript 代码的需求。基本上,jQuery 用于在前端操作DOM 和 CSS 操作,并增强网站的交互性和功能。

该框架的最新开发允许开发人员使用其基于 HTML5 的 UI 方案 - jQuery Mobile 创建本地移动应用程序。 此外,jQuery 框架对浏览器友好,并支持您打算使用的浏览器。

一些旧的网站,依然使用此jQuery。

Svelte

官网:https://svelte.dev
中文官网:https://www.sveltejs.cn / https://www.svelte.cn/

Svelte 是一种全新的构建用户界面的方法。传统框架如 React 和 Vue 在浏览器中需要做大量的工作,而 Svelte 将这些工作放到构建应用程序的编译阶段来处理。

与使用虚拟(virtual)DOM 差异对比不同。Svelte 编写的代码在应用程序的状态更改时就能像做外科手术一样更新 DOM。

Alpine

官网:https://alpinejs.dev
中文官网:https://www.alpinejs.cn

Alpine.js 通过很低的成本提供了与 Vue 或 React 这类大型框架相近的响应式和声明式特性。

你可以继续操作 DOM,并在需要的时候使用 Alpine.js。

可以理解为 JavaScript 版本的 Tailwind。

备注:Alpine.js 的语法几乎完全借用自 Vue (并用 Angular 的语法做了些扩展)。在此由衷感谢他们对 Web 世界的贡献。

实例

<div x-data="{ open: false }"><button @click="open = true">Open Dropdown</button><ulx-show="open"@click.away="open = false">Dropdown Body</ul>
</div>

Preact

官网:https://preactjs.com

React 的 3kb 轻量化方案,拥有同样的 ES6 API。具有体积小、高性能、轻量 & 可嵌入、生态系统兼容等特点。

Preact是一个 JavaScript 库,它将自己定义为包含类似 ES6 API 的 React 的最快 3KB 替代品。Preact 提供了除了 DOM 之外的最小可能的虚拟 DOM 抽象。

它在稳定的平台特性和功能上与其他可用的前端和 UI 库一起开发。Preact 体积小,但速度不受影响,可以开发复杂的动态 Web 应用程序。

实例

import { h, render, Component } from 'preact';class App extends Component {// Initialise our state. For now we only store the input valuestate = { value: '' }onInput = ev => {// This will schedule a state update. Once updated the component// will automatically re-render itself.this.setState({ value: ev.target.value });}render() {return (<div><h1>Hello, world!</h1><form><input type="text" value={this.state.value} onInput={this.onInput} /><button type="submit">Update</button></form></div>);}
}render(<App />, document.getElementById("app"));

LitElement

官网:https://lit.dev

LitElement 是一个简单的框架,用于构建快速、轻量级的 Web 组件。它提供反应状态、作用域样式和一个小巧、快速且富有表现力的声明性模板系统。

实例

import { LitElement, html, property, customElement } from 'lit-element';@customElement('simple-greeting')
export class SimpleGreeting extends LitElement {@property() name = 'World';render() {return html`<p>Hello, ${this.name}!</p>`;}
}
<simple-greeting name="Everyone"></simple-greeting>

为什么使用LitElement

  • 令人愉快的声明: Lit-element简单,熟悉的开发模型使构建web组件变得前所未有的简单。以声明的方式表达UI,作为状态的函数。不用学习web-components语言,可以在模版中使用javascript的全部功能。element元素更改时会自动更新
  • 快而轻: 无论是在哪里工作的人,都会欣赏Lit-element的速度非常快。它使用lit-html定义和呈现html只会重新刷新组件样式动态变更部分
  • 无缝互操作: Lit-element遵循web组件标准。因此组件将适用于任何框架。Lit-element使用自定义元素轻松包含在网页中。使用shadow DOM进行封装。

Stimulus

官网:https://stimulus.hotwired.dev

Stimulus 是一个轻量级前端框架。这个框架通过 data-contoller data-target data-action 等属性,把 HTML 元素和 JavaScript 行为绑定,Stimulus 本身不处理 HTML 渲染,而是为已渲染的 HTML 添加行为。

Ember

官网:https://emberjs.com

Ember.js 是一个开源的免费 JavaScript 客户端框架,用于开发 Web 应用程序。使用模型-视图-控制器(MVC)模式。该框架提供通用数据绑定,基于网址驱动的方法用于构建不同应用,重点放在可扩展性上。

Emberjs是 2011 年开发的基于组件的框架。它呈现双向数据绑定,类似于 Angular。它旨在无可挑剔地管理对当代技术不断增长的需求。 您可以使用 Ember.js 构建多方面的 Web 和移动应用程序,并期望其有效的设计能够处理这些问题。然而,Ember 的学习曲线是它为数不多的缺陷之一。由于其传统和刚性的结构,该框架是最具挑战性的 Web UI 框架之一。 由于相对较新且未经探索,它的开发者社区是微不足道的。任何人只要不拘泥于花时间学习它的知识,就可以学习它。

当然,还有很多框架,比如:Semantic-UI、Backbone.js、Foundation等等。

最好的前端框架

谈到最好的前端框架,我们可以确定市场是多种多样的。更重要的是,UI 开发人员有机会从顶级创新者中进行选择。

Angular、Vue.js 和 React 等 前端框架已经在市场上占据了最高位置。

这些框架得到了社区的大力支持,并因其独特的灵活性和特性而被选中。

参考文档

  • https://baijiahao.baidu.com/s?id=1719221861793933665&wfr=spider&for=pc
  • https://zhuanlan.zhihu.com/p/76463271
  • https://baijiahao.baidu.com/s?id=1728185890869092949&wfr=spider&for=pc

http://www.ppmy.cn/news/89236.html

相关文章

python 编程技巧高阶函数

一、python 常见编程技巧&#xff1a;提高代码的效率和可读性 1、使用列表推导式和生成器表达式来简化代码&#xff0c; 例如 [x * 2 for x in range(10)] 和 (x * 2 for x in range(10))。 2、使用 enumerate 函数来同时遍历序列的索引和值&#xff0c; 例如 for i, x in enu…

ClickHouse:(一)安装部署

1.准备工作 1.2关闭防火墙 防火墙的开启、关闭、禁用命令 &#xff08;1&#xff09;设置开机启用防火墙&#xff1a;systemctl enable firewalld.service&#xff08;2&#xff09;设置开机禁用防火墙&#xff1a;systemctl disable firewalld.service&#xff08;3&#x…

2023年数据治理企业老板为啥都让员工考CDGA/CDGP证书?

企业老板让员工考取CDGA证书一般有以下几个原因: 提升数据治理能力 CDGA认证是一种全球通用的数据治理认证&#xff0c;可以帮助员工提升数据治理的技能和能力更好地管理、保护和分析企业的数据。 增强员工竞争力 随着数据治理在企业中的重要性越来越高&#xff0c;拥有CDGA…

安卓基础巩固(二):四大组件:Activity、Service、Broadcast、Content Provider

文章目录 Activity生命周期onCreate和onStart的区别onPause和onStop的区别生命周期的变化 Activity的启动IntentBundle Activity携带参数返回Activity启动模式任务&#xff08;task&#xff09;&#xff0c;返回栈&#xff08;back stack&#xff09;Activity的四种启动模式sta…

如何入手学习halcon课程

如何入手学习halcon课程 halcon是一款综合性的机器视觉标准软件&#xff0c;拥有全球通用的集成开发环境HDevelop。 它不仅能够节约成本而且缩短您产品进入市场的时间。 halcon的灵活架构有利于快速开发任何类型的机器视觉应用。 官网 halcon支持多种图像采集设备&#xff0…

Android开发 外部存储空间

一、存储空间 对Andriod来说&#xff0c;存储空间分为内部存储空间和外部存储空间。 外部存储空间也就是常说的SD卡&#xff0c;可以分为私有存储空间和公共存储空间。 内部存储空间和外部存储空间的私有存储空间&#xff0c;都是每个APP独有的&#xff0c;不允许其他APP访问…

央国企数字化转型难在哪?为什么要数字化转型?

随着新一轮科技革命和产业变革深入发展&#xff0c;数字化成为央国有企业的必答题。 但就目前情况来看&#xff0c;央国有企业数字化转型还面临着许多挑战&#xff0c;必然是一个长期的过程。 01 央国企数字化转型难在哪&#xff1f; 根据调研数据&#xff0c;中央企业数字化…

超详细的wireshark抓包使用教程

前言 Wireshark是非常流行的网络封包分析软件&#xff0c;可以截取各种网络数据包&#xff0c;并显示数据包详细信息。常用于开发测试过程各种问题定位。本文主要内容包括&#xff1a; 1、Wireshark软件下载和安装以及Wireshark主界面介绍。 2、WireShark简单抓包示例。通过该…