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

工程化与框架系列(4)--Webpack 高级配置详解

Webpack 高级配置详解 🛠️

Webpack 是前端工程化中最流行的构建工具之一,掌握其高级配置可以帮助我们构建更高效、更优化的应用。本文将深入探讨Webpack的高级配置技巧和最佳实践。

Webpack 核心概念回顾 🌟

💡 小知识:Webpack 本质上是一个现代 JavaScript 应用程序的静态模块打包器。当 Webpack 处理应用程序时,它会递归地构建一个依赖关系图,其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle。

代码分割策略 📦

// 1. 基于入口的代码分割
class EntryPointSplitting {static createConfig() {return {entry: {main: './src/index.js',vendor: './src/vendor.js',admin: './src/admin.js'},output: {filename: '[name].[contenthash].js',path: path.resolve(__dirname, 'dist')},optimization: {runtimeChunk: 'single'}};}
}// 2. 动态导入
class DynamicImports {static asyncComponent() {return `// 路由级别的代码分割const UserProfile = () => import(/* webpackChunkName: "profile" */'./components/UserProfile');// 条件加载const loadAnalytics = () => {if (process.env.NODE_ENV === 'production') {import(/* webpackChunkName: "analytics" */ './analytics').then(module => module.default()).catch(err => console.error('Failed to load analytics:', err));}};`;}static preloadComponent() {return `// 预加载重要资源import(/* webpackChunkName: "important" *//* webpackPreload: true */'./important-module');// 预获取未来可能需要的资源import(/* webpackChunkName: "future" *//* webpackPrefetch: true */'./future-module');`;}
}// 3. SplitChunksPlugin 配置
class SplitChunksConfig {static getAdvancedConfig() {return {optimization: {splitChunks: {chunks: 'all',maxInitialRequests: Infinity,minSize: 20000,cacheGroups: {vendor: {test: /[\\/]node_modules[\\/]/,name(module) {// 获取npm包名 (例如:node_modules/packageName/...)const packageName = module.context.match(/[\\/]node_modules[\\/](.*?)([\\/]|$)/)[1];// npm包名转换为有效的文件名return `npm.${packageName.replace('@', '')}`;}},common: {name: 'common',minChunks: 2,priority: 10,reuseExistingChunk: true}}}}};}
}

模块联邦实现 🔗

// 1. 主应用配置
class ModuleFederationHost {static createConfig() {const deps = require('./package.json').dependencies;return {plugins: [new ModuleFederationPlugin({name: 'host',filename: 'remoteEntry.js',remotes: {app1: 'app1@http://localhost:3001/remoteEntry.js',app2: 'app2@http://localhost:3002/remoteEntry.js'},shared: {...deps,react: {singleton: true,requiredVersion: deps.react},'react-dom': {singleton: true,requiredVersion: deps['react-dom']}}})]};}static importRemoteModule() {return `// 动态加载远程模块const RemoteButton = React.lazy(() => import('app1/Button'));const App = () => (<div><h1>Host Application</h1><React.Suspense fallback="Loading Button..."><RemoteButton /></React.Suspense></div>);`;}
}// 2. 微前端模块配置
class ModuleFederationRemote {static createConfig() {const deps = require('./package.json').dependencies;return {plugins: [new ModuleFederationPlugin({name: 'app1',filename: 'remoteEntry.js',exposes: {'./Button': './src/components/Button','./Header': './src/components/Header','./API': './src/services/api'},shared: {...deps,react: {singleton: true,requiredVersion: deps.react},'react-dom': {singleton: true,requiredVersion: deps['react-dom']}}})]};}
}// 3. 共享模块高级配置
class SharedModulesAdvanced {static createConfig() {return {shared: {react: {singleton: true,requiredVersion: '^17.0.0',eager: true,strictVersion: true},moment: {singleton: false,requiredVersion: false,version: false,shareScope: 'default'},lodash: {shareKey: 'lodash',singleton: true,requiredVersion: '^4.17.21',eager: false}}};}
}

性能优化技术 ⚡

// 1. Tree Shaking 优化
class TreeShakingOptimizer {static configurePackageJson() {return {name: "my-project",version: "1.0.0",sideEffects: ["*.css","*.scss","./src/some-side-effectful-file.js"]};}static configureWebpack() {return {mode: 'production',optimization: {usedExports: true,sideEffects: true,providedExports: true,concatenateModules: true, // 模块合并minimize: true}};}static properModuleExport() {return `// 良好的tree-shaking友好导出export const add = (a, b) => a + b;export const subtract = (a, b) => a - b;export const multiply = (a, b) => a * b;export const divide = (a, b) => a / b;// 不友好的导出方式/*const utils = {add: (a, b) => a + b,subtract: (a, b) => a - b,multiply: (a, b) => a * b,divide: (a, b) => a / b};export default utils;*/`;}
}// 2. 缓存优化
class CachingOptimizer {static configureWebpack() {return {output: {filename: '[name].[contenthash].js',path: path.resolve(__dirname, 'dist'),chunkFilename: '[name].[contenthash].chunk.js',assetModuleFilename: 'assets/[hash][ext][query]'},optimization: {moduleIds: 'deterministic',runtimeChunk: 'single',splitChunks: {cacheGroups: {vendor: {test: /[\\/]node_modules[\\/]/,name: 'vendors',chunks: 'all'}}}}};}static configureTerser() {return {optimization: {minimizer: [new TerserPlugin({terserOptions: {compress: {drop_console: true,drop_debugger: true},format: {comments: false}},extractComments: false,parallel: true,cache: true})]}};}
}// 3. 构建性能优化
class BuildPerformanceOptimizer {static configureWebpack() {return {cache: {type: 'filesystem',buildDependencies: {config: [__filename]}},snapshot: {managedPaths: [/^(.+?[\\/]node_modules[\\/])/],immutablePaths: [/node_modules/],buildDependencies: {timestamp: true}},watchOptions: {aggregateTimeout: 300,poll: 1000,ignored: /node_modules/},stats: {chunks: false,modules: false,children: false,assets: true}};}static configureBundleAnalyzer() {return `const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;module.exports = {plugins: [new BundleAnalyzerPlugin({analyzerMode: 'static',reportFilename: 'bundle-report.html',openAnalyzer: false,generateStatsFile: true,statsFilename: 'bundle-stats.json'})]};`;}
}

高级加载器和插件 🔌

// 1. 自定义加载器
class CustomLoader {static createMarkdownLoader() {return `module.exports = function(source) {// 使loader可缓存this.cacheable && this.cacheable();// 异步处理const callback = this.async();// 处理 markdown 转换为 HTMLconst html = convertMarkdownToHtml(source);// 转换为模块导出const code = \`import React from 'react';export default function MarkdownContent() {return React.createElement('div', {dangerouslySetInnerHTML: { __html: ${JSON.stringify(html)} }});}\`;// 返回结果callback(null, code);};function convertMarkdownToHtml(markdown) {// 实现markdown到html的转换// 这里可以使用库如marked或showdownreturn "HTML content";}`;}static configureLoader() {return {module: {rules: [{test: /\.md$/,use: ['babel-loader',path.resolve('./loaders/markdown-loader.js')]}]}};}
}// 2. 自定义插件
class CustomPlugin {static createFileSizePlugin() {return `class FileSizePlugin {constructor(options = {}) {this.options = {outputFile: options.outputFile || 'file-sizes.json',warn: options.warn || false,warnLimit: options.warnLimit || 250 * 1024 // 250KB};}apply(compiler) {compiler.hooks.emit.tapAsync('FileSizePlugin',(compilation, callback) => {// 收集所有生成的文件大小信息const fileSizes = {};let totalSize = 0;for (const filename in compilation.assets) {const size = compilation.assets[filename].size();fileSizes[filename] = this.formatSize(size);totalSize += size;// 警告大文件if (this.options.warn && size > this.options.warnLimit) {console.warn(\`⚠️ Large file: \${filename} (\${this.formatSize(size)})\`);}}// 添加总大小fileSizes['total'] = this.formatSize(totalSize);// 创建输出文件const content = JSON.stringify(fileSizes, null, 2);compilation.assets[this.options.outputFile] = {source: () => content,size: () => content.length};callback();});}formatSize(bytes) {if (bytes < 1024) {return bytes + ' bytes';} else if (bytes < 1024 * 1024) {return (bytes / 1024).toFixed(2) + ' KB';} else {return (bytes / (1024 * 1024)).toFixed(2) + ' MB';}}}module.exports = FileSizePlugin;`;}static configurePlugin() {return `const FileSizePlugin = require('./plugins/file-size-plugin');module.exports = {plugins: [new FileSizePlugin({outputFile: 'file-sizes.json',warn: true,warnLimit: 300 * 1024 // 300KB})]};`;}
}// 3. 环境特定配置
class EnvironmentConfig {static createWebpackEnvConfig() {return `const { merge } = require('webpack-merge');const commonConfig = require('./webpack.common');module.exports = (envVars) => {const { mode } = envVars;const envConfig = require(\`./webpack.\${mode}\`);return merge(commonConfig, envConfig);};`;}static createEnvFiles() {return {common: `const path = require('path');const HtmlWebpackPlugin = require('html-webpack-plugin');module.exports = {entry: './src/index.js',output: {path: path.resolve(__dirname, 'dist'),filename: '[name].[contenthash].js',clean: true},module: {rules: [{test: /\.js$/,use: 'babel-loader',exclude: /node_modules/}]},plugins: [new HtmlWebpackPlugin({template: './public/index.html'})]};`,development: `const ReactRefreshWebpackPlugin = require('@pmmmwh/react-refresh-webpack-plugin');module.exports = {mode: 'development',devtool: 'eval-cheap-module-source-map',devServer: {hot: true,port: 3000,historyApiFallback: true},plugins: [new ReactRefreshWebpackPlugin()]};`,production: `const CssMinimizerPlugin = require('css-minimizer-webpack-plugin');const TerserPlugin = require('terser-webpack-plugin');module.exports = {mode: 'production',devtool: 'source-map',optimization: {minimizer: [new TerserPlugin(),new CssMinimizerPlugin()]},performance: {hints: 'warning',maxEntrypointSize: 512000,maxAssetSize: 512000}};`};}
}

Webpack 5 新特性 🚀

// 1. 资源模块
class AssetModules {static configureAssetModules() {return {module: {rules: [// 图片资源{test: /\.(png|jpg|jpeg|gif)$/i,type: 'asset',parser: {dataUrlCondition: {maxSize: 8 * 1024 // 8KB}},generator: {filename: 'images/[hash][ext][query]'}},// 字体资源{test: /\.(woff|woff2|eot|ttf|otf)$/i,type: 'asset/resource',generator: {filename: 'fonts/[hash][ext][query]'}},// SVG资源{test: /\.svg$/i,oneOf: [{// 针对SVG React组件resourceQuery: /react/,use: ['@svgr/webpack']},{// 普通SVG资源type: 'asset/resource',generator: {filename: 'icons/[hash][ext][query]'}}]}]}};}static assetUsageExample() {return `// 图片资源import logo from './assets/logo.png';document.getElementById('logo').src = logo;// SVG React组件import { ReactComponent as Logo } from './assets/logo.svg?react';function Header() {return <Logo width={50} height={50} />;}// 字体资源import './assets/fonts/opensans.woff2';`;}
}// 2. 持久缓存
class PersistentCache {static configureCache() {return {cache: {type: 'filesystem',version: '1.0',cacheDirectory: path.resolve(__dirname, '.temp_cache'),name: 'my-project-cache',buildDependencies: {config: [__filename]},compression: 'gzip'}};}static setupMaxAge() {return {cache: {type: 'filesystem',maxAge: 5184000000, // 60 days in millisecondsmaxMemoryGenerations: 1}};}
}// 3. 实验性功能
class ExperimentalFeatures {static enableExperiments() {return {experiments: {asyncWebAssembly: true,topLevelAwait: true,outputModule: true,lazyCompilation: {entries: false,imports: true}}};}static topLevelAwaitExample() {return `// 顶级 await(不需要包装在 async 函数中)const response = await fetch('https://api.example.com/data');const data = await response.json();export default data;`;}static webAssemblyExample() {return `// 异步WebAssembly加载async function loadWasm() {const wasm = await import('./module.wasm');return wasm;}// 使用loadWasm().then(module => {module.exports.someFunction();});`;}
}

Webpack分析与调试 🔍

// 1. 构建分析
class BuildAnalysis {static configureStatsPreset() {return {stats: {preset: 'errors-warnings',assets: true,colors: true,timings: true,performance: true,optimizationBailout: true}};}static configureAnalyzerPlugin() {return `const { BundleAnalyzerPlugin } = require('webpack-bundle-analyzer');module.exports = {plugins: [new BundleAnalyzerPlugin({analyzerMode: process.env.ANALYZE ? 'server' : 'disabled',analyzerHost: '127.0.0.1',analyzerPort: 8888,reportFilename: 'bundle-report.html',openAnalyzer: true,generateStatsFile: true,statsFilename: 'stats.json',statsOptions: {source: false,reasons: true},excludeAssets: [/\.map$/]})]};`;}static configureSpeedMeasurePlugin() {return `const SpeedMeasurePlugin = require('speed-measure-webpack-plugin');const smp = new SpeedMeasurePlugin();// 包装整个webpack配置module.exports = smp.wrap({// 常规webpack配置...});`;}
}// 2. 调试技巧
class WebpackDebugging {static profileConfig() {return `module.exports = {// ...其他配置profile: true};`;}static traceConfig() {return `// 命令行使用示例// webpack --trace-deprecation// webpack --trace-warnings// webpack --trace`;}static inspectConfig() {return `// 检查配置const { inspect } = require('util');module.exports = (env, argv) => {const config = {// ...正常配置};// 输出最终配置到控制台console.log(inspect(config, { depth: null, colors: true }));return config;};`;}
}

高级优化策略 💎

// 1. 懒加载优化
class LazyLoadingOptimization {static routeLevelCodeSplitting() {return `// React Router 懒加载import React, { lazy, Suspense } from 'react';import { BrowserRouter as Router, Route, Switch } from 'react-router-dom';// 懒加载路由组件const Home = lazy(() => import(/* webpackChunkName: "home" */ './pages/Home'));const About = lazy(() => import(/* webpackChunkName: "about" */ './pages/About'));const Dashboard = lazy(() => import(/* webpackChunkName: "dashboard" */ './pages/Dashboard'));function App() {return (<Router><Suspense fallback={<div>Loading...</div>}><Switch><Route exact path="/" component={Home} /><Route path="/about" component={About} /><Route path="/dashboard" component={Dashboard} /></Switch></Suspense></Router>);}`;}static componentLevelCodeSplitting() {return `// 组件级懒加载import React, { lazy, Suspense, useState } from 'react';// 懒加载重型组件const HeavyChart = lazy(() => import(/* webpackChunkName: "heavy-chart" */ './components/HeavyChart'));function Dashboard() {const [showChart, setShowChart] = useState(false);return (<div><h1>Dashboard</h1><button onClick={() => setShowChart(true)}>Load Chart</button>{showChart && (<Suspense fallback={<div>Loading chart...</div>}><HeavyChart /></Suspense>)}</div>);}`;}
}// 2. 线上部署优化
class DeploymentOptimization {static configureOutput() {return {output: {filename: '[name].[contenthash].js',chunkFilename: '[name].[contenthash].chunk.js',path: path.resolve(__dirname, 'dist'),publicPath: 'https://cdn.example.com/',crossOriginLoading: 'anonymous'}};}static configureSecurity() {return {output: {trustedTypes: true,crossOriginLoading: 'anonymous'},devtool: false, // 生产环境禁用源代码映射plugins: [new webpack.ids.HashedModuleIdsPlugin(), // 稳定模块IDnew webpack.DefinePlugin({'process.env.NODE_ENV': JSON.stringify('production'),'process.env.API_URL': JSON.stringify('https://api.example.com')})]};}static configureCompression() {return `const CompressionPlugin = require('compression-webpack-plugin');const zlib = require('zlib');module.exports = {plugins: [// Gzip压缩new CompressionPlugin({filename: '[path][base].gz',algorithm: 'gzip',test: /\.(js|css|html|svg)$/,threshold: 10240, // 只处理大于10KB的资源minRatio: 0.8 // 只有压缩率小于0.8的资源才会被处理}),// Brotli压缩(更高压缩率)new CompressionPlugin({filename: '[path][base].br',algorithm: 'brotliCompress',test: /\.(js|css|html|svg)$/,compressionOptions: {params: {[zlib.constants.BROTLI_PARAM_QUALITY]: 11}},threshold: 10240,minRatio: 0.8})]};`;}
}

结语 📝

Webpack的高级配置能够帮助我们构建更高效、更优化的前端应用。我们学习了:

  1. 代码分割策略和动态导入
  2. 模块联邦实现微前端架构
  3. 性能优化技术如Tree Shaking和缓存优化
  4. 自定义加载器和插件开发
  5. Webpack 5的新特性
  6. 构建分析与调试技巧
  7. 高级优化策略和部署配置

💡 学习建议:

  1. 逐步应用这些高级特性,不要一次性应用所有优化
  2. 使用分析工具监控优化效果
  3. 根据项目需求选择合适的配置
  4. 持续关注Webpack的更新和新特性
  5. 参考成熟项目的Webpack配置学习最佳实践

如果你觉得这篇文章有帮助,欢迎点赞收藏,也期待在评论区看到你的想法和建议!👇

终身学习,共同成长。

咱们下一期见

💻

相关文章:

工程化与框架系列(4)--Webpack 高级配置详解

Webpack 高级配置详解 &#x1f6e0;️ Webpack 是前端工程化中最流行的构建工具之一&#xff0c;掌握其高级配置可以帮助我们构建更高效、更优化的应用。本文将深入探讨Webpack的高级配置技巧和最佳实践。 Webpack 核心概念回顾 &#x1f31f; &#x1f4a1; 小知识&#xf…...

Let‘s Encrypt免费证书的应用示例

文章目录 前言证书申请证书介绍cert.pemchain.pemfullchain.pemprivkey.pem 使用步骤搭建简易demo应用新建nginx配置文件测试SSL是否生效 总结 前言 最近在搞苹果应用上架的问题&#xff0c;据说用HTTP会被拒&#xff0c;但貌似不绝对&#xff0c;2017年苹果曾发公告说必须要求…...

线性模型 - 支持向量机

支持向量机&#xff08;SVM&#xff09;是一种用于分类&#xff08;和回归&#xff09;的监督学习算法&#xff0c;其主要目标是找到一个最佳决策超平面&#xff0c;将数据点分为不同的类别&#xff0c;并且使得分类边界与最近的数据点之间的间隔&#xff08;margin&#xff09…...

455. 分发饼干(LeetCode)

题目来源&#xff1a; 455. 分发饼干 - 力扣&#xff08;LeetCode&#xff09; 题目内容&#xff1a; 假设你是一位很棒的家长&#xff0c;想要给你的孩子们一些小饼干。但是&#xff0c;每个孩子最多只能给一块饼干。 对每个孩子 i&#xff0c;都有一个胃口值 g[i]&#xf…...

Harmony os next~鸿蒙应用开发入门教程

鸿蒙应用开发入门教程 基础准备与环境搭建 1. 了解鸿蒙系统 1.1 核心理念学习 HarmonyOS&#xff08;鸿蒙系统&#xff09;是华为推出的全场景分布式操作系统&#xff0c;其核心特点如下&#xff1a; 分布式能力 设备协同&#xff1a;手机、平板、智能手表、IoT设备等可无…...

数据库数据恢复—SQL Server附加数据库报错“错误 823”怎么办?

SQL Server数据库附加数据库过程中比较常见的报错是“错误 823”&#xff0c;附加数据库失败。 如果数据库有备份则只需还原备份即可。但是如果没有备份&#xff0c;备份时间太久&#xff0c;或者其他原因导致备份不可用&#xff0c;那么就需要通过专业手段对数据库进行数据恢复…...

树莓派安装ros docker

系统&#xff1a;bookworm或者ubuntu24都行 一、下载docker和拉取ros:noetic镜像 ubuntu 用鱼香ros脚本安装docker并拉取ros:noetic镜像&#xff1a; https://fishros.org.cn/forum/topic/20/小鱼的一键安装系列 wget http://fishros.com/install -O fishros && . …...

MyBatis-Plus 自动填充功能

MyBatis-Plus&#xff08;MP&#xff09; 提供了一个非常强大的功能——自动填充功能。该功能可以在执行插入或更新操作时&#xff0c;自动为某些字段赋值&#xff0c;免去手动设置这些字段的麻烦。常见的应用场景包括 创建时间 和 更新时间 字段的自动填充&#xff0c;帮助开发…...

折半搜索笔记

前言 01 01 01 爆搜的时间复杂度通常为 O ( 2 n ) O(2^n) O(2n)&#xff0c;只能应付 N N N 为 20 20 20 左右的题目&#xff0c;但是折半搜索可以应付 N N N 为 30 30 30 ~ 40 40 40 的题目。 思想 将 N N N 个数分为前后两半&#xff0c;先搜索前一半的状态&#xf…...

vue 项目部署到nginx 服务器

一 vue 项目打包 1 本地环境 npm run build 2 打包完成生成一个dist 文件夹&#xff0c;将其放到服务器指定的文件夹&#xff0c;此文件夹可以在nginx 配置文件中配置 二 nginx 1 根据对应的系统搜索安装命令 sudo yum install nginx 2 查看conf位置 如果不知道的话 ng…...

JavaWeb基础专项复习6——AJAX

系列文章目录 1、JavaWeb基础专项复习1——XML文件-CSDN博客 2、JavaWeb基础专项复习2——JSP文件-CSDN博客 3、JavaWeb基础专项复习2——Servlet相关知识-CSDN博客 4、JavaWeb基础专项复习4——会话对象Session and Cookie-CSDN博客 5、JavaWeb基础专项复习5——请求对象…...

RabbitMQ快速入门

目录 MQ简介 1、同步通信 图片 2、异步通信 图片 RabbitMQ快速上手 基本介绍&#xff1a; Producer和Consumer Connection和Channel Virtual host Queue Exchange 工作流程 AMQP Java编写RabbitMQ生产者消费者 生产者 1.建立连接 2.开启信道 3.声明交换机 4.声…...

内存中的缓存区

在 Java 的 I/O 流设计中&#xff0c;BufferedInputStream 和 BufferedOutputStream 的“缓冲区”是 内存中的缓存区&#xff08;具体是 JVM 堆内存的一部分&#xff09;&#xff0c;但它们的作用是优化数据的传输效率&#xff0c;并不是直接操作硬盘和内存之间的缓存。以下是详…...

快速列出MS Word中所有可用字体

Word中有很多字体&#xff0c;虽然在字体下拉列表中提供了字体的样例&#xff0c;但是并不全面&#xff0c;例如使用Batang字体的话&#xff0c;数字会显示成什么效果&#xff0c;就无法直观的看到。 打开Word应用程序&#xff0c;新建一个空白文档&#xff0c;按AltF11打开VBE…...

《机器学习数学基础》补充资料:矩阵的LU分解

本文是对《机器学习数学基础》第2章2.3.3节矩阵LU分解的拓展。 判断是否可LU分解 并非所有矩阵都可以实现LU分解。 定理1&#xff1a; 若 n n n 阶可逆矩阵 A \pmb{A} A 可以进行LU分解&#xff0c;则 A \pmb{A} A 的 k k k 阶顺序主子阵&#xff08;leading principal s…...

seasms v9 注入漏洞 + order by注入+​information_schema​解决方法

目录 一、当注入时&#xff0c;information_schema被禁用的解决方法 1.通过sys库可以获取到表名和库名 2.通过无列名注入join获取列名 二、seasms v9 注入漏洞 三、order by注入 一、当注入时&#xff0c;information_schema被禁用的解决方法 information_schema数据库是My…...

跨端方案选型:对比Uni-app与Taro在复杂电商项目中的技术选型依据参考

跨端方案选型:对比Uni-app与Taro在复杂电商项目中的技术选型依据参考 请赏析: Uni-app与Taro复杂电商项目选型对比指南 一、核心选型维度速记 技术栈匹配 → 跨端能力 → 性能优化 → 开发效率 → 生态支持 → 长期维护二、关键维度对比分析 1. 技术栈匹配性 框架技术栈适…...

C语言32个关键字

32个关键字 1.基本数据类型 signed unsigned char int float double short long void 2.构造数据类型 struct union enum 3.数据存储类别 auto static extern register 4.数据优化 const volatile 5. 9条基本语句 if else switch case break default while do for…...

音乐游戏Drummania(GITADORA)模拟器

文章目录 &#xff08;一&#xff09;Drummania和GITADORA&#xff08;1.1&#xff09;基本情况&#xff08;1.2&#xff09;机体 &#xff08;二&#xff09;模拟器&#xff08;2.1&#xff09;主程序&#xff08;2.2&#xff09;模拟器主题 &#xff08;三&#xff09;曲谱文…...

WPF中对滚动条进行平滑滚动

有时候我们在动态添加内容时&#xff0c;需要将滚动条滚动到指定内容处。 一般我们会调用ScrollViewer的ScrollToVerticalOffset&#xff08;垂直方向&#xff09;函数和ScrollToHorizontalOffset&#xff08;水平方向&#xff09;函数来控制滚动条滚动到指定位置。 正常滚动效…...

【通俗讲解电子电路】——从零开始理解生活中的电路(一)

导言&#xff1a;电子电路为什么重要&#xff1f; ——看不见的“魔法”&#xff0c;如何驱动你的生活&#xff1f; 清晨&#xff0c;当你的手机闹钟响起时&#xff0c;你可能不会想到&#xff0c;是电子电路在精准控制着时间的跳动&#xff1b;当你用微波炉加热早餐时&#…...

达梦:内存相关参数

目录 28个相关参数1. 内存池相关MEMORY_POOLMEMORY_N_POOLSMEMORY_BAK_POOL 2. 大缓冲区相关HUGE_BUFFERHUGE_BUFFER_POOLS 3. 共享缓冲区相关BUFFERBUFFER_POOLSBUFFER_MODEMAX_BUFFER 4. 快速池相关FAST_POOL_PAGES 5. 回收池相关RECYCLE_POOLS 6. 回滚段池相关ROLLSEG_POOLS…...

MySql面试总结(一)

mysql中排序是怎么实现的? MySQL 中的排序主要通过ORDER BY子句来实现,其底层实现方式有文件排序和索引排序两种,以下是具体介绍: 通过ORDER BY子句实现排序 这是 MySQL 中进行排序的基本方式,语法为SELECT column1, column2,... FROM table_name ORDER BY column_name…...

YOLOv5 + SE注意力机制:提升目标检测性能的实践

一、引言 目标检测是计算机视觉领域的一个重要任务&#xff0c;广泛应用于自动驾驶、安防监控、工业检测等领域。YOLOv5作为YOLO系列的最新版本&#xff0c;以其高效性和准确性在实际应用中表现出色。然而&#xff0c;随着应用场景的复杂化&#xff0c;传统的卷积神经网络在处…...

第十四届蓝桥杯大赛软件赛国赛C/C++大学C组

A 【跑步计划——日期问题】-CSDN博客 B 【残缺的数字】-CSDN博客 C 题目 代码 #include <bits/stdc.h> using namespace std;void change(int &x) {int sum 0, t x;while(t){sum t % 10;t / 10;}x - sum; } int main() {int n;cin >> n;int ans 0;…...

【备份】php项目处理跨域请求踩坑

这都是老生常谈的东西了。我还在踩坑&#xff0c;记录一下。 我在项目入口明明写了如下代码&#xff1a; // 处理预检请求 (OPTIONS) if ($_SERVER[REQUEST_METHOD] OPTIONS) {header("Access-Control-Allow-Origin: https://xxx.vip");header("Access-Cont…...

编程题 - 汽水瓶【JavaScript/Node.js解法】

‌“学如逆水行舟&#xff0c;不进则退。”‌ ——《增广贤文》 目录 汽水瓶 题目&#xff1a;解答分析&#xff1a;js代码解答 -ACM模式&#xff1a;代码通过&#xff1a;题解分析&#xff1a;简洁思路代码&#xff1a; 汽水瓶 题目&#xff1a; 某商店规定&#xff1a;三个空…...

【考研】复试相关上机题目

文章目录 22机试回忆版1、判断燃气费描述输入格式输出格式输入样例输出样例 C o d e Code Code 2、统计闰年数量描述输入格式输出格式输入样例输出样例 C o d e Code Code 3、打印图形描述输入格式输出格式 C o d e Code Code 4、密文数据描述输入格式输出格式输入样例输出样例…...

HONOR荣耀MagicBook 15 2021款 独显(BOD-WXX9,BDR-WFH9HN)原厂Win10系统

适用型号&#xff1a;【BOD-WXX9】 MagicBook 15 2021款 i7 独显 MX450 16GB512GB (BDR-WFE9HN) MagicBook 15 2021款 i5 独显 MX450 16GB512GB (BDR-WFH9HN) MagicBook 15 2021款 i5 集显 16GB512GB (BDR-WFH9HN) 链接&#xff1a;https://pan.baidu.com/s/1S6L57ADS18fnJZ1…...

微信小程序:完善购物车功能,购物车主页面展示,详细页面展示效果

一、效果图 1、主页面 根据物品信息进行菜单分类&#xff0c;点击单项购物车图标添加至购物车&#xff0c;记录总购物车数量 2、购物车详情页 根据主页面选择的项&#xff0c;根据后台查询展示到页面&#xff0c;可进行多选&#xff0c;数量加减等 二、代码 1、主页面 页…...

Spring Boot集成MyBatis访问MySQL:从项目搭建到基础数据库查询(基础入门)

Spring Boot集成MyBatis访问MySQL 一、引言 在当今企业级应用开发中&#xff0c;Spring Boot、MyBatis与MySQL的组合凭借其高效性和灵活性&#xff0c;成为构建数据驱动型应用的首选方案。本文将带你从零开始搭建项目&#xff0c;掌握Spring Boot集成MyBatis的基础入门内容。…...

基于STM32的智能家居能源管理系统

1. 引言 传统家庭能源管理存在能耗监控粗放、设备联动不足等问题&#xff0c;难以适应绿色低碳发展需求。本文设计了一款基于STM32的智能家居能源管理系统&#xff0c;通过多源能耗监测、负荷预测与优化调度技术&#xff0c;实现家庭能源的精细化管理与智能优化&#xff0c;提…...

OpenAI发布GPT-4.5:功能非常特殊,推理很贵

今天凌晨4点&#xff0c;OpenAI进行了在线技术直播&#xff0c;发布了最新模型GPT-4.5。 GPT-4.5与之前的模型相比&#xff0c;本次最大的亮点是加上了“情商”&#xff0c;这也是目前所有大模型最缺、最难的功能。 此外&#xff0c;GPT-4.5 在SimpleQA上的测试数据显示&…...

DeepSeek开源周 Day04:从DualPipe聊聊大模型分布式训练的并行策略

DualPipe简介 今天是DeepSeek开源周的第四天&#xff0c;官方开源了一种新型并行计算优化策略——DualPipe。 其实大家阅读过Deepseek-V3技术报告的同学&#xff0c;对这个技术并不陌生。 开源地址&#xff1a;https://github.com/deepseek-ai/DualPipe 核心亮点 DualPipe&…...

RabbitMQ系列(七)基本概念之Channel

RabbitMQ 中的 Channel&#xff08;信道&#xff09; 是客户端与 RabbitMQ 服务器通信的虚拟会话通道&#xff0c;其核心作用在于优化资源利用并提升消息处理效率。以下是其核心机制与功能的详细解析&#xff1a; 一、Channel 的核心定义 虚拟通信链路 Channel 是建立在 TCP 连…...

LeetCode 热题 100_有效的括号(69_20_简单_C++)(栈;栈+哈希表(建立左右括号的对应关系))

LeetCode 热题 100_有效的括号&#xff08;69_20&#xff09; 题目描述&#xff1a;输入输出样例&#xff1a;题解&#xff1a;解题思路&#xff1a;思路一&#xff08;栈&#xff09;&#xff1a;思路二&#xff08;栈哈希表&#xff08;建立左右括号的对应关系&#xff09;&a…...

c#-LINQ与lambda表达式学习笔记

https://blog.csdn.net/m0_56259289/article/details/144134122 static void Main(string[] args) //程序入口{int[] arr1 new int[] { 1, 2, 3, 4, 5, 6, 7 };int[] arr2 new int[] { 1, 2, 3, 4, 5, 6, 7 };var query1 from n in arr1 select n;var query2 from a in arr…...

数据库基础二(数据库安装配置)

打开MySQL官网进行安装包的下载 https://www.mysql.com/ 接着找到适用于windows的版本 下载版本 直接点击下载即可 接下来对应的内容分别是&#xff1a; 1&#xff1a;安装所有 MySQL 数据库需要的产品&#xff1b; 2&#xff1a;仅使用 MySQL 数据库的服务器&#xff1b; 3&a…...

Word 插入图片会到文字底下解决方案

一、现象描述 正常情况下&#xff0c;我们插入图片都是这样的。 但有时突然会这样&#xff0c;插入的图片陷于文字底部。 二、网上解决方案 网上有教程说&#xff0c;修改图片布局选项&#xff0c;从嵌入型改成上下型环绕。改完之后确实有用&#xff0c;但是需要手动拖动图片…...

有没有什么免费的AI工具可以帮忙做简单的ppt?

互联网各领域资料分享专区(不定期更新): Sheet 正文 1. 博思AIPPT 特点:专为中文用户设计,支持文本/文件导入生成PPT,内置海量模板和智能排版功能,涵盖商务、教育等多种场景。可一键优化布局、配色,并集成AI绘图功能(文生图/图生图)。适用场景:职场汇报、教育培训、商…...

实战-使用 Playbook 批量部署多台 LAMP 环境

实战-使用 Playbook 批量部署多台 LAMP 环境 playbooks 使用步骤 playbook 是一个不同于使用 ansible 命令行执行方式的模式&#xff0c;功能更强大更灵活。 1、在 playbooks 中定义任务&#xff1a; - name&#xff1a; task description #任务描述信息 module_name: modul…...

CSS—引入方式、选择器、复合选择器、文字控制属性、CSS特性

目录 CSS 1.引入方式 2.选择器 3.复合选择器 4.文字控制属性 5.CSS特性 CSS 层叠样式表&#xff0c;是一种样式表语言&#xff0c;用来描述HTML文档的呈现 书写时一般按照顺序&#xff1a;盒子模型属性—>文字样式—>圆角、阴影等修饰属性 1.引入方式 引入方式方…...

Spring 源码硬核解析系列专题(十):Spring Data JPA 的 ORM 源码解析

在前几期中,我们从 Spring 核心到 Spring Boot、Spring Cloud、Spring Security 和 Spring Batch,逐步揭示了 Spring 生态的多样性。在企业级开发中,数据访问是不可或缺的部分,而 Spring Data JPA 通过简化 JPA(Java Persistence API)操作,成为主流的 ORM 框架。本篇将深…...

爬虫和逆向教程-专栏介绍和目录

文章目录 一、爬虫基础和进阶二、App数据采集三、爬虫项目四、爬虫面试 本专栏为爬虫初学者和进阶开发者量身定制的爬虫和逆向学习园地。为你提供全面而深入的爬虫和逆向技术指导&#xff0c;从入门到精通&#xff0c;从基础理论到高级实战&#xff0c;助你在数据的海洋中畅游&…...

Lua | 每日一练 (4)

&#x1f4a2;欢迎来到张胤尘的技术站 &#x1f4a5;技术如江河&#xff0c;汇聚众志成。代码似星辰&#xff0c;照亮行征程。开源精神长&#xff0c;传承永不忘。携手共前行&#xff0c;未来更辉煌&#x1f4a5; 文章目录 Lua | 每日一练 (4)题目参考答案线程和协程调度方式上…...

【折线图 Line】——1

🌟 解锁数据可视化的魔法钥匙 —— pyecharts实战指南 🌟 在这个数据为王的时代,每一次点击、每一次交易、每一份报告背后都隐藏着无尽的故事与洞察。但你是否曾苦恼于如何将这些冰冷的数据转化为直观、吸引人的视觉盛宴? 🔥 欢迎来到《pyecharts图形绘制大师班》 �…...

大白话前端性能优化,常见方法有哪些?

大白话前端性能优化&#xff0c;常见方法有哪些&#xff1f; 咱来唠唠前端性能优化&#xff0c;其实就是想办法让网页打开得更快、用起来更流畅&#xff0c;就跟给汽车做保养让它跑得更顺溜一样。下面详细说说常见的优化方法&#xff1a; 压缩代码 CSS 压缩&#xff1a;CSS …...

IP属地是通过卫星定位的吗?如何保护用户隐私

在数字时代&#xff0c;网络空间成为了人们日常生活不可或缺的一部分。随着社交媒体、在线服务等平台的兴起&#xff0c;用户IP属地信息的重要性日益凸显。然而&#xff0c;关于IP属地是如何确定的&#xff0c;尤其是是否通过卫星定位这一问题&#xff0c;却常常引发公众的疑问…...

Vue3+Node/Express支付宝沙箱支付与确认支付

Vue3Node/Express支付宝沙箱支付与确认支付 支付宝沙箱配置进入沙箱选择自定义密钥 密钥工具下载生成密钥格式转换 自定义密钥设置Express安装依赖项目目录创建alipay.js请求&#xff08;打开支付&#xff09;代码router/pay.jsapp.js 前端代码前端封装接口前端调用 实现支付查…...

什么是大语言模型

大语言模型&#xff08;Large Language Model&#xff0c;LLM&#xff09;是一种基于深度学习技术的人工智能模型&#xff0c;旨在理解和生成人类语言。以下是大语言模型的详细介绍&#xff1a; 一、基本概念 大语言模型通常包含数百亿甚至数千亿个参数&#xff0c;通过在海量…...