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

前端构建工具 webpack 笔记

  • 1、了解 webpack 

1、定义:本质上,webpack 是一个用于现代 JavaScript 应用程序的静态模块打包工具,当 webpack 处理应用它会在内部从一个或多个入口点构建一个依赖图(dependency graph),然后将你项目中所程序时,需的每一个模块组合成一个或多个 bundles,它们均为静态资源,用于展示你的内容。

2、静态模块:指的是编写代码过程中的,html,css,js,图片等固定内容的文件

3、打包:把静态模块内容,压缩,整合,转译等(前端工程化)

        1)把 less / sass 转成 css 代码

        2)把 ES6+ 降级成 ES5

        3)支持多种模块标准语法

4、问题:为何不学 vite ?

        因为:很多项目还是基于 Webpack 构建,并为 Vue React 脚手架使用做铺垫!


  • 2、使用 webpack

1、需求:封装 utils 包,校验手机号长度和验证码长度,在 src/index.js 中使用并打包观察

2、步骤:

        1)新建并初始化项目,编写业务源代码

1、创建包管理文件:package.jsonnpm init -y2、编写业务代码 

        2)下载 webpack webpack-cli 到当前项目中(版本独立),并配置局部自定义命令

    Webpack是一个功能强大的模块打包工具,而Webpack-CLI则是用于在命令行中执行Webpack相关操作的工具。它们通常一起使用,以便更好地管理和构建前端项目。1、终端:npm i webpack webpack-cli --save-dev2、package.json:  [我们自定义一个命令 build,但是最终执行的是 webpack]"scripts": {"build":"webpack"}

        3)运行打包命令,自动产生 dist 分发文件夹(压缩和优化后,用于最终运行的代码)

    执行我们定义的命令,即执行了 webpack ,进行打包npm run build


  • 3、修改 Webpack 打包出入口

webpack 官方文档:概念 | webpack 中文文档 (docschina.org) 

1)项目根目录,新建 webpack.config.js 配置文件

2)导出配置对象,配置入口,出口文件的路径

1、下面是引入 path 模块 ,path.resolve作用是,把下面 __dirname (可得到当前绝对路径) 和后面的字符串,拼接成一个绝对路径

2、entry:配置需要打包文件的文件路径

3、output:配置打包后文件的存储显示路径

        1)这里的path.resolve第二参数是打包后输出的文件夹名称

        2)filename:配置打包后的文件名

        3)clean: true  生成打包后内容之前,清空原有的输出目录【和filename同位置】

3)重新打包观察 注意:只有和入口产生直接/间接的引入关系,才会被打包

执行命令,npm run build,最后输出如下图框中

4)打包后的 js 文件,例子如下【我用了自动换行,让你们看清楚】


  • 4、webpack 打包输出 index.html 文件

注意:前面我们打包的都是 js 文件,那么 html 文件怎么打包到 dist 文件夹里面呢?

官方网址指向HtmlWebpackPlugin | webpack 中文文档 (docschina.org)

1)安装对应的包

    npm install html-webpack-plugin --save-dev

2)在 webpack.config.js 中配置

3)重新打包观察

执行命令,npm run build,最后输出如下图框中

 4)打包后的 html 文件,例子如下【我用了自动换行,让你们看清楚】


  • 5、webpack 打包 css 代码 【js 文件中】

1、和 打包 html 文件一样,我们需要下载对应的包,用于 打包 该文件 到 【js 文件中】

        1)加载器 css-loader:解析 css 代码

        2)加载器 style-loader:把解析后的 css 代码插入到 DOM

2、注意:Webpack 默认只识别 js 代码

3、官方网址指向:

css-loader | webpack 中文文档 (docschina.org)

style-loader | webpack 中文文档 (docschina.org)

1)准备 css 文件代码引入到 src 文件夹中

2)准备 css 代码,并引入到 js 中 【没错,就是引入 js 文件中】

2)下载 css-loader 和 style-loader 本地软件包

  同时,下载两个加载器npm i css-loader style-loader --save-dev

3)配置 webpack.config.js 让 Webpack 拥有该加载器功能

module.exports = {module: {rules: [{// 匹配 css 文件,/i 就是 无论后缀大小写test: /\.css$/i,// 使用 这两个加载器,注意,它是从最后一个元素【这里是css-loader】开始使用,顺序不能改变use: ["style-loader", "css-loader"],},],},
};

4)重新打包观察

执行命令,npm run build,最后输出如下图框中【注意,下面是 js 文件】

最后 打包后页面 和 打包前页面 展示 一样


  • 6、webpack 打包 css 代码【css 文件中】

 1、下载对应的包,用于 打包 该文件 到【独立的 css 文件中】

        1)加载器 css-loader:解析 css 代码

        2)插件 mini-css-extract-plugin:提取 css 代码 【webpack5 才有】

2、注意:【mini-css-extract-plugin 不能和 style-loader 一起使用】

3、好处:css 文件可以被浏览器缓存,减少 js 文件体积

4、官方网址指向:

css-loader | webpack 中文文档 (docschina.org)

MiniCssExtractPlugin | webpack 中文文档 (docschina.org)

1、下载 mini-css-extract-plugin 本地软件包

    npm install mini-css-extract-plugin --save-dev

2、配置 webpack.config.js 让 Webpack 拥有该插件功能

const MiniCssExtractPlugin = require("mini-css-extract-plugin");module.exports = {plugins: [new MiniCssExtractPlugin()],module: {rules: [{test: /\.css$/i,// 注意:style-loader 和 MiniCssExtractPlugin.loader 不能同时使用// use: ['style-loader', "css-loader"],use: [MiniCssExtractPlugin.loader, "css-loader"],},],},
};

3、打包后观察效果

注意:执行命令,npm run build,这里 打包后 的 css 代码,还没有被压缩


  • 7、webpack 打包 css 代码【压缩 css 代码】

 1、下载对应的包,用于 打包 该文件 到【独立的 css 文件中】

        1)加载器 css-loader:解析 css 代码

        2)mini-css-extract-plugin:提取 css 代码 【webpack5 才有】

        3)css-minimizer-webpack-plugin :压缩 css 代码

2、注意:【mini-css-extract-plugin 不能和 style-loader 一起使用】

3、好处:css 文件可以被浏览器缓存,减少 js 文件体积

4、官方网址指向:

css-loader | webpack 中文文档 (docschina.org)

MiniCssExtractPlugin | webpack 中文文档 (docschina.org)​​​​​​

MiniCssExtractPlugin | webpack 中文文档 (docschina.org)  【这个是生产模式压缩】

1、下载 css-minimizer-webpack-plugin 本地软件包

    npm install css-minimizer-webpack-plugin --save-dev

2、配置 webpack.config.js 让 Webpack 拥有该插件功能

const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const CssMinimizerPlugin = require("css-minimizer-webpack-plugin");module.exports = {plugins: [new MiniCssExtractPlugin()],module: {rules: [{test: /.s?css$/,use: [MiniCssExtractPlugin.loader, "css-loader"],},],},optimization: {minimizer: [// 在 webpack@5 中,你可以使用 `...` 语法来扩展现有的 minimizer(即 `terser-webpack-plugin`)`...`, // 保留这个,就是使 js 代码打包后,还能压缩new CssMinimizerPlugin(),],}
};;

3、打包后观察效果

 注意:执行命令,npm run build,这里的 css 代码已经被压缩了


  • 8、webpack 打包 less 代码

 1、下载对应的包,用于 打包 该文件

        1)加载器 css-loader:解析 css 代码

        2)mini-css-extract-plugin:提取 css 代码 

        3)less less-loader:下载 less 和 less-loader 包

2、注意:【mini-css-extract-plugin 不能和 style-loader 一起使用】

3、官方网址指向:

css-loader | webpack 中文文档 (docschina.org)

MiniCssExtractPlugin | webpack 中文文档 (docschina.org)​​​​​​

less-loader | webpack 中文文档 (docschina.org)

1、下载 less less-loader 本地软件包

     npm install less less-loader --save-dev

2、新建 less 代码(设置背景图)并引入到 index.js 中 

3、配置 webpack.config.js 让 Webpack 拥有该插件功能

const MiniCssExtractPlugin = require("mini-css-extract-plugin");module.exports = {plugins: [new MiniCssExtractPlugin()],module: {rules: [{test: /\.less$/i,use: [MiniCssExtractPlugin.loade,'css-loader','less-loader',],},],},
};

4、打包后观察效果

 注意:执行命令,npm run build,因为用了mini-css-extract-plugin,最后,这段代码打包后,在输出的 css 文件中【注意:图片所在的文件夹也被打包到 dist 文件夹里面了】


  • 9、webpack 打包图片

资源模块:Webpack5 内置资源模块(字体,图片等)打包,无需额外 loader,无需下载包

官方网址指向:资源模块 | webpack 中文文档 (docschina.org)

1、配置 webpack.config.js 让 Webpack 拥有打包图片功能

  • 这个规则的作用是匹配以 .png.jpg.jpeg.gif 结尾的文件,并使用 asset 模块类型进行处理。
  • asset 模块类型是 webpack 5 引入的一种处理资源的方式,它会根据文件大小,自动决定是将文件转换为 Data URL (DataURL),还是将其复制到输出目录。 

1)占位符 【hash】对模块内容做算法计算,得到映射的数字字母组合的字符串

2)占位符 【ext】使用当前模块原本的占位符,例如:.png / .jpg 等字符串

3)占位符 【query】保留引入文件时代码中查询参数(只有 URL 下生效)

module.exports = {plugins: [new MiniCssExtractPlugin()],module: {rules: [...{test: /\.(png|jpg|jpeg|gif)$/i,type: 'asset',generator: {filename: 'assets/[hash][ext][query]'}}],},
};

2、打包后观察效果和区别

注意:判断临界值默认为 8KB

1)大于 8KB 文件:发送一个单独的文件并导出 URL 地址【打包输出图片】

2)小于 8KB 文件:导出一个 data URI(base64字符串)【打包后转为base64字符串】


  • 10、webpack 搭建开发环境

  • 问题:之前改代码,需重新打包才能运行查看,效率很低
  • 开发环境:配置 webpack-dev-server 快速开发应用程序
  • 作用:启动 Web 服务,自动检测代码变化,热更新到网页
  • 注意:dist 目录和打包内容是在内存里(更新快)【并非打包到根目录下
  • 官网地址指向:开发环境 | webpack 中文文档 (docschina.org)

1、下载 webpack-dev-server 软件包到当前项目

    npm i webpack-dev-server--save-dev

2、设置模式为开发模式,并配置自定义命令

3、使用 npm run dev 来启动开发服务器,试试热更新效果

  • 11、webpack 的 打包模式

打包模式:告知 Webpack 使用相应模式的内置优化

1、在 webpack.config.js 配置文件设置 mode 选项

2、在 package.json 命令行设置 mode 参数 

注意:命令行设置的 优先级 高于 配置文件中的,推荐用命令行设置 


  • 12、webpack 打包模式的应用

需求:在开发模式下用 style-loader 内嵌更快,在生产模式下提取 css 代码

方案1:webpack.config.js 配置导出函数,但是局限性大(只接受 2 种模式)

方案2:借助 cross-env (跨平台通用)包命令,设置参数区分环境

1、下载 cross-env 软件包到当前项目

    npm i cross-env --save-dev

2、配置自定义命令,传入参数名和值(会绑定到 process.env 对象下)

当你运行对应命令 npm run build 或者dev 时,根据 pageage.json 的 NODE_ENV=??,执行cross-env :固定NODE_ENV=production  :自定义的,也可以直接写 a=b,但是为了语义化点

3、在 webpack.config.js 区分不同环境使用不同配置 

process.env.NODE_ENV === 'development' ? 'style-loader' : MiniCssExtractPlugin.loaderprocess.env :固定的,通过这个调用 我们定义的值


  • 13、前端-注入环境变量 

  • 需求:前端项目中 index.js 中,开发模式下打印语句生效,生产模式下打印语句失效
  • 问题:cross-env 设置的只在 Node.js 环境生效,前端代码无法访问 process.env.NODE_ENV
  • 解决:使用 Webpack 内置的 DefinePlugin 插件
  • 作用:在编译时,将前端代码中匹配的变量名,替换为值或表达式

plugins: [new webpack.DefinePlugin({// 就是,在 前端项目 某个js文件 中,遇见 process.env.NODE_ENV 就赋值 给 模式对应的值'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV)})],

测试的结果:


  • 14、开发环境调错 - source map

  • 问题:代码被压缩和混淆,无法正确定位源代码位置(行数和列数)
  • source map可以准确追踪 error 和 warning 在原始代码的位置
  • 设置:webpack.config.js 配置 devtool 选项
  • inline-source-map 选项:把源码的位置信息一起打包在 js 文件内
  • 注意:source map 仅适于开发环境不要在生产环境使用(防止被轻易看源码位置)
  • 官网网址指向:Devtool | webpack 中文文档 (docschina.org)
const config = {...
}// 开发环境下使用 sourcemap 选项
if (process.env.NODE_ENV === 'development') {config.devtool = 'inline-source-map'
}module.exports = config

解决方法:下载 cross-env 软件包,根据 pageage.json 中设置的 环境变量,判断当前启动的是生产模式,还是开发模式


  • 15、解析别名 alias 【用 @ 来代表 src 绝对路径】

  • 解析别名:配置模块如何解析,创建 import 引入路径的别名,来确保模块引入变得更简单
  • 例如:原来路径如图,比较长而且相对路径不安全
  • 解决:在 webpack.config.js 中配置解析别名 @ 来代表 src 绝对路径
  • 官网网址指向:webpack 中文文档 (docschina.org)

module.exports = {//...resolve: {// __dirname 获取的是 webpack.config.js 所在文件夹的绝对路径'@': path.resolve(__dirname, 'src')},
};

  • 16、开发模式使用 npm 下载包 || 生产模式使用 CDN 引用

  • CDN定义:内容分发网络,指的是一组分布在各个地区的服务器
  • 作用:把静态资源文件/第三方库放在 CDN 网络中各个服务器中,供用户就近请求获取
  • 好处:减轻自己服务器请求压力,就近请求物理延迟低,配套缓存策略
  • cdn 引入网址:BootCDN - Bootstrap 中文网开源项目免费 CDN 加速服务

需求:开发模式使用本地第三方库,生产模式下使用 CDN 加载引入 

1、在 html 中引入第三方库的 CDN 地址 并用模板语法判断

下面这个是 htmlWebpackPlugin 规定的用法,我们后面在 options 定义 useCdn 的值 判断就行<% if(htmlWebpackPlugin.options.useCdn){ %><link href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/5.2.3/css/bootstrap.min.css" rel="stylesheet"><% } %>

2、配置 webpack.config.js 中 externals 外部扩展选项(防止某些 import 的包被打包

const config = {plugins: [new HtmlWebpackPlugin({useCdn: process.env.NODE_ENV === 'production', // 生产模式下使用 cdn 引入的地址}),]
}// 生产环境下使用相关配置
if (process.env.NODE_ENV === 'production') {// 外部扩展(让 webpack 防止 import 的包被打包进来)config.externals = {// key:import from 语句后面的字符串// value:留在原地的全局变量(最好和 cdn 在全局暴露的变量一致)'bootstrap/dist/css/bootstrap.min.css': 'bootstrap','axios': 'axios',}
}module.exports = config

3、两种模式下打包观察效果 


  • 17、webpack 多页面打包

 多页面:多个 html 文件,切换页面实现不同业务逻辑展示

相关文章:

前端构建工具 webpack 笔记

1、了解 webpack 1、定义&#xff1a;本质上&#xff0c;webpack 是一个用于现代 JavaScript 应用程序的静态模块打包工具&#xff0c;当 webpack 处理应用它会在内部从一个或多个入口点构建一个依赖图(dependency graph)&#xff0c;然后将你项目中所程序时&#xff0c;需的…...

.Net MVC 使用Areas后存在相同Controller时报错的解决办法; 从上下文获取请求的Area名及Controller名

先来说个额外的问题&#xff1a;如何在请求上下文&#xff08;比如过滤器的中&#xff09;获取请求对应的Area和Controller 名字&#xff1f;&#xff08;假设请求上下文对象为 filterContext &#xff09;&#xff1a; 1. 获取Area名: (string)filterContext.RouteData.DataTo…...

docker-compose部署etcd集群

1. docker-compose.yml cat > docker-compose.yml << EOF version: "3.0"networks:etcd-net: # 网络driver: bridge # 桥接模式volumes:etcd1_data: # 挂载到本地的数据卷名driver: localetcd2_data:driver: localetcd3_data:driver:…...

微信怎么定时发圈?

定时发圈的妙用 在合适的时间点发布新的产品、促销活动&#xff0c;不仅能够及时提醒用户品牌的存在&#xff0c;还可以引发用户的兴趣&#xff0c;增加品牌的曝光率。 选择最佳的发朋友圈时间段&#xff0c;以确保推广内容得到最大的曝光和关注&#xff0c;提高广告投放的效果…...

记录造数据测试接口

一、前言 在java开发中经常需要造数据进行测试接口&#xff0c;这里记录一下常用的通过造数据测试接口的方法。 二、一般的接口传参方式 1、接口的方式最好是使用JSON或者map的方式&#xff0c;这样的好处是传参可以灵活伸缩&#xff0c;返回的结果也最好是JSON或者map的方式…...

数据结构基础7:二叉树【链式结构】实现和递归思想。

二叉树的链式结构实现 一.二叉树链式结构的实现&#xff1a;1.前置说明&#xff1a;1.创建二叉树&#xff1a;2.二叉树的结构&#xff1a; 2.二叉树的遍历&#xff1a;1.二叉树的前中后序遍历&#xff1a;2.内容拓展&#xff1a; 二.二叉树链式(题目)题目一&#xff1a;计算节点…...

[.NET 6] IHostedService 的呼叫等等我的爱——等待Web应用准备就绪

📢欢迎点赞 :👍 收藏 ⭐留言 📝 如有错误敬请指正,赐人玫瑰,手留余香!📢本文作者:由webmote 原创📢作者格言:新的征程,我们面对的不是技术而是人心,人心不可测,海水不可量,唯有技术,才是深沉黑夜中的一座闪烁的灯塔 !序言 在这篇文章中,我将介绍如何等…...

基于jeecg-boot的flowable流程自定义业务退回撤回或驳回到发起人后的再次流程提交

更多nbcio-boot功能请看演示系统 gitee源代码地址 后端代码&#xff1a; https://gitee.com/nbacheng/nbcio-boot 前端代码&#xff1a;https://gitee.com/nbacheng/nbcio-vue.git 在线演示&#xff08;包括H5&#xff09; &#xff1a; http://122.227.135.243:9888 主要…...

python如何学习

功能如此强大、高效的Python&#xff0c;却非常的简单好学&#xff0c;这让学它的同学爱不释手&#xff0c;也让越来越多的互联网企业开始用Python来做主要的开发语言&#xff0c;比如谷歌、Facebook&#xff08;现Meta&#xff09;、豆瓣、知乎等知名互联网公司都在使用Python…...

Centos7更新php7.2版本升级

之前搭建的LNMP环境php使用yum安装的版本为7.2&#xff0c;现有项目wordpress安装wp插件需要php7.4版本的支持&#xff0c;需要在原来的环境更新php版本。 一、卸载php7.2 yum remove php*原先的安装方式是yum安装直接yum remove就可以卸载否则需要rpm命令查询&#xff0c;按…...

操作系统学习笔记---计算机系统概述

目录 概念 功能和目标 特征 并发 共享&#xff08;资源共享&#xff09; 虚拟 异步 发展与分类 手工操作阶段&#xff08;无OS&#xff09; 批处理阶段 单道批处理系统 多道批处理系统 分时操作系统 实时操作系统 网络操作系统 分布式计算机系统 个人计算机操…...

uniapp H5 navigateBack无法返回上一层级

项目场景&#xff1a; 提交表单后需要返回上一级 原因分析&#xff1a; H5在PC端打开&#xff0c;当前页面重新加载的情况下&#xff0c;出现navigateBack不能返回&#xff0c;由于H5端页面刷新后返回页面栈会消失 //提交 const handleSubmit async () > {form.value?.a…...

Android性能优化之应用瘦身(APK瘦身)

关于作者&#xff1a;CSDN内容合伙人、技术专家&#xff0c; 从零开始做日活千万级APP。 专注于分享各领域原创系列文章 &#xff0c;擅长java后端、移动开发、人工智能等&#xff0c;希望大家多多支持。 目录 一、导读二、概览2.1 apk组成 三、优化方向3.1 源代码3.1.1 代码混…...

C语言数组和指针笔试题(二)(一定要看)

目录 字符数组二例题1例题2例题3例题4例题5例题6例题7总结 字符数组三例题1例题2例题3例题4例题5例题6例题7 字符数组二 char arr[] {a,b,c,d,e,f} 1:printf("%d\n", strlen(arr)); 2:printf("%d\n", strlen(arr0)); 3:printf("%d\n", strlen(…...

uniapp——实现在线选座功能——技能提升

首先声明一点&#xff1a;下面的内容是从一个uniapp的程序中摘录的&#xff0c;并非本人所写&#xff0c;先做记录&#xff0c;以免后续遇到相似需求抓耳挠腮。 这里写目录标题 效果图代码——html部分cu-custom组件anil-seat组件 代码——jscss部分 效果图 代码——html部分 …...

领域驱动设计:微服务的各种边界

文章目录 演进式架构微服务还是小单体&#xff1f;微服务边界的作用 在用 DDD 进行微服务设计时&#xff0c;我们可以通过事件风暴来确定领域模型边界&#xff0c;划定微服务边界&#xff0c;定义业务和系统运行边界&#xff0c;从而保证微服务的单一职责和随需而变的架构演进能…...

MySQL之数据类型

目录 一、MySQL数据类型分类 二、数值类型 1、整数类型 2、bit类型 3、小数类型 三、字符串类型 1、char 2、varchar 3、char和varchar比较 四、日期和时间类型 五、enum和set 一、MySQL数据类型分类 MySQL 数据类型可以大致分为以下三类&#xff1a; 数值类型&#xff1a;用于…...

词法作用域改变词法作用域

一、词法作用域 1.定义&#xff1a; 为什么叫词法作用域&#xff1f;因为大部分标准语言编译器的第一个工作阶段叫作词法化&#xff0c;词法化的过程会对源代码中的字符进行检查&#xff0c;如果是有状态的解析过程&#xff0c;还会赋予单词语义。 简单来说&#xff0…...

关于C++的隐藏 (hidden),重载(overload),重写(override)小结。

关于隐藏 (hidden) 假如继承以后&#xff0c;子类出现父类同名函数&#xff0c; 即使参数的形式不同&#xff0c; 也会导致父类的函数隐藏&#xff0c; 不参与函数匹配&#xff0c;不能使用。 这个链接讲的不错。https://zhuanlan.zhihu.com/p/575423511 #include <iostrea…...

算法通关村18关 | 透析回溯的模板

回溯有清晰的解题模板&#xff0c; void backtracking(参数){if (终止条件){存放结果;return;}for (选择本层中的集合元素&#xff08;画成树&#xff0c;就是树节点孩子的大小) {处理节点;backtracking();回溯&#xff0c;撤销处理结果;}} 1. 从N叉树说起 在回溯之前&#x…...

【论文阅读】Untargeted Backdoor Attack Against Object Detection(针对目标检测的无目标后门攻击)

文章目录 一.论文信息二.论文内容0.摘要1.论文概述2.背景介绍3.作者贡献4.重点图表 一.论文信息 论文题目&#xff1a; Untargeted Backdoor Attack Against Object Detection&#xff08;针对目标检测的无目标后门攻击&#xff09; 发表年份&#xff1a; 2023-ICASSP&#x…...

分库分表---理论

目录 一、垂直切分 1、垂直分库 2、垂直分表 3、垂直切分优缺点 二、水平切分 1、水平分库 2、水平分表 3、水平切分优缺点 三、数据分片规则 1、Hash取模分表 2、数值Range分表 3、一致性Hash算法 四、分库分表带来的问题 1、分布式事务问题 2、跨节点关联查询…...

[golang 流媒体在线直播系统] 2.搭建基于golang的流媒体服务器实现拉流推流,以及Html客户端拉取hls类型的流

一.使用 Go 语言的开源框架Livego搭建流媒体服务器 1.Livego 框架的介绍 Go 语言拥有强大的 服务器性能 ,golang 在语言级别解决了 多进程并发 的问题,支持 多核 CPU均衡使用 ,支持 海量轻量级线程 ,所以非常适合做 流媒体服务器 .而 livego 是基于golang 开发的简单高效的…...

9月12日作业

作业代码 #include <iostream>using namespace std;class Shape { protected:double cir;double area; public://无参构造Shape() {cout<<"无参构造"<<endl;}//有参构造Shape(double c, double a):cir(c), area(a){cout<<"有参构造&quo…...

React框架下如何集成H.265网页流媒体视频播放器EasyPlayer.js?

H5无插件流媒体播放器EasyPlayer属于一款高效、精炼、稳定且免费的流媒体播放器&#xff0c;可支持多种流媒体协议播放&#xff0c;可支持H.264与H.265编码格式&#xff0c;性能稳定、播放流畅&#xff0c;能支持WebSocket-FLV、HTTP-FLV&#xff0c;HLS&#xff08;m3u8&#…...

《向量数据库》——向量数据库的使用场景有哪些?

向量数据库在许多应用领域都有广泛的用途,特别是那些需要存储、检索和分析向量数据的场景。以下是一些常见的向量数据库使用场景: 1、相似性搜索: 推荐系统:用于根据用户的历史行为或兴趣,搜索相似用户或物品,以提供个性化推荐。图像检索:允许用户通过图像查询相似的图像…...

Java 中 List 集合取补集

交集 Intersection 英 [ˌɪntəˈsekʃn] 并集 Union 英 [ˈjuːniən] 差集 difference of set 补集 complement set 英 [ˈkɒmplɪment] Java 中 List 集合取交集 Java 中 List 集合取并集 Java 中 List 集合取差集 Java 中 List 集合取补集 # 求两个集合交集的补集 List&l…...

我的个人网站——宏夏Coding上线啦

网站地址&#xff1a;宏夏Coding Github地址&#xff1a;&#x1f525;&#x1f525;宏夏coding网站&#xff0c;致力于为编程学习者、互联网求职者提供最需要的内容&#xff01;网站内容包括求职秘籍&#xff0c;葵花宝典&#xff08;学习笔记&#xff09;&#xff0c;资源推…...

【机器视觉】喇叭的外圆以及金属内圆的同心度视觉检测--康耐德智能

客户的需求 检测内容 喇叭的外圆以及金属内圆的同心度测量 检测要求 精度0.02mm&#xff0c;速度没要求&#xff0c;抽检产品。 评估 视觉可行性分析 对贵司的样品进行了光学实验&#xff0c;并进行图像处理&#xff0c;原则上可以使用机器视觉进行测试测量。 结果 对所有样…...

STM32WB55开发(2)----修改蓝牙地址

STM32WB55开发----2.修改蓝牙地址 概述硬件准备视频教学样品申请完整代码下载选择芯片型号配置时钟源配置时钟树RTC时钟配置查看开启STM32_WPAN条件配置HSEM配置IPCC配置RTC启动RF开启蓝牙设置工程信息工程文件设置修改置BLE设备公共地址Ble_Hci_Gap_Gatt_Init结果演示 概述 在…...

西安做网站找腾帆/外贸建站优化

二叉树的直径 思路①&#xff1a; 这种写法完全是基于递归的想法&#xff1a; 路径如果经过根节点&#xff0c;最长路径应该是左右子树高度之和。如果不经过&#xff0c;那么去看如果经过左子树的跟、经过右子树的根的最长长度。&#xff08;相同问题&#xff0c;递归解决&…...

廊坊网站制作潍坊公司电话/推广软文范例大全500

1.final修饰&#xff1a;数据、方法和类1) 修饰属性&#xff0c;表示属性【只能赋值一次】(1)基本类型&#xff1a;值不能被修改&#xff1b;(2)引用类型&#xff1a;引用不可以被修改2) 修饰方法&#xff0c;表示方法不可以重写&#xff0c;但是可以被子类访问(如果方法不是 p…...

网店seo排名优化/整站优化工具

这跟你是不是wmap没有关系的&#xff0c; wamp是一个集成环境&#xff0c;只是一次性帮你创建一个web服务器而已 下面给你些配置 一、登录Master服务器,修改my.ini ,添加如下内容&#xff1a; [wampmysqld]   #数据库ID号&#xff0c; 为1时表示为Master,其中master_id必须为…...

上海博道投资管理公司的网站谁做的/网站开发与设计

题目&#xff1a; 给定一个n个点m条边的有向图&#xff0c;点的编号是1到n&#xff0c;图中可能存在重边和自环。 请输出任意一个该有向图的拓扑序列&#xff0c;如果拓扑序列不存在&#xff0c;则输出-1。 若一个由图中所有点构成的序列A满足&#xff1a;对于图中的每条边(…...

网站怎样做的有吸引力/开发一个app价目表

dell的服务器网卡Broadcom Corporation NetXtreme II BCM5709 Gigabit Ethernet在负载高的情况下会出现无故中断&#xff0c;重启网卡就好了&#xff0c;必须要更新网卡驱动。果断升级网卡驱动。第一步: yum install kernel-devel #安装内核源码包第二步&#xff1a;驱动下载&a…...

nft制作网站/电商平台排行榜

这是因为中国的企业都没有长远的规划&#xff0c;或者说它们都不知道自己能生存多长时间,如此情况下谁会愿意冒险去尝试新的东西&#xff0c;即使是深圳科技企业其实同样不愿意尝试新的东西&#xff0c;你看它先后进入的手机、PC、服务器、云计算&#xff0c;哪个是它开拓出来的…...