当前位置: 首页 > news >正文

前端开发技术栈(工具篇):2023深入了解webpack的安装和使用以及核心概念和启动流程(详细) 63.3k stars

目录

Webpack简介

Entry

Module

Chunk

Loader

Plugin

Output

Webpack的启动流程

Webpack的优缺点

Webpack的使用

1. 安装Webpack

2. 创建Webpack配置文件

3. 编写代码

4. 运行Webpack

5. 在HTML中引入打包后的文件

6. 执行编译命令

Webpack其他功能介绍

1. 使用配置文件

2. 使用插件

3. 使用loader

总结


图片

在前面一篇文章《前端开发技术栈(工具篇):2023深入了解快速开发工具vite的安装和使用(详细)》中,我们详细介绍了vite这款工具的使用,并构建一个项目,通过编写了一个简单的示例来演示它的热更新功能。由于最早的项目可能使用的都还是webpack,所以本篇我将给大家总结介绍下webpack这款项目的打包工具。

更多关于Vue前端相关技术点,敬请关注公众号:CTO Plus后续的发文,有问题欢迎后台留言交流。

图片

本文原文:前端开发技术栈(工具篇):2023深入了解webpack的安装和使用以及核心概念和启动流程(详细) 63.3k stars

Webpack是一个强大的模块打包工具,它可以将多个模块打包成一个bundle文件,可以将各种资源(如JavaScript、CSS、图片等)打包成一个或多个静态资源文件,使得前端开发更加高效,从而实现代码的模块化、打包、压缩等功能。在本篇博客中,在使用Webpack时,了解它的启动流程以及它的优缺点是非常重要的,所以本篇我们将介绍Webpack核心概念的含义和作用、启动流程、优缺点以及在项目中的使用方法。 

图片

在Webpack中,Entry指定了构建的入口文件,Module表示一个模块,Chunk代表被分割的代码块,Loader用于处理各种类型的文件,Plugin扩展和定制Webpack的构建过程,Output指定构建后文件的输出路径和文件名。这些概念和功能共同构成了Webpack的核心,帮助开发者高效地构建前端项目。

Webpack简介

Webpack 是一个前端资源加载/打包工具。它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源。

从图中我们可以看出,Webpack 可以将多种静态资源 js、css、less 转换成一个静态文件,减少了页面的请求。

图片

 Webpack核心概念

接下来我们来介绍下Webpack主要的6个核心概念,在使用Webpack时,有6个核心概念是非常重要的,它们分别是入口(Entry)、出口(Output)、加载器(Loader)、插件(Plugin)、模式(Mode)和代码分割(Code Splitting)。了解和掌握这些概念对于使用Webpack进行项目构建是非常重要的。通过合理地配置入口、出口、加载器、插件、模式和代码分割,我们可以高效地打包和管理项目中的各种资源,提高开发效率和代码质量。

1. 入口(Entry):入口是Webpack开始构建依赖图的起点,可抽象成输入。它指定了Webpack应该从哪个文件开始查找依赖关系,并从该文件开始构建整个应用程序的依赖图。一个入口可以对应一个或多个输出文件。

2. 出口(Output):输出结果,在 Webpack 经过一系列处理并得出最终想要的代码后输出结果,出口指定了Webpack打包后的文件输出的位置和文件名。它定义了打包后的文件应该存放在哪个目录下,以及输出文件的命名规则。通常情况下,一个Webpack配置文件只能有一个出口。

3. 加载器/模块转换器(Loader):加载器用于把模块原内容按照需求转换成新内容,对非JavaScript文件进行转换和处理。Webpack默认只能处理JavaScript文件,而通过加载器,我们可以告诉Webpack如何处理其他类型的文件,例如将CSS文件转换为JavaScript模块,或者将图片文件转换为Base64编码的字符串。

4. 插件(Plugin):插件是Webpack的核心功能扩展机制,在 Webpack 构建流程中的特定时机注入扩展逻辑来改变构建结果或做你想要的事情。它们可以用于执行各种任务,例如压缩代码、提取CSS、生成HTML文件等。插件可以通过配置文件或者命令行参数进行配置,并且可以在整个构建过程中的不同阶段进行操作。

5. 模块(Module):在 Webpack 里一切皆模块,一个模块对应着一个文件。Webpack 会从配置的 Entry 开始递归找出所有依赖的模块。

6. 代码块(Chunk):一个 Chunk 由多个模块组合而成的抽象概念,用于代码合并与分割。代码分割(Code Splitting)是指将应用程序的代码分割成多个块,以便于按需加载。这样可以减小初始加载的文件大小,并且在需要时动态加载额外的代码块。Webpack提供了多种代码分割的方式,例如通过动态导入(dynamic import)语法、使用`SplitChunksPlugin`插件等。

Entry

在Webpack中,Entry是指定构建的入口文件的配置项。入口文件是Webpack开始构建依赖图的起点,它可以是一个或多个JavaScript文件。通过指定Entry,Webpack可以找到入口文件,并从入口文件开始递归地解析模块依赖关系。

Entry的作用是告诉Webpack从哪里开始构建依赖图,并确定构建的入口模块。它可以是一个字符串,表示单个入口文件的路径,也可以是一个对象,表示多个入口文件的路径。

Entry支持一个入口,也可以支持多个入口,更可以支持由函数动态写入。Webpack 在寻找相对路径的文件时会以 context 为根目录,context 默认为执行启动 Webpack 时所在的当前工作目录。 如果想改变 context 的默认配置,则可以在配置文件里设置它。

Module

Module是Webpack中的一个核心概念,它代表着一个模块。模块可以是一个JavaScript文件,也可以是一个CSS文件、图片文件等其他类型的文件。

通过rules 配置模块的读取和解析规则,通常用来配置Loader。其类型是一个数组,数组里每一项都描述了如何去处理部分文件。配置一项rules 时大致通过以下方式:

1、条件匹配:通过test、include、exclude三个配置项来命中Loader要应用规则的文件。

2、应用规则:对选中后的文件通过use配置项来应用Loader,可以只应用一个Loader或者按照从后往前的顺序应用一组Loader,同时还可以分别给Loader传入参数。

在Webpack中,模块可以通过加载器(Loader)进行转换和处理。加载器可以将各种类型的文件转换为JavaScript模块,以便在浏览器中执行。例如,使用babel-loader可以将ES6代码转换为ES5代码,使用css-loader可以加载和处理CSS文件。

Module的作用是将项目中的各种资源文件转换为可执行的JavaScript代码,并将它们组织成一个依赖关系树。

Chunk

Chunk是Webpack中的一个概念,它代表着被分割出来的代码块。在Webpack的构建过程中,可以将代码拆分成多个块(Chunk),每个块包含一组相关的模块。

通过代码分割,可以实现按需加载,提高页面的加载速度和用户体验。例如,可以将第三方库和业务代码分割成不同的块,使得第三方库可以被缓存,减少重复加载的时间。

Loader

Loader是Webpack中的一个功能模块,用于处理各种类型的文件。通过加载器,Webpack可以将非JavaScript文件转换为JavaScript模块。

Loader可以看作具有文件转换功能的转义员,配置里的module.rules 数组配置了一组规则,告诉 Webpack 在遇到哪些文件时使用哪些 Loader 去加载和转换。如配置告诉 Webpack 在遇到以 .css 结尾的文件时先使用 css-loader 读取 CSS 文件,再交给 style-loader 把 CSS 内容注入到 JavaScript 里。

Loader的作用是在模块加载的过程中对文件进行转换和处理。例如,可以使用babel-loader将ES6代码转换为ES5代码,使用css-loader加载和处理CSS文件,使用file-loader加载和处理图片文件。

Webpack支持链式调用多个加载器,通过加载器的配置可以对文件进行一系列的转换和处理操作。

Plugin

Plugin是Webpack中的一个功能模块,用于扩展和定制Webpack的构建过程。通过插件,在构建流程里注入钩子,可以实现各种功能需求,例如代码压缩、文件合并、文件分割、自动生成HTML文件等。它给 Webpack 带来了很大的灵活性。

使用 Plugin 的难点在于掌握Plugin 本身提供的配置项,而不是如何在 Webpack 中接入 Plugin。几乎所有 Webpack 无法直接实现的功能都能在社区找到开源的 Plugin 去解决,你需要善于使用搜索引擎去寻找解决问题的方法。Webpack有一个庞大的插件生态系统,开发者可以根据自己的需求选择合适的插件,或者自己开发插件来扩展Webpack的功能。

Plugin的作用是在Webpack的构建过程中执行一些额外的操作。插件可以通过在Webpack配置中实例化,并传入一些配置参数来使用。

Output

Output是Webpack中的一个配置项,配置如何输出最终想要的代码,用于指定构建后文件的输出路径和文件名。通过Output,可以将构建后的文件输出到指定的目录中。

Output 是一个 object,里面包含一系列配置项。例如:

  • output.filename:配置输出文件的名称,为string 类型。

  • Path:output.path 配置输出文件存放在本地的目录,必须是 string 类型的绝对路径。

  • publicPath:在复杂的项目里可能会有一些构建出的资源需要异步加载,加载这些异步资源需要对应的 URL 地址。

Output的作用是告诉Webpack构建后的文件应该输出到哪个目录,并指定输出文件的名称和格式。可以使用占位符来生成文件名,例如使用[hash]来生成带有哈希值的文件名,以便在文件内容变化时,可以通过改变文件名来实现缓存更新。

更多关于Vue前端相关技术点,敬请关注公众号:CTO Plus后续的发文,有问题欢迎后台留言交流。

图片

Webpack的启动流程

Webpack的启动流程可以分为以下几个步骤:

1. 解析配置文件:Webpack启动后,首先会读取并解析项目中的配置文件,通常是一个名为`webpack.config.js`的文件。在配置文件中,我们可以指定入口、出口、加载器、插件等各种配置项。

2. 解析入口文件:Webpack会根据配置文件中指定的入口文件路径,找到入口文件。入口文件是Webpack开始构建依赖图的起点,它会引入其他模块,形成一个依赖关系树。

3. 解析模块依赖:Webpack会递归地解析入口文件引入的模块,并找到它们的依赖关系。Webpack支持多种模块化规范,如CommonJS、AMD、ES6模块等。也就是从Entry里配置的Module开始递归解析Entry依赖的所有Module,每找到一个Module,就会根据配置的Loader去找出对应的转换规则,对Module进行转换后,再解析出当前Module依赖的Module;

4. 加载器转换:当Webpack遇到非JavaScript文件时,它会根据配置中的加载器进行转换。加载器可以将各种类型的文件转换为JavaScript模块,以便在浏览器中执行。

5. 代码打包:Webpack会将所有模块打包成一个或多个静态资源文件。在打包过程中,Webpack会根据配置中的规则对代码进行优化,例如代码压缩、文件合并、文件分割等。这些模块会以Entry为单位进行分组,一个Entry和其所有依赖的Module被分到一个组也就是一个Chunk;

6. 输出文件:最后,Webpack将打包后的文件输出到指定的目录中,也就是把所有Chunk转换成文件输出。输出的文件可以是JavaScript文件、CSS文件、图片文件等,具体的输出路径和文件名可以在配置文件中指定。在整个流程中Webpack会在恰当的时机执行Plugin里定义的逻辑。

大前端专栏

https://blog.csdn.net/zhouruifu2015/category_5734911

Vue专栏

https://blog.csdn.net/zhouruifu2015/category_6295339

Webpack的优缺点

Webpack作为一个功能强大的前端构建工具,具有以下优点:

1. 模块化支持:Webpack支持多种模块化规范,可以将代码拆分成多个模块,提高代码的可维护性和复用性。

2. 丰富的插件生态系统:Webpack有一个庞大的插件生态系统,可以通过插件来扩展和定制构建过程,实现各种功能需求。通过 Plugin 扩展,完整好用又不失灵活。

3. 代码分割和按需加载:Webpack支持代码分割,可以将应用程序的代码拆分成多个块,实现按需加载,提高页面加载速度和用户体验。

4. 开发者友好的调试工具:Webpack提供了强大的调试工具,可以帮助开发者定位和解决代码中的问题,提高开发效率。

5. 使用场景不仅限于 Web 开发。

6. 社区庞大活跃。

然而,Webpack也存在一些缺点:

1. 学习曲线较陡:Webpack的配置相对复杂,对于初学者来说,需要花费一定的时间来学习和理解其工作原理和配置方式。

2. 构建速度较慢:由于Webpack需要处理大量的模块和资源文件,所以在项目较大时,构建速度可能会比较慢。

3. 配置复杂:Webpack的配置文件中有许多选项和配置项,需要开发者具备一定的配置能力和经验。

大前端专栏

https://blog.csdn.net/zhouruifu2015/category_5734911

更多关于Vue前端相关技术点,敬请关注公众号:CTO Plus后续的发文,有问题欢迎后台留言交流。

图片

Webpack的使用

1. 安装Webpack

首先,在开始使用Webpack之前,我们需要先安装Webpack。可以使用npm命令安装Webpack,命令如下:

npm install webpack --save-dev

安装完成后,可以使用以下命令查看Webpack版本:

webpack -v

或者使用如下命令进行全局安装均可

npm install -g webpack webpack-cli

npm install -g webpack

npm install -g webpack-cli

2. 创建Webpack配置文件

Webpack需要一个配置文件来告诉它如何进行打包。我们可以在项目根目录下创建一个名为webpack.config.js的文件,并在其中配置Webpack。

javascript

const path = require('path');  //Node.js内置模块
module.exports = {  entry: './src/index.js',  //配置入口文件或main.js  output: {filename: 'bundle.js',   //输出文件//输出路径,__dirname:当前文件所在路径    path: path.resolve(__dirname, 'dist')  }};

在这个配置文件中,读取当前项目目录下src文件夹中的index.js(入口文件或main.js)内容,分析资源依赖,把相关的js文件打包。我们指定了入口文件和输出文件的路径。入口文件是src/index.js,输出文件是dist/bundle.js,即打包后的文件放入当前目录的dist文件夹下,打包后的js文件名为bundle.js

3. 编写代码

现在我们可以编写代码了。在src/index.js中,我们可以编写我们的应用代码。

javascript

function hello() {

    console.log('Hello, World!');

}

hello();

这段代码简单地打印了一个"Hello, World!"的消息。

4. 运行Webpack

现在我们可以使用Webpack进行打包了。在命令行中运行以下命令:

npx webpack

Webpack会读取我们的配置文件,并将我们的代码打包成一个名为bundle.js的文件,输出到dist目录下。

5. 在HTML中引入打包后的文件

最后,我们需要在HTML中引入打包后的文件。在index.html中,我们可以添加以下代码:

html

<!DOCTYPE html><html>  <head>    <meta charset="utf-8">    <title>Webpack Tutorial</title>  </head>  <body>    <script src="dist/bundle.js"></script>  </body></html>

这样,我们的应用就可以在浏览器中运行了。

6. 执行编译命令

webpack --mode=development

#执行后查看bundle.js 里面包含了上面两个js文件的内容并进行了代码打包

也可以配置项目的npm运行命令,修改package.json文件

"scripts": {    //...,    "dev": "webpack --mode=development",    "prod": "webpack --mode=production"}

运行npm命令执行打包与启动项目

npm run dev #开发打包

npm run prod #生产打包

图片

Webpack其他功能介绍

Webpack的使用非常简单,只需要在命令行中输入webpack命令即可。例如,如果要将一个index.js文件打包成bundle.js文件,可以使用以下命令:

webpack index.js bundle.js

Webpack会自动查找index.js文件所依赖的其他模块,并将它们打包成一个bundle.js文件。打包完成后,可以在HTML文件中引用该文件,例如:

<script src="bundle.js"></script>

Webpack还有许多其他功能,例如:

1. 使用配置文件

Webpack可以使用配置文件来配置打包的细节。可以创建一个webpack.config.js文件来配置Webpack,例如:

module.exports = {

entry: './index.js',

output: {

filename: 'bundle.js'

}

};

在命令行中输入webpack命令时,Webpack会自动读取webpack.config.js文件中的配置信息。

2. 使用插件

Webpack可以使用插件来扩展其功能。可以使用npm命令安装插件,然后在webpack.config.js文件中配置插件,例如:

const UglifyJSPlugin = require('uglifyjs-webpack-plugin'); module.exports = {    entry: './index.js',    output: {        filename: 'bundle.js'    },    plugins: [        new UglifyJSPlugin()    ]};

该配置会使用UglifyJSPlugin插件来压缩打包后的代码。

3. 使用loader

Webpack可以使用loader来处理各种类型的文件,例如CSS、图片等。可以使用npm命令安装loader,然后在webpack.config.js文件中配置loader,例如:

module.exports = {    entry: './index.js',    output: {        filename: 'bundle.js'    },    module: {        rules: [            {                test: /\.css$/,                use: ['style-loader', 'css-loader']            }        ]    }};

该配置会使用style-loader和css-loader来处理CSS文件。

以上就是Webpack的基本用法。当然,Webpack还有很多高级功能,例如使用插件来优化打包结果等等。如果您想深入了解可以参考官方文档介绍,或者关注公众号CTO Plus后续的文章。

图片

总结

Webpack是一个非常强大的模块打包工具,可以帮助我们实现代码的模块化、打包、压缩等功能。在使用Webpack时,可以使用命令行、配置文件、插件、loader等方式来实现不同的功能。希望本篇博客能够帮助大家更好地了解和使用Webpack。

参考资料

Github地址:https://github.com/webpack/webpack

服务配置:https://webpack.docschina.org/configuration/dev-server/

开发指南:https://webpack.docschina.org/guides/development/

大前端专栏

https://blog.csdn.net/zhouruifu2015/category_5734911.html

 更多精彩,关注我公号,一起学习、成长

图片

 

Vue推荐阅读:

  • Vue3进阶:弄清Vue2 和 Vue3的一些区别以及Vue.js和Node.js之间的关系

  • Vue进阶:Vue特点和优点介绍,以及开发环境搭建和构建Vue3.0项目的几种方法

推荐阅读:

  • 前端开发技术栈(工具篇):2023最新版nvm的Win/Linux安装和使用(详细) 27.8k stars

  • 前端开发技术栈(模板篇):10款较流行的前端后台管理系统模板

  • 50+款前端高效开发辅助工具总结

  • 开源项目 | Vue进阶:总结下日常开发中关于Vue的热门开源项目

  • 最热门的用于后台管理类产品开发的开源前端框架vue-element-admin-4.4.0的介绍和使用

工具类推荐阅读:

  • 《前端开发技术栈(工具篇):2023最新版nvm的Win/Linux安装和使用(详细)》

  • 《前端开发技术栈(工具篇):2023深入了解快速开发工具vite的安装和使用(详细)》

  • 《前端开发技术栈(工具篇):2023深入了解webpack的安装和使用以及核心概念和启动流程(详细)》

  • 《前端开发技术栈(工具篇):详细介绍npm、pnpm和cnpm分别是什么,使用方法以及之间有哪些关系》

  • 《前端开发技术栈(工具篇):Vue/Node.js项目构建和包管理器npm的使用以及命令详解》

  • 《前端开发技术栈(工具篇):Vite在项目中的一些实践以及vite和webpack的区别,为什么选择Vite》

  • 《Vite实战案例:构建快速、高效的现代前端项目》

  • 《Vue进阶:得心应手的开发体验-基于Pycharm的Vue3项目构建与开发环境搭建》

 

相关文章:

前端开发技术栈(工具篇):2023深入了解webpack的安装和使用以及核心概念和启动流程(详细) 63.3k stars

目录 Webpack简介 Entry Module Chunk Loader Plugin Output Webpack的启动流程 Webpack的优缺点 Webpack的使用 1. 安装Webpack 2. 创建Webpack配置文件 3. 编写代码 4. 运行Webpack 5. 在HTML中引入打包后的文件 6. 执行编译命令 Webpack其他功能介绍 1. 使…...

[SQL开发笔记]LIKE操作符:在 WHERE 子句中搜索列中的指定模式

一、功能描述&#xff1a; LIKE操作符&#xff1a;用于在 WHERE 子句中搜索列中的指定模式。 二、LIKE操作符语法详解&#xff1a; LIKE 语法 SELECT column1, column2,…FROM table_nameWHERE column LIKE pattern; 参数说明&#xff1a; &#xff08;1&#xff09;colum…...

flutter深研

https://www.douyin.com/video/7020336319058627853 关闭系统风扇 在 Windows 操作系统上安装和配置 Flutter 开发环境 - Flutter 中文文档 - Flutter 中文开发者网站 - Flutter...

TypeScript中的declare关键字

declare关键字 1. 简介 declare关键字用来告诉编译器&#xff0c;某个类型是存在的&#xff0c;可以在当前文件中使用。 作用&#xff1a;就是让当前文件可以使用其他文件声明的类型。比如&#xff0c;自己的脚本使用外部库定义的函数&#xff0c;编译器会因为不知道外部函数…...

玫瑰红葡萄酒的基本知识

在过去的几年里&#xff0c;玫瑰红葡萄酒越来越受欢迎&#xff0c;但是如果你是饮用玫瑰红葡萄酒的新手&#xff0c;你可能想知道它是如何从其他红葡萄酒或白葡萄酒中脱颖而出的。 玫瑰红具有标志性的粉色&#xff0c;很难归类&#xff0c;那它是更适合放在红酒类还是属于白酒…...

HTTP 协议参考文档

开发者Web协议文档&#xff1a; https://developer.mozilla.org/zh-CN/docs/Web 其中子节点包含 HTTP 协议内容&#xff1a; https://developer.mozilla.org/zh-CN/docs/Web/HTTP 其内容是基于 markdown 编写的&#xff0c;对应源文件在 Github 中&#xff0c;如下&#xf…...

Python遍历删除列表元素的一个奇怪bug

假定有一个Python列表&#xff0c;比如[CFFEX.IF, CFFEX.TS,SHFE.FU]&#xff0c;现在需要将其中带‘CFFEX’前缀的所有元素都删除。在使用列表推导式一行代码搞定之前&#xff0c;用了一种最朴素的遍历删除方法&#xff0c;结果出现了意想不到的的问题。复盘了下&#xff0c;结…...

Elasticsearch部署中的两大常见问题及其解决方案

随着大数据和实时搜索的日益普及&#xff0c;Elasticsearch已经成为现代应用中不可或缺的工具。但是&#xff0c;像所有软件一样&#xff0c;部署和配置Elasticsearch可能会遇到一些问题。本文将探讨两个我最近遇到的常见问题及其解决方案。 问题描述 1. 主机名解析问题 在启…...

【计网 CDN】计算机网络 CDN(Content Delivery Network)分布式网络架构详解:中科大郑烇老师笔记 (八)

目录 0 引言1 为什么需要分布式的网络架构&#xff1f;2 视频流化服务2.1 多媒体&#xff1a;视频2.2 存储视频的流化&#xff08;Streaming&#xff09;服务2.3 流媒体传输协议&#xff1a;DASH2.4 面临挑战&#xff1a;服务器如何向上百万用户同时提供视频流化内容&#xff1…...

C# 图解教程 第5版 —— 第9章 表达式和运算符

文章目录 9.1 表达式&#xff08;*&#xff09;9.2 字面量9.2.1 整数字面量9.2.2 实数字面量9.2.3 字符字面量9.2.4 字符串字面量 9.3 求值顺序9.3.1 优先级9.3.2 结合性 9.4 简单算术运算符9.5 求余运算符9.6 关系比较运算符和相等比较运算符9.7 递增运算符和递减运算符&#…...

TIA博途_Profinet通信故障诊断及常见错误解决方法汇总

TIA博途_Profinet通信故障诊断及常见错误解决方法汇总 1. 在线诊断报硬件组件的用户数据错误,设备组态不支持 解决方法: (1)检查模块终端盖板; (2)检查组态模块与实际组装模块顺序型号是否一致。 2. 网络视图,设备视图界面显示黑色感叹号 解决方法: PLC转离线,下载硬…...

Windows server部署filebeat到kafka

需求&#xff1a;Windows dhcp日志需要实时传输到elk或者其他告警平台。 1、filebeat下载地址&#xff1a;https://www.elastic.co/cn/downloads/beats/filebeat 2、下载后解压后配置filebeat.yml文件&#xff0c; 3、README.md文件中有运行的操作方法&#xff1a;cmd上进入f…...

Interview of ING internship for master thesis: LLM

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1. Background2. Interview2.1 Intro2.2 project experience2.3 问题2.4 Q&A 总结 Interview of ING internship for master thesis: LLM 1. Background Proje…...

华为校招第三题 找最小数

给你一个以字符串表示的非负整数 num 和一个整数 k &#xff0c;移除这个数中的 k 位数字&#xff0c;使得剩下的数字最小。请你以字符串形式返回这个最小的数字。 示例 1 &#xff1a; 输入&#xff1a;num "1432219", k 3 输出&#xff1a;"1219" 解…...

大数据Flink(一百零三):SQL 表值聚合函数(Table Aggregate Function)

文章目录 SQL 表值聚合函数(Table Aggregate Function) SQL 表值聚合函数(Table Aggregate Function) Python UDTAF,即 Python TableAggregateFunction。Python UDTAF 用来针对一组数据进行聚合运算,比如同一个 window 下的多条数据、或者同一个 key 下的多条数据等,与…...

php+JavaScript实现callback跨域请求jsonp数据

摘要 JSONP 是 JSON with Padding 的缩写&#xff0c;是一种解决跨域数据获取的方案。由于浏览器的同源策略限制&#xff0c;不同域名之间的前端JS代码不能相互访问到对方的数据&#xff0c;JSONP通过script标签的特性&#xff0c;实现在不同域名的网页间传递数据。 其原理是…...

荣电集团与钕希科技签署全面战略合作

10月26日&#xff0c;荣电集团&#xff08;以下简称荣电&#xff09;与钕希科技南京有限公司&#xff08;以下简称钕希科技&#xff09;今天在合肥市签署全面战略合作协议&#xff0c;联合进军混合现实&#xff08;Mixed Reality&#xff0c;以下简称MR&#xff09;空间计算高科…...

C语言_文件_进程_进程间通讯 常用函数/命令 + 实例

文件相关命令&#xff1a; ps -aux|grep init? //搜索包含init名称的进程 top //linux下的资源管理器&#xff08;动态&#xff09;//open 返回的int 是给后面的读/写/光标移动 用的fd&#xff0c;没有open就不能进行后面的操作&#xff1b; int op…...

力扣第406题 根据身高重建队列 c++ 贪心思维

题目 406. 根据身高重建队列 中等 相关标签 贪心 树状数组 线段树 数组 排序 假设有打乱顺序的一群人站成一个队列&#xff0c;数组 people 表示队列中一些人的属性&#xff08;不一定按顺序&#xff09;。每个 people[i] [hi, ki] 表示第 i 个人的身高为 hi &am…...

postgresSQL 数据库本地创建表空间读取本地备份SQL文件

使用pgAdmin4&#xff0c;你安装PG得文件夹****/16/paAdmin 4 /runtime/pgAdmin4.exe 第一步&#xff1a;找到Tablespaces 第二步&#xff1a;创建表空间名称 第三步&#xff1a;指向数据文件 第四步&#xff1a;找到Databases&#xff0c;创建表空间 第五步&#xff1a;输入数…...

贝锐花生壳内网穿透推出全新功能,远程业务连接更安全

贝锐旗下内网穿透兼动态域名解析品牌花生壳目前推出了全新的“访问控制”功能&#xff0c;可精确设置访问权限&#xff0c;充分保障信息安全&#xff0c;满足更多用户安全远程访问内网服务的需求。 通过这一功能&#xff0c;可实现指定时间、IP、地区等条件下才能远程访问映射的…...

NIO和BIO编程

一、网络通信编程基本常识 1、什么是Socket&#xff1f; Socket是应用层与TCP/IP协议族通信的中间软件抽象层&#xff0c;它是一组接口&#xff0c;一般由操作系统提供。 2、短连接 短连接是指socket建立连接之后传输数据确定接收完后关闭连接 3、长连接 长连接是指建立so…...

嵌入式系统设计师考试笔记之操作系统基础复习笔记二

目录 3、任务管理 &#xff08;1&#xff09;嵌入式操作系统的任务管理可以分为 &#xff08;2&#xff09;进程 &#xff08;3&#xff09;线程 &#xff08;4&#xff09;任务 &#xff08;5&#xff09;任务的创建与中止 &#xff08;6&#xff09;任务的状态任务有三…...

读图数据库实战笔记01_初识图

1. 图论 1.1. 起源于莱昂哈德欧拉在1736年发表的一篇关于“哥尼斯堡七桥问题”的论文 1.2. 要解决这个问题&#xff0c;该图需要零个或两个具有奇数连接的节点 1.3. 任何满足这一条件的图都被称为欧拉图 1.4. 如果路径只访问每条边一次&#xff0c;则该图具有欧拉路径 1.5…...

K-Means和KNN

主要区别 从无序 —> 有序 从K-Means —> KNN KNN&#xff1a;监督学习&#xff0c;类别是已知的&#xff0c;对已知分类的数据进行训练和学习&#xff0c;找到不同类的特征&#xff0c;再对未分类的数据进行分类。K-Means&#xff1a;无监督学习&#xff0c;事先不知道…...

【Python】【Flask】flask_login的初始化

【背景】 想要更高效地用现有的Flask_login包来实现用户管理方面的常用功能会话管理等。不想再手搓了。 【要点】 首先引入flask_login from flask_login import LoginManager, login_user, login_required, logout_user,current_user然后进行app级别的设置和初始化 login…...

Spring Cloud之API网关(Gateway)

目录 API网关 好处 解决方案 Gateway 简介 特征 核心概念 Route(路由) Predicate(断言) Filter(过滤器) 工作流程 Route(路由) 路由配置方式 1.yml配置文件路由 2.bean进行配置 3.动态路由 动态路由 Predicate(断言) 特点 常见断言 示例 Filter(过滤器) …...

nodejs+vue 电子书阅读系统

本文首先介绍了电子书阅读系统的发展背景与发展现状&#xff0c;然后遵循软件常规开发流程&#xff0c;首先针对系统选取适用的语言和开发平台&#xff0c;随着网络技术的不断发展&#xff0c;多媒体技术应用渐渐的出现在教育领域中&#xff0c;电子书阅读已经成为社会的一个热…...

百度文心一言4.0抢先体验教程!

&#x1f341; 展望&#xff1a;关注我, AI学习之旅上&#xff0c;我与您一同成长&#xff01; 一、 引言 想快速体验文心一言4.0&#xff0c;但又觉得技术难度太高&#xff1f;别担心&#xff0c;我来手把手教你&#xff01; &#x1f680; 10月17日&#xff0c;文心一言4.0…...

单目3D目标检测 方法综述——直接回归方法、基于深度信息方法、基于点云信息方法

本文综合整理单目3D目标检测的方法模型&#xff0c;包括&#xff1a;基于几何约束的直接回归方法&#xff0c;基于深度信息的方法&#xff0c;基于点云信息的方法。万字长文&#xff0c;慢慢阅读~ 直接回归方法 涉及到模型包括&#xff1a;MonoCon、MonoDLE、MonoFlex、CUPNet…...