前端框架对比与选择

在这里插入图片描述

🤖 作者简介:水煮白菜王 ,一位资深前端劝退师 👻
👀 文章专栏: 前端专栏 ,记录一下平时在博客写作中,总结出的一些开发技巧✍。
感谢支持💕💕💕

目录

  • 前端框架对比与选择
    • 1. React
    • 2. Vue
    • 3. Angular
    • 4. Svelte
    • 5. Electron
    • 6. Next.js
    • 7. Nuxt.js
    • 8. Gatsby
    • 9. Preact
    • 10. 国内大厂自研前端框架
      • 10.1 Dumi
      • 10.2 Taro
      • 10.3 Ant Design Pro
    • 11. 总结
      • 11.1 选择建议
      • 11.2 未来趋势

在这里插入图片描述

前端框架对比与选择

随着前端技术的快速发展,各种前端框架层出不穷,每个框架都有其独特的优势和适用场景。本文将详细对比几个主流的前端框架——React、Vue、Angular、Svelte、Electron、Next.js、Nuxt.js、Gatsby、Preact,以及国内大厂自研的前端框架,如Dumi、Taro、Ant Design Pro等,并提供选择建议,帮助开发者根据项目需求做出最佳选择。

1. React

1.1 概述

React 是由 Facebook 开发并维护的一个用于构建用户界面的 JavaScript 库。它主要用于构建单页面应用程序(SPA)和移动应用。

1.2 优点

  • 组件化:React 采用组件化开发,使得代码复用性和可维护性更高。
  • 虚拟 DOM:通过虚拟 DOM 提高性能,减少不必要的 DOM 操作。
  • 生态系统丰富:拥有庞大的社区支持和丰富的第三方库。
  • 学习曲线适中:对于初学者来说,学习曲线相对平缓。

1.3 缺点

  • 文档不够全面:官方文档有时不够详细,需要查阅社区资源。
  • 灵活性高但复杂度增加:高度灵活的架构可能导致项目结构复杂。
  • 状态管理复杂:大型项目中状态管理较为复杂,需要引入 Redux 等工具。

1.4 适用场景

  • 单页面应用程序:适合构建复杂的单页面应用程序。
  • 大型项目:适合大型企业级项目,尤其是需要高度定制化的场景。
  • 社区支持:适合需要丰富社区资源和第三方库的项目。

1.5 代码示例

import React, { useState } from 'react';function App() {const [count, setCount] = useState(0);return (<div><p>Count: {count}</p><button onClick={() => setCount(count + 1)}>Increment</button></div>);
}export default App;

2. Vue

2.1 概述

Vue 是由尤雨溪开发并维护的一个渐进式 JavaScript 框架。它易于上手,同时提供了强大的功能,适合构建复杂的单页面应用程序。

2.2 优点

  • 易学易用:语法简洁,学习曲线平缓,适合初学者快速上手。
  • 模板系统:使用模板系统,代码可读性高。
  • 双向数据绑定:通过 v-model 实现双向数据绑定,简化数据管理。
  • 体积小:核心库体积小,加载速度快。

2.3 缺点

  • 社区规模较小:相对于 React 和 Angular,社区规模较小,第三方库较少。
  • 生态不如 React 成熟:虽然发展迅速,但生态成熟度略逊于 React。

2.4 适用场景

  • 小型项目:适合快速开发小型项目。
  • 中型项目:适合中型项目,尤其是需要快速迭代的场景。
  • 个人项目:适合个人开发者或小团队快速上手。

2.5 代码示例

<template><div><p>Count: {{ count }}</p><button @click="increment">Increment</button></div>
</template><script>
export default {data() {return {count: 0};},methods: {increment() {this.count++;}}
};
</script>

3. Angular

在这里插入图片描述

3.1 概述

Angular 是由 Google 开发并维护的一个完整的前端框架。它采用了 MVC 架构,适合构建大型企业级应用程序。

3.2 优点

  • 完整的解决方案:提供从路由到依赖注入的完整解决方案。
  • 类型安全:基于 TypeScript,提供类型检查,减少运行时错误。
  • 强大的模板系统:模板系统强大,支持双向数据绑定和指令。
  • 社区支持:拥有庞大的社区支持和丰富的文档。

3.3 缺点

  • 学习曲线陡峭:对于初学者来说,学习曲线较陡峭。
  • 项目初始化复杂:项目初始化和配置较为复杂。
  • 体积较大:核心库体积较大,初始加载时间较长。

3.4 适用场景

  • 大型企业级项目:适合构建大型企业级应用程序。
  • 需要类型安全的项目:适合需要类型检查和静态分析的项目。
  • 长期维护的项目:适合需要长期维护和扩展的项目。

3.5 代码示例

import { Component } from '@angular/core';@Component({selector: 'app-root',template: `<div><p>Count: {{ count }}</p><button (click)="increment()">Increment</button></div>`,styleUrls: ['./app.component.css']
})
export class AppComponent {count = 0;increment() {this.count++;}
}

4. Svelte

在这里插入图片描述

4.1 概述

Svelte 是一个较新的前端框架,由 Rich Harris 开发。它在编译时将框架逻辑移除,生成纯粹的 JavaScript,从而提高运行时性能。

4.2 优点

  • 高性能:编译时优化,生成的代码更高效。
  • 体积小:运行时没有框架开销,生成的代码体积小。
  • 易于上手:语法简洁,学习曲线平缓。
  • 反应式编程:内置反应式编程模型,简化状态管理。

4.3 缺点

  • 社区较小:相对于 React 和 Vue,社区规模较小,第三方库较少。
  • 生态不成熟:虽然发展迅速,但生态成熟度略逊于 React 和 Vue。

4.4 适用场景

  • 高性能需求:适合需要高性能的应用程序。
  • 小型到中型项目:适合快速开发小型到中型项目。
  • 个人项目:适合个人开发者或小团队快速上手。

4.5 代码示例

<script>let count = 0;function increment() {count += 1;}
</script><div><p>Count: {count}</p><button on:click={increment}>Increment</button>
</div>

5. Electron

在这里插入图片描述

5.1 概述

Electron 是一个使用 JavaScript、HTML 和 CSS 构建跨平台桌面应用程序的框架。它结合了 Chromium 渲染引擎和 Node.js 运行时。

5.2 优点

  • 跨平台:支持 Windows、macOS 和 Linux,实现一次开发,多平台运行。
  • Web 技术栈:使用 Web 技术栈,前端开发者可以快速上手。
  • 丰富的 API:提供丰富的原生 API,方便访问系统功能。
  • 社区活跃:拥有活跃的社区和丰富的第三方库。

5.3 缺点

  • 体积较大:打包后的应用程序体积较大。
  • 性能问题:某些场景下,性能可能不如原生应用。
  • 资源消耗:运行时资源消耗较高。

5.4 适用场景

  • 跨平台桌面应用:适合开发需要跨平台的桌面应用程序。
  • Web 技术栈项目:适合前端开发者快速开发桌面应用。
  • 需要原生功能:适合需要访问系统原生功能的应用程序。

5.5 代码示例

// main.js
const { app, BrowserWindow } = require('electron');function createWindow() {const win = new BrowserWindow({width: 800,height: 600,webPreferences: {nodeIntegration: true}});win.loadFile('index.html');
}app.whenReady().then(createWindow);app.on('window-all-closed', () => {if (process.platform !== 'darwin') {app.quit();}
});app.on('activate', () => {if (BrowserWindow.getAllWindows().length === 0) {createWindow();}
});

6. Next.js

在这里插入图片描述

6.1 概述

Next.js 是一个基于 React 的轻量级框架,用于构建服务端渲染(SSR)和静态生成的网站。

6.2 优点

  • 服务端渲染:支持 SSR,提高首屏加载速度和 SEO。
  • 静态生成:支持静态生成,适合构建静态网站。
  • 自动代码分割:自动进行代码分割,优化加载性能。
  • 易于上手:基于 React,学习曲线平缓。

6.3 缺点

  • 配置复杂:某些高级功能需要复杂的配置。
  • 依赖 React:需要对 React 有较深的理解。

6.4 适用场景

  • 服务端渲染:适合需要 SSR 的项目。
  • 静态网站:适合构建静态生成的网站。
  • SEO 优化:适合需要 SEO 优化的项目。

6.5 代码示例

// pages/index.js
import { useState } from 'react';export default function Home() {const [count, setCount] = useState(0);return (<div><p>Count: {count}</p><button onClick={() => setCount(count + 1)}>Increment</button></div>);
}

7. Nuxt.js

在这里插入图片描述

7.1 概述

Nuxt.js 是一个基于 Vue 的轻量级框架,用于构建服务端渲染(SSR)和静态生成的网站。

7.2 优点

  • 服务端渲染:支持 SSR,提高首屏加载速度和 SEO。
  • 静态生成:支持静态生成,适合构建静态网站。
  • 自动代码分割:自动进行代码分割,优化加载性能。
  • 易于上手:基于 Vue,学习曲线平缓。

7.3 缺点

  • 配置复杂:某些高级功能需要复杂的配置。
  • 依赖 Vue:需要对 Vue 有较深的理解。

7.4 适用场景

  • 服务端渲染:适合需要 SSR 的项目。
  • 静态网站:适合构建静态生成的网站。
  • SEO 优化:适合需要 SEO 优化的项目。

7.5 代码示例

<template><div><p>Count: {{ count }}</p><button @click="increment">Increment</button></div>
</template><script>
export default {data() {return {count: 0};},methods: {increment() {this.count++;}}
};
</script>

8. Gatsby

在这里插入图片描述

8.1 概述

Gatsby 是一个基于 React 的静态网站生成器,专注于性能优化和开发体验。

8.2 优点

  • 高性能:优化了静态生成和加载性能。
  • 丰富的插件系统:提供丰富的插件和主题。
  • GraphQL:内置 GraphQL 支持,方便数据管理。
  • 易于上手:基于 React,学习曲线平缓。

8.3 缺点

  • 配置复杂:某些高级功能需要复杂的配置。
  • 依赖 React:需要对 React 有较深的理解。

8.4 适用场景

  • 静态网站:适合构建静态生成的网站。
  • 高性能需求:适合需要高性能的项目。
  • 内容驱动的网站:适合内容驱动的网站,如博客和文档。

8.5 代码示例

// src/pages/index.js
import React from 'react';
import { graphql } from 'gatsby';export default function Home({ data }) {const { count } = data.site.siteMetadata;return (<div><p>Count: {count}</p><button onClick={() => console.log('Increment')}>Increment</button></div>);
}export const query = graphql`query {site {siteMetadata {count}}}
`;

9. Preact

在这里插入图片描述

9.1 概述

Preact 是一个轻量级的 React 替代品,体积更小,性能更高。

9.2 优点

  • 体积小:核心库体积小,加载速度快。
  • 性能高:优化了性能,适合性能敏感的项目。
  • 兼容 React:API 与 React 兼容,可以轻松迁移。
  • 易于上手:基于 React,学习曲线平缓。

9.3 缺点

  • 社区较小:相对于 React,社区规模较小,第三方库较少。
  • 生态不成熟:虽然发展迅速,但生态成熟度略逊于 React。

9.4 适用场景

  • 性能敏感的项目:适合需要高性能的项目。
  • 小型项目:适合快速开发小型项目。
  • 嵌入式设备:适合资源受限的嵌入式设备。

9.5 代码示例

import { h, Component } from 'preact';class App extends Component {state = { count: 0 };increment = () => {this.setState({ count: this.state.count + 1 });};render() {return (<div><p>Count: {this.state.count}</p><button onClick={this.increment}>Increment</button></div>);}
}export default App;

10. 国内大厂自研前端框架

10.1 Dumi

在这里插入图片描述
10.1.1 概述
Dumi 是由蚂蚁金服开发的组件开发工具,支持组件库的开发、测试和文档生成。Dumi是一个基于约定的文档管理工具,特别适用于组件开发场景,旨在让开发者能够专注于组件开发和文档编写,具有开箱即用的特点。它支持将注意力集中在组件开发和文档编写上,提供了一种轻量级且开发者友好的方式来生成文档。Dumi支持多种组件库类型,包括但不限于React,并且特别适合迁移React组件
库到Dumi环境。dumi是基于 Umi 打造,dumi 就是可以用来写文档、官网和组件库 Demo 的 Umi。

10.1.2 优点

  • 组件开发:专为组件库开发设计,提供丰富的开发工具。
  • 文档生成:自动生成组件文档,提高开发效率。
  • 插件系统:支持丰富的插件,扩展性强。

10.1.3 缺点

  • 社区较小:相对于主流框架,社区规模较小。
  • 学习曲线:需要一定的学习成本。

10.1.4 适用场景

  • 组件库开发:适合开发和维护组件库。
  • 企业内部项目:适合企业内部项目,尤其是需要组件化开发的场景。

10.2 Taro

10.2.1 概述

Taro 是由京东开发的一个多端统一开发方案,支持微信小程序、H5、React Native 等多端开发。

10.2.2 优点

  • 多端开发:一套代码,多端运行,提高开发效率。
  • 生态丰富:支持多种平台,生态丰富。
  • 社区活跃:拥有活跃的社区和丰富的文档。

10.2.3 缺点

  • 性能问题:某些平台上的性能可能不如原生开发。
  • 学习曲线:需要一定的学习成本。

10.2.4 适用场景

  • 多端开发:适合需要多端开发的项目。
  • 小程序开发:适合微信小程序开发。
  • 跨平台应用:适合需要跨平台的应用。

10.3 Ant Design Pro

10.3.1 概述

Ant Design Pro 是由蚂蚁金服开发的企业级中后台前端/设计解决方案。

10.3.2 优点

  • 企业级:专为企业级应用设计,提供丰富的组件和模板。
  • 设计规范:遵循 Ant Design 设计规范,保证一致的用户体验。
  • 开箱即用:提供多种预设模板,开箱即用。

10.3.3 缺点

  • 学习曲线:需要一定的学习成本。
  • 定制性:某些场景下定制性较差。

10.3.4 适用场景

  • 企业级应用:适合开发企业级中后台应用。
  • 快速开发:适合需要快速开发的应用。
  • 设计一致性:适合需要设计一致性的项目。

11. 总结

框架优点缺点适用场景
React- 组件化
- 虚拟 DOM
- 生态系统丰富
- 学习曲线适中
- 文档不够全面
- 灵活性高但复杂度增加
- 状态管理复杂
- 单页面应用程序
- 大型项目
- 社区支持
Vue- 易学易用
- 模板系统
- 双向数据绑定
- 体积小
- 社区规模较小
- 生态不如 React 成熟
- 小型项目
- 中型项目
- 个人项目
Angular- 完整的解决方案
- 类型安全
- 强大的模板系统
- 社区支持
- 学习曲线陡峭
- 项目初始化复杂
- 体积较大
- 大型企业级项目
- 需要类型安全的项目
- 长期维护的项目
Svelte- 高性能
- 体积小
- 易于上手
- 反应式编程
- 社区较小
- 生态不成熟
- 高性能需求
- 小型到中型项目
- 个人项目
Electron- 跨平台
- Web 技术栈
- 丰富的 API
- 社区活跃
- 体积较大
- 性能问题
- 资源消耗
- 跨平台桌面应用
- Web 技术栈项目
- 需要原生功能
Next.js- 服务端渲染
- 静态生成
- 自动代码分割
- 易于上手
- 配置复杂
- 依赖 React
- 服务端渲染
- 静态网站
- SEO 优化
Nuxt.js- 服务端渲染
- 静态生成
- 自动代码分割
- 易于上手
- 配置复杂
- 依赖 Vue
- 服务端渲染
- 静态网站
- SEO 优化
Gatsby- 高性能
- 丰富的插件系统
- GraphQL
- 易于上手
- 配置复杂
- 依赖 React
- 静态网站
- 高性能需求
- 内容驱动的网站
Preact- 体积小
- 性能高
- 兼容 React
- 易于上手
- 社区较小
- 生态不成熟
- 性能敏感的项目
- 小型项目
- 嵌入式设备
Dumi- 组件开发
- 文档生成
- 插件系统
- 社区较小
- 学习曲线
- 组件库开发
- 企业内部项目
Taro- 多端开发
- 生态丰富
- 社区活跃
- 性能问题
- 学习曲线
- 多端开发
- 小程序开发
- 跨平台应用
Ant Design Pro- 企业级
- 设计规范
- 开箱即用
- 学习曲线
- 定制性
- 企业级应用
- 快速开发
- 设计一致性

11.1 选择建议

  • React:适合大型企业级项目,需要高度定制化和丰富社区资源的场景。
  • Vue:适合快速开发小型到中型项目,适合初学者和需要快速迭代的场景。
  • Angular:适合大型企业级项目,需要类型安全和完整解决方案的场景。
  • Svelte:适合需要高性能的小型到中型项目,适合个人开发者或小团队快速上手。
  • Electron:适合开发跨平台的桌面应用程序,适合前端开发者快速上手。
  • Next.js:适合需要 SSR 和静态生成的项目,适合需要 SEO 优化的项目。
  • Nuxt.js:适合需要 SSR 和静态生成的项目,适合需要 SEO 优化的项目。
  • Gatsby:适合构建静态网站,适合内容驱动的项目。
  • Preact:适合性能敏感的项目,适合小型项目和嵌入式设备。
  • Dumi:适合组件库开发和企业内部项目。
  • Taro:适合多端开发和微信小程序开发。
  • Ant Design Pro:适合企业级中后台应用和需要快速开发的项目。

11.2 未来趋势

  • React:持续更新,社区活跃,未来将继续保持领先地位。
  • Vue:发展迅速,社区逐渐壮大,未来有望成为主流框架之一。
  • Angular:虽然学习曲线较陡峭,但凭借 Google 的支持,依然会有稳定的用户群体。
  • Svelte:性能优越,社区逐渐扩大,未来前景看好。
  • Electron:跨平台优势明显,社区活跃,将持续受到欢迎。
  • Next.js:React 生态的重要组成部分,将持续发展。
  • Nuxt.js:Vue 生态的重要组成部分,将持续发展。
  • Gatsby:静态生成领域的重要玩家,将持续优化性能。
  • Preact:轻量级框架,适合性能敏感的项目,将持续受到关注。
  • Dumi:组件开发工具,适合企业内部项目,将持续优化。
  • Taro:多端开发方案,适合微信小程序开发,将持续发展。
  • Ant Design Pro:企业级中后台解决方案,将持续优化用户体验。

在这里插入图片描述
如果你觉得这篇文章对你有帮助,请点赞 👍、收藏 👏 并关注我!👀
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/432383.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

详细分析SpringMvc中HandlerInterceptor拦截器的基本知识(附Demo)

目录 前言1. 基本知识2. Demo3. 实战解析 前言 对于Java的基本知识推荐阅读&#xff1a; java框架 零基础从入门到精通的学习路线 附开源项目面经等&#xff08;超全&#xff09;【Java项目】实战CRUD的功能整理&#xff08;持续更新&#xff09; 1. 基本知识 HandlerInter…

量化交易四大邪术之三:春去花还在

网络相传亚洲有四大邪术&#xff0c;日本化妆&#xff0c;韩国整容&#xff0c;泰国变X&#xff0c;Z国PS。 这些都是让人在颜值上看起来很美&#xff0c;类似地&#xff0c;在量化交易领域&#xff0c;也有四大邪术能让净值曲线看起来很美&#xff0c;之前已经说了“般若波罗蜜…

CSS clip-path 属性的使用

今天记录一个css属性clip-path&#xff0c;首先介绍下这个属性。 clip-path 是CSS中的一个神奇属性&#xff0c;它能够让你像魔术师一样&#xff0c;对网页元素施展“裁剪魔法”——只展示元素的一部分&#xff0c;隐藏其余部分。想象一下&#xff0c;不用依赖图片编辑软件&am…

Python--类【详细教程】

类的介绍 面向对象编程&#xff08;object-oriented programming&#xff0c;OOP&#xff09;是最有效的软件编写方法之⼀。在面向对象编程中&#xff0c;你编写表示现实世界中的事物的类&#xff08;class&#xff09;&#xff0c;并基于这些类来创建对象&#xff08;object&…

C语言 | Leetcode C语言题解之第436题寻找右区间

题目&#xff1a; 题解&#xff1a; typedef struct {int start;int index; } Node;int cmp(const void *pa, const void *pb) {return ((Node *)pa)->start - ((Node *)pb)->start; }int* findRightInterval(int** intervals, int intervalsSize, int* intervalsColSiz…

四川财谷通信息技术有限公司抖音小店强势引领电商

在数字经济蓬勃发展的今天&#xff0c;短视频与直播电商已成为推动消费增长的重要引擎&#xff0c;而抖音平台更是以其庞大的用户基础、精准的算法推荐和创新的商业模式&#xff0c;成为了众多商家争相入驻的蓝海市场。在这片充满活力的电商沃土上&#xff0c;四川财谷通信息技…

GPS冷启动定位不准问题

1.使用模块 EG800K 2.定位不准问题 应用场景&#xff1a;由于低功耗设备&#xff0c;需要GPS定位&#xff0c;设备的功耗会很高&#xff0c;因此每次定位完成后必须将模块的电源断开。 定位不准原因&#xff1a; 1.每次设备从供电&#xff0c;到定位成功&#xff0c;需要3…

【文心智能体】 旅游手绘手帐 开发分享 零代码 手绘风景 记录行程和心情 旅游攻略

旅游手绘手帐&#xff0c;点击文心智能体平台AgentBuilder | 想象即现实 目录 背景 创作灵感 开发历程 一、基础配置 二、高级配置 三、引导示例&#xff08;提示词&#xff09; 四、prompt&#xff08;提示词&#xff09;优化 期待优化 背景 这个智能体是一个零代码…

CSS中的字体样式、文本样式、列表样式以及背景和渐变

一、字体样式和文本样式 1.span标签 span标签的作用&#xff1a;能让某几个文字或者是词语凸显出来 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-…

在深度学习中,是否应该打破正负样本1:1的迷信思想?

Q&#xff1a;是否应该打破正负样本 1:1 的迷信思想&#xff1f;A&#xff1a;是的&#xff0c;类别不平衡的比例只是表象&#xff0c;并非本质。 Q&#xff1a;当训练集和测试集分布匹配&#xff0c;但正负样本比例仍然悬殊&#xff0c;是否有必要再引入处理不平衡样本的策略…

新峰商城之订单处理流程

订单处理是电商系统中的重要模块&#xff0c;从用户单击提交订单并成功生成订单开始&#xff0c;包括订单支付成功、订单信息确认、订单出库、到确认收货的正常订单流程。也包括了订单取消、订单退款等其它异常流程。 一、订单处理流程 正常流程&#xff1a; 订单生成后&…

Git - 初识版本库

版本库也叫仓库&#xff0c;英文名 repository。 ‍ 创建版本库 之前我们说了版本库的概念&#xff1a; 存储版本的地方&#xff08;存放各个版本之间差异的地方&#xff09;&#xff0c;通常称为版本库。通常版本库是以文件&#xff08;夹&#xff09;的形式存放在磁盘上&a…

处理RabbitMQ连接和认证问题

在使用RabbitMQ进行消息队列管理时&#xff0c;我们可能会遇到各种连接和认证问题。本文将介绍如何诊断和解决这些问题&#xff0c;并通过使用RabbitMQ的管理端进行登录验证来确保配置正确。 1. 问题概述 在最近的一次部署中&#xff0c;我们遇到了两个主要问题&#xff1a; …

成为谷歌开发者专家(GDE)的经历

大家好&#xff0c;我是张海龙(Jason)。经过一年多的准备&#xff0c;GDE申请 终于正式成功通过面试&#xff0c;成为了国内第一位Firebase GDE。下面对整个过程做个总结&#xff0c;希望对大家有所帮助。 1.什么是 GDE&#xff1f; Google Developers上面有详细的说明&#x…

Apache Druid命令执行(CVE-2021-25646)

漏洞详情&#xff1a; Apache Druid 是用Java编写的面向列的开源分布式数据存储系统&#xff0c;旨在快速获取大量事件数据&#xff0c;并在数据之上提供低延迟查询。 Apache Druid含有能够执行嵌入在各种类型请求中由用户提供的JavaScript代码功能。此功能适用于高度信任环境…

计算机前沿技术-人工智能算法-大语言模型-最新论文阅读-2024-09-21

计算机前沿技术-人工智能算法-大语言模型-最新论文阅读-2024-09-21 1. AIvril: AI-Driven RTL Generation With Verification In-The-Loop Authors: Mubashir ul Islam, Humza Sami, Pierre-Emmanuel Gaillardon, and Valerio Tenace AIVRIL: 人工智能驱动的RTL生成与验证内…

如何在Excel中快速找出前 N 名,后 N 名

有如下销售额统计表&#xff1a; 找出销售额排前 10 名的产品及其销售额&#xff0c;和销售额排倒数 10 名以内的产品及其销售额&#xff0c;结果如下所示&#xff1a; 前 10 名&#xff1a; spl("E(?1).sort(ProductSales:-1).to(10)",A1:C78)后 10 名&#xff1…

K8S精进之路-控制器StatefulSet有状态控制 -(2)

状态说明 在进行StatefulSet部署之前&#xff0c;我们首先可能要了解一下&#xff0c;什么是"有状态应用"和"无状态应用"。无状态应用就是pod无论部署在哪里&#xff0c;在哪台服务器上提供服务&#xff0c;都是一样的结果&#xff0c;比如经常用的nginx。…

Debian与Ubuntu:深入解读两大Linux发行版的历史与联系

Debian与Ubuntu&#xff1a;深入解读两大Linux发行版的历史与联系 引言 在开源操作系统的领域中&#xff0c;Debian和Ubuntu是两款备受瞩目的Linux发行版。它们不仅在技术上有着密切的联系&#xff0c;而且各自的发展历程和理念也对开源社区产生了深远的影响。本文将详细介绍…

主数据的前世今生与治理方法论(附PPT | 某集团公司主数据项目案例与方法论)

主数据&#xff08;Master Data&#xff09;是指企业内核心业务实体数据&#xff0c;具有共享、稳定、跨部门和系统的特点。主数据在企业数据管理中扮演着至关重要的角色&#xff0c;它是企业核心业务实体数据的核心组成部分。它是企业经营运作的主体对象&#xff0c;也是企业数…