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

webpack4手动搭建Vue项目

小满视频

  • 很多解释使用通义灵码搜的,通义灵码的搜索结果也是有错误的
  • 全程使用pnpm包管理工具,和npm的用法基本一样

学习总结
1. 多看看webpack官网
2. webpack的作用:配置一堆东西,达到运行程序的目的
3. 无论什么东西都转成js,然后插入到一个空空的html文件中运行
4. webpack就是个管理者,管理着一堆loader,一堆loader的作用就是把自己负责的东西弄成js

手动搭建Vue项目,使用webpack4

  • 手动构建webpack基本环境
    • 1. 初始化node项目
    • 2. 生成TypeScript项目
    • 3. 安装webpack
    • 4. 安装webpack-cli
    • 5. 安装webpack-dev-server
    • 6. 安装html-webpack-plugin
    • 7. 安装Vue
    • 8 安装vue-loader
    • 9 安装clean-webpack-plugin
    • 10. 结果
    • 小结:
      • 项目目录树
      • 各文件代码
        • 1. webpack.config.js
        • 2. tsconfi.json
        • 3. package.json
        • 4. main.ts
        • 5. end.d.ts
        • 6. App.vue
        • 7. /public/index.html
  • webpack.config.js中的其他配置项
    • 1. resolve解析器
      • alias:设置别名
      • extensions:省略后缀名
    • 2. plugin 插件
    • 3. devServer 网络/服务相关配置
    • 4. stats 控制台信息如何显示
    • 5. module.rules配置预加载器
    • 6. 外部扩展(Externals)

手动构建webpack基本环境

webpack官网链接

1. 初始化node项目

  1. 初始化一个 Node.js 项目,并生成一个 package.json 文件
pnpm init

执行命令后自动创建package.json文件,内容如下:

{"name": "webpack-demo", 项目的名称"version": "1.0.0",项目的版本号"description": "",项目的简短描述"main": "index.js",项目的主入口文件"scripts": {项目的脚本命令,如测试脚本。"test": "echo \"Error: no test specified\" && exit 1"定义了一个简单的测试命令,当运行 npm test 时,会输出错误信息并退出。},"keywords": [],项目的关键词列表,用于搜索和分类"author": "",项目的作者信息"license": "ISC"项目的许可类型
}

2. 生成TypeScript项目

  1. 安装typescript
pnpm i typescript -g
  1. 生成 TypeScript 项目,和项目的初始配置文件 tsconfig.json
tsc --init
  • tsconfig.json内容
{"compilerOptions": {target: es2016  设置目标 ECMAScript 版本module: commonjs 指定模块系统。这里的 "commonjs" 表示使用 CommonJS 模块系统。strict: true 启用所有严格的类型检查选项esModuleInterop: true 启用 ES 模块与 CommonJS 模块之间的互操作性。这里的 true 表示启用此功能。skipLibCheck: true 是否跳过类型声明文件的检查。这里的 true 表示跳过类型声明文件的检查。forceConsistentCasingInFileNames: true 强制要求文件名大小写一致。这里的 true 表示启用此功能。}
}

-查看全局安装的插件的安装位置

npm config get prefix

3. 安装webpack

webpack官网

  • webpack.config.js文件中所有的配置项都是webpack管理的

  • 安装webpack

pnpm add webpack -D
  • Webpack 是一个非常流行的 JavaScript 模块打包器,用于将现代前端应用中的各种资源(如 JavaScript、CSS、图片等)打包成一个或多个浏览器可以加载的文件。Webpack 提供了一种强大的方式来组织和管理前端资源,使其易于维护和优化。
  • 根目录创建webpack.config.js文件
  • webpack.config.js中配置打包的入口和出口文件及打包后文件的路径
const config = {mode: 'development', // 开发模式entry: "./src/main.ts", // 入口文件output: {filename: "[fullhash].js", // 输出文件名path: path.resolve(__dirname , "dist") // 输出路径},
}
module.exports = config;

__dirname: 表示当前配置文件所在的目录。
‘dist’: 表示输出文件所在的子目录名。
path.resolve: 用于将相对路径转换为绝对路径。

4. 安装webpack-cli

pnpm add webpack-cli -D
  • package.json文件中配置打包命令
  "scripts": {"bulid": "webpack",......},
  • webpack-cli 是 Webpack 提供的命令行工具,用于在命令行中执行 Webpack 相关的操作。webpack-cli 主要完成以下几项工作:

    1. 解析和处理命令行参数:webpack-cli 负责解析用户在命令行中输入的参数,包括配置文件路径、打包模式、插件等信息。通过解析这些参数,webpack-cli 确定如何执行 Webpack 相关的操作。
    2. 载入并执行 Webpack 配置:webpack-cli 负责读取并解析指定的 Webpack 配置文件(通常是 webpack.config.js)。通过读取配置文件,webpack-cli 知道如何进行模块打包、资源处理等操作。
    3. 调用 Webpack API:通过调用 Webpack 提供的 API,webpack-cli 将用户输入的参数和配置转化为具体的 Webpack 打包操作。webpack-cli 可以执行 Webpack 的构建、开发服务器启动、打包分析等功能。
    4. 提供辅助功能:除了执行 Webpack 操作外,webpack-cli 还提供了一些辅助功能,比如生成 Webpack 相关的配置文件模板、帮助命令、插件等,帮助开发者更方便地使用 Webpack。
  • 在命令行输入:pnpm run devpnpm run build 时,通过webpack-cli执行webpack中的命令,并使用相应的配置,比如:webpack.config.js中打包的入口和出口等配置项

  • 不安装此插件也可以运行webpack,只不过可能需要很多复杂的命令

5. 安装webpack-dev-server

  • 作用:
    webpack-dev-server 是一个基于 Node.js 的本地开发服务器,它可以与 Webpack 一起使用,为开发者提供实时重新加载和热模块替换等功能。它能够自动监听文件更改,并在文件发生变化时重新编译并刷新浏览器,从而极大地提高了开发效率。
pnpm add webpack-dev-server -D

6. 安装html-webpack-plugin

  • 作用:
    用于生成 HTML 文件,并自动注入 Webpack 打包后的 JavaScript 和 CSS 文件。这个插件可以帮助你轻松地管理和自动化 HTML 文件的生成过程,确保每次构建后都能得到最新的 HTML 文件。
pnpm add html-webpack-plugin -D
  • package.json文件中配置运行命令
  "scripts": {"dev":"webpack-dev-server --open",......},

–open:自动打开浏览器

  • 在webpack.config.js中配置此插件:
// 导入html-webpack-plugin
const HtmlWebpackPlugin = require("html-webpack-plugin");
    plugins: [new HtmlWebpackPlugin({template: './public/index.html', // 指定模板文件filename: 'index.html',        // 输出文件名inject: 'body'                 // 注入的位置})],

7. 安装Vue

pnpm add vue -D
  • main.ts
import { createApp } from "vue";
import App from "./App.vue";createApp(App).mount("#app");
  • App.vue
<template><div>test</div>
</template><script setup lang=ts></script><style scoped lang="scss" >
</style>
  • 新建vue.d.ts文件,main.ts中使用了import App from "./App.vue";代码,在编译时TypeScript 不认识.vue文件,在此声明.vue文件的类型
declare module "*.vue"{import type {DefineComponent} from 'vue'const component:DefineComponent<{},{},any>export default component
}
  • .d.ts文件是 TypeScript 定义文件的一种。在 TypeScript 中,.d.ts 文件用于提供类型定义,以便 TypeScript 编译器可以理解未包含类型信息的 JavaScript 代码或其他 TypeScript 模块的类型。在编译时TypeScript 编译器会在项目的根目录及其子目录中查找 .d.ts 文件。
  • declare module:用于声明一个模块的类型定义
    1. declare module “*.vue”: 声明一个模块,该模块匹配所有的 .vue 文件。
    2. import type {DefineComponent} from ‘vue’: 导入 DefineComponent 类型,这是 Vue.js 中的一个类型,用于表示 Vue 组件。
    3. const component: DefineComponent<{},{},any>: 定义一个名为 component 的常量,它的类型为 DefineComponent。这里的泛型参数分别代表:
      • 第一个参数 {} 表示组件的 props 类型为空。
      • 第二个参数 {} 表示组件的 emits 类型为空。
      • 第三个参数 any 表示组件的 data 类型为 any。

此时pnpm build打包时会报错:

ERROR in ./src/App.vue 1:0
Module parse failed: Unexpected token (1:0)
You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders
> <template>
| <div>
| test
@ ./src/main.ts 2:0-28 4:10-13

翻译:您可能需要一个适当的加载器来处理此文件类型,目前没有配置加载器来处理该文件。请参阅https://webpack.js.org/concepts#loaders

  • 打包工具webpack不认识<template>等代码,需要一个新的工具vue-loader

8 安装vue-loader

vue-loader官网

  • 安装vue-loader
pnpm add vue-loader -D
  • webpack.config.js中配置vue-loader
// 导入vue-loader
const { VueLoaderPlugin } = require("vue-loader");const config = { // 执行命令npm run build,按照config中的配置打包文件...module: {rules: [// 以.vue结尾的文件,指定vue-loader加载器来处理{test: /\.vue$/,loader: 'vue-loader'},]},plugins: [...// 引入vue-loader插件new VueLoaderPlugin(),],
}
  • 作用vue Loader 是一个 webpackloader(加载器),它允许你以一种名为单文件组件 (SFCs)的格式撰写 Vue 组件

  • vue-loader部分工作流程:

    1. 调用@vue/compiler-sfc会解析文件,提取每个语言块,
    2. 通过标签中lang="ts"lang="scss"中lang的特性以及 webpack 配置中的规则自动推断出要使用的预处理(loader)
    3. vue-loader调用ts-loader预处理器,处理<script>部分;调用scss-loader预处理器,处理<style>部分
    4. 最后将他们组装成一个 ES Module,它的默认导出是一个 Vue.js 组件选项的对象。
  • Vue 单文件组件 (SFC) 规范:官网介绍
    vue 文件是一个自定义的文件类型,用类 HTML 语法描述一个 Vue 组件。每个 .vue 文件包含三种类型的顶级语言块 <template>、<script> 和 <style>,还允许添加可选的自定义块

  • vue-loader官网介绍说需要安装vue-template-compiler,在vue3中已经包含了相同功能的@vue/compiler-sfc插件,已经不需要再安装
    在这里插入图片描述

9 安装clean-webpack-plugin

  • 安装clean-webpack-plugin
pnpm add clean-webpack-plugin -D
  • 作用:用于在构建之前(pnpm build)清理输出目录(dist)。这个插件可以帮助你在每次构建时删除旧的构建文件,确保输出目录只包含最新构建的结果。这对于避免旧文件残留、减少混淆等问题非常有用。

  • webpack.config.js

// 导入clean-webpack-plugin
const { CleanWebpackPlugin } = require("clean-webpack-plugin");
    plugins: [...// 引入clean-webpack-pluginnew CleanWebpackPlugin()],
}

10. 结果

  • 在浏览器中正常执行
pnpm dev
  • 打包后,打开/dist/html文件,执行正常
 pnpm build

小结:

项目目录树

在这里插入图片描述

各文件代码

1. webpack.config.js
// 导入Configuration,使用注解的方式提供书写代码的智能提示
const {Configuration} = require("webpack");
// 导入vue-loader
const { VueLoaderPlugin } = require("vue-loader");
// 导入html-webpack-plugin
const HtmlWebpackPlugin = require("html-webpack-plugin");
// 导入clean-webpack-plugin
const { CleanWebpackPlugin } = require("clean-webpack-plugin");
const path = require("path");/*** @type {Configuration}*/
const config = { // 执行命令npm run build,按照config中的配置打包文件mode: 'development', // 开发模式entry: "./src/main.ts", // 入口文件module: {rules: [// 以.vue结尾的文件,指定使用vue-loader加载器来处理{test: /\.vue$/,loader: 'vue-loader'},]},output: {filename: "[fullhash].js", // 输出文件名path: path.resolve(__dirname , "dist") // 输出路径},// resolve: {//     extensions: ['.tsx', '.ts', '.js'] // 自动解析扩展名// },plugins: [new HtmlWebpackPlugin({template: './public/index.html', // 指定模板文件filename: 'index.html',        // 输出文件名inject: 'body'                 // 注入的位置}),// 引入vue-loader插件new VueLoaderPlugin(),// 引入clean-webpack-pluginnew CleanWebpackPlugin()],
}module.exports = config;
2. tsconfi.json
{"compilerOptions": {target: es2016  module: commonjs strict: true esModuleInterop: true skipLibCheck: true forceConsistentCasingInFileNames: true }
}
3. package.json
{"name": "webpack-demo","version": "1.0.0","description": "","main": "index.js","scripts": {"build": "webpack","dev": "webpack-dev-server --open","test": "echo \"Error: no test specified\" && exit 1"},"keywords": [],"author": "","license": "ISC","devDependencies": {"clean-webpack-plugin": "^4.0.0","html-webpack-plugin": "^5.5.0","ts-loader": "^9.5.1","vue": "3.2.38","vue-loader": "^17.4.2","webpack": "^5.74.0","webpack-cli": "^5.1.4","webpack-dev-server": "^4.10.1"}
}
4. main.ts
import { createApp } from "vue";
import App from "./App.vue";createApp(App).mount("#app");
5. end.d.ts
declare module "*.vue"{import type {DefineComponent} from 'vue'const component:DefineComponent<{},{},any>export default component
}
6. App.vue
<template><div>test</div>
</template><script setup lang="ts"></script><style scoped ></style>
7. /public/index.html
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>webpack-demo</title>
</head>
<body><div id="app"></div>
</body>
</html>

webpack.config.js中的其他配置项

    resolve: {alias: {'@': path.resolve(__dirname, 'src')},extensions: ['.tsx', '.ts', '.js'] // import 时,可以省略后缀名},

1. resolve解析器

官网详细说明

  • 设置模块如何被解析
  • 使用import和require时的相关配置

alias:设置别名

  • 设置@的别名
    resolve: {alias: {'@': path.resolve(__dirname, 'src')}},
  1. __dirname 是 Node.js 中的一个全局变量,用于表示当前文件所在的目录的绝对路径
  2. importrequire 语句中使用@时,相当于使用 当前文件的路径/src

extensions:省略后缀名

    resolve: {extensions: ['.tsx', '.ts', '.js'] // import 时,可以省略后缀名},
  1. 如需导入文件/src/views/index.js,可以不写后缀import ex from “src/views/index”
  2. 假如目录中有同名文件/src/views/index.ts,按照extensions给定的顺序导入的是ts文件

2. plugin 插件

作用: 各种方法修改webpack的构建过程,达到各种各样的目的

  1. 美化在构建过程中cmd中展示的各种信息
// 安装
pnpm add friendy-error-webpack-plugin -D
// 引入
const FriendlyErrorsWebpackPlugin = require("friendly-errors-webpack-plugin");
//使用
plugins: [// 引入friendly-errors-webpack-pluginnew FriendlyErrorsWebpackPlugin({compilationSuccessInfo: {messages: [`You application is running here http://localhost:5173`],}}),],

3. devServer 网络/服务相关配置

官网详细说明

  • 配置启动后监听的端口号,通过pnpm dev启动项目后,浏览器中端口号
  devServer: {port: 5173, // 端口号},

4. stats 控制台信息如何显示

官网的详细说明
作用: 控制台信息如何显示

  • 只有在错误时展示信息
stats:"errors-only",

5. module.rules配置预加载器

官方的详细说明

  • webpack原生只认识js和json文件,遇到其他类型文件时通过rules中配置规则,找对应的预加载器,把所有的文件都解析成js

  • rules中有多少loader,就需要pnpm安装多少loader

  module: {rules: [// 以.vue结尾的文件,指定使用vue-loader加载器来处理{test: /\.vue$/,use: "vue-loader",},// 以.css结尾的文件,指定使用css-loader和style-loader加载器来处理// use中的loader是倒序执行的,不能乱排顺序{test: /\.css$/,use: ["style-loader", "css-loader"],},// 以.ts结尾的文件,ts-loader加载器来处理// {//   test: /\.ts$/,//   use: [//     {//       loader: "ts-loader",//       options: {//         configFile: path.resolve(process.cwd(), "tsconfig.json"),//         appendTsSuffixTo: [/\.vue$/],//       },//     },//   ],// },{test: /\.ts$/,loader: "ts-loader",options: {configFile: path.resolve(process.cwd(), "tsconfig.json"),appendTsSuffixTo: [/\.vue$/],},},],},

6. 外部扩展(Externals)

代码:

  externals: {vue: "Vue",},
  • 使用上述代码后,打包的文件中将不包含vue,在运行打包文件index.html会报错
    在这里插入图片描述
  • Vue给我们提供了CDN的引入方式:
<script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>

将上述代码插入到指定的模板文件index.html中再打包就可以运行了.

  • 优点:有效的减少打包后的体积,减少服务器的压力
  • 缺点:vue的相关文件都会从网络下载,会增加网络负担,如果网络传输速度不够快,直接影响使用者的体验

相关文章:

webpack4手动搭建Vue项目

小满视频 很多解释使用通义灵码搜的,通义灵码的搜索结果也是有错误的全程使用pnpm包管理工具&#xff0c;和npm的用法基本一样 学习总结 1. 多看看webpack官网 2. webpack的作用&#xff1a;配置一堆东西&#xff0c;达到运行程序的目的 3. 无论什么东西都转成js&#xff0c;…...

Python爬虫所需的技术及其原理(简单易懂)

导言 随着互联网的发展&#xff0c;大量的数据被存储在网络上&#xff0c;而我们需要从中获取有用的信息。Python作为一种功能强大且易于学习的编程语言&#xff0c;被广泛用于网络爬虫的开发。本文将详细介绍Python爬虫所需的技术及其原理&#xff0c;并提供相关的代码案例。…...

FxFactory 8 for Mac 视觉特效插件包安装

Mac分享吧 文章目录 介绍页面效果一、下载软件二、开始安装1、Install安装2、显示软件页面&#xff0c;表示安装成功3、补丁安装 三、注意事项1、若已安装过其他版本&#xff0c;需要使用软件自带的卸载功能进行软件卸载&#xff0c;再安装此版本 安装完成&#xff01;&#x…...

将语义分割的标签转换为实例分割(yolo)的标签

语义分割的标签&#xff08;目标处为255&#xff0c;其余处为0&#xff09; 实例分割的标签&#xff08;yolo.txt&#xff09;,描述边界的多边形顶点的归一化位置 绘制在原图类似蓝色的边框所示。 废话不多说&#xff0c;直接贴代码&#xff1b; import os import cv2 imp…...

QT 遍历ini配置文件

在 Qt 中&#xff0c;处理 INI 配置文件是一项常见任务&#xff0c;通常使用 QSettings 类来读取和写入这些文件。QSettings 提供了一种方便的方式来操作 INI 文件中的配置数据。下面是如何使用 QSettings 遍历和处理 INI 配置文件的示例。 示例代码 假设有一个名为 config.i…...

ecmascript和javascript的区别详细讲解

​ 大家好&#xff0c;我是程序员小羊&#xff01; 前言&#xff1a; ECMAScript 和 JavaScript是紧密相关的术语&#xff0c;但它们有着各自明确的定义和用途。要理解它们的区别&#xff0c;首先需要从它们的起源、发展历史、技术架构以及具体应用领域来分析。以下是对它们的详…...

【Python报错已解决】“ModuleNotFoundError: No module named ‘timm‘”

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 文章目录 引言&#xff1a;一、问题描述1.1 报错示例&#xff1a;当我们尝试导入timm库时&#xff0c;可能会看到以下错误信息。…...

「图::存储」链式邻接表|链式前向星(C++)

前置知识 上一节我们介绍了三种基本的存图结构&#xff1a; 「图」邻接矩阵|边集数组|邻接表&#xff08;C&#xff09; 概述 他们各有优劣&#xff0c;为了综合他们的性能&#xff0c; 这一节我们来介绍两种以这三种结构为基础实现的高级存储结构&#xff1a;链式邻接表|…...

《Cloud Native Data Center Networking》(云原生数据中心网络设计)读书笔记 -- 10数据中心中的BGP

本章解答以下问题&#xff1a; ASN&#xff0c;团体&#xff08;community&#xff09;&#xff0c;属性&#xff08;attribute&#xff09;&#xff0c;最佳路径这些BGP术语是什么疑似&#xff1f;在数据中心中应该使用eBGP还是iBGP?在数据中心使用BGP时&#xff0c;应采用什…...

unity游戏开发——标记物体 一目了然

Unity游戏开发:标记物体,让开发变得一目了然 “好读书&#xff0c;不求甚解&#xff1b;每有会意&#xff0c;便欣然忘食。” 本文目录&#xff1a; Unity游戏开发 Unity游戏开发:标记物体,让开发变得一目了然前言1. 什么是Tag&#xff1f;2. Unity中如何添加和管理Tag步骤1&am…...

vue 项目打包图片没有打包进去问题解决

解决方法1.在导入图片的文件中通过 import 引入图片 这种方法只适合图片少的情况 <template> <img :srctestImg/> </template> <script> import testImg from /assets/img/testImg.png </script>2.封装公共方法,通过 new URL() 的方式…...

TCP的传输速度

如何确定TCP最大传输速度&#xff1f; TCP 的传输速度&#xff0c;受限于发送窗⼝&#xff0c;接收窗⼝以及⽹络设备传输能⼒。 其中&#xff0c;窗⼝⼤⼩由内核缓冲区⼤⼩决定。如果缓冲区与⽹络传输能⼒匹配&#xff0c;那么缓冲区的利⽤率就达到了最⼤化。 如何计算网络传…...

直播间的“骆驼”比沙漠还多?刀郎演唱会惊现“骆驼”

“送战友&#xff0c;踏征程&#xff0c;默默无语两行泪&#xff0c;耳边响起驼铃声……”8月30日&#xff0c;刀郎知交线上演唱会在微信视频号直播。一曲《驼铃》&#xff0c;勾起了无数人的回忆&#xff0c;离别的伤感、人性的关怀与温暖&#xff0c;通过悠然的旋律流入千万听…...

Android Studio gradle下载太慢了!怎么办?(已解决)

Android Studio&#xff01;你到底干了什么&#xff1f;&#xff01; 不能高速下载gradle&#xff0c;我等如何进行app编程&#xff1f;&#xff01; 很简单&#xff0c;我修改gradle地址不就是了。 找到gradle-wrapper.properties文件 修改其中distributionUrl的地址。 将 ht…...

安卓版Infuse来了 打造自己的影视墙

如何让安卓设备上的视频播放更高效&#xff1f;AfuseKt 或许能给出答案 AfuseKt 是一款功能强大的安卓网络视频播放器&#xff0c;专为满足用户对多样化媒体播放需求而设计。它不仅支持多种流行的在线存储和媒体管理平台&#xff0c;如阿里云盘、Alist、WebDAV 和 Emby 等&…...

【Python时序预测系列】高创新模型:基于xlstm模型实现单变量时间序列预测(案例+源码)

这是我的第351篇原创文章。 一、引言 LSTM在1990年代被提出&#xff0c;用以解决循环神经网络&#xff08;RNN&#xff09;的梯度消失问题。LSTM在多种领域取得了成功&#xff0c;但随着Transformer技术的出现&#xff0c;其地位受到了挑战。如果将LSTM扩展到数十亿参数&#…...

Ubuntu 22.04 系统中 ROS2安装

Ubuntu 22.04 系统中 ROS2安装 ROS2安装 # 多窗口终端工具 sudo apt update sudo apt install tilix打开软件&#xff0c;点击右上角图标进入设置 -> General -> size120, columns:48Command -> 勾选第一个 Run command as login shellColor -> Theme Color 选择…...

Vue内置指令v-once、v-memo和v-pre提升性能?

前言 Vue的内置指令估计大家都用过不少&#xff0c;例如v-for、v-if之类的就是最常用的内置指令&#xff0c;但今天给大家介绍几个平时用的比较少的内置指令。毕竟这几个Vue内置指令可用可不用&#xff0c;不用的时候系统正常跑&#xff0c;但在对的地方用了却能提升系统性能&…...

OpenHarmony轻松玩转GIF数据渲染

OpenAtom OpenHarmony&#xff08;以下简称“OpenHarmony”&#xff09;提供了Image组件支持GIF动图的播放&#xff0c;但是缺乏扩展能力&#xff0c;不支持播放控制等。今天介绍一款三方库——ohos-gif-drawable三方组件&#xff0c;带大家一起玩转GIF的数据渲染&#xff0c;搞…...

torch.clip函数介绍

PyTorch 中,torch.clip函数用于对张量中的元素进行裁剪,将其值限制在指定的范围内。 一、函数语法及参数解释 torch.clip(input, min=None, max=None, out=None) input:输入张量,即要进行裁剪的张量。min(可选):裁剪的下限。如果未指定,则不进行下限裁剪。max(可选)…...

高频面试之3Zookeeper

高频面试之3Zookeeper 文章目录 高频面试之3Zookeeper3.1 常用命令3.2 选举机制3.3 Zookeeper符合法则中哪两个&#xff1f;3.4 Zookeeper脑裂3.5 Zookeeper用来干嘛了 3.1 常用命令 ls、get、create、delete、deleteall3.2 选举机制 半数机制&#xff08;过半机制&#xff0…...

Leetcode 3577. Count the Number of Computer Unlocking Permutations

Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接&#xff1a;3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯&#xff0c;要想要能够将所有的电脑解锁&#x…...

条件运算符

C中的三目运算符&#xff08;也称条件运算符&#xff0c;英文&#xff1a;ternary operator&#xff09;是一种简洁的条件选择语句&#xff0c;语法如下&#xff1a; 条件表达式 ? 表达式1 : 表达式2• 如果“条件表达式”为true&#xff0c;则整个表达式的结果为“表达式1”…...

【python异步多线程】异步多线程爬虫代码示例

claude生成的python多线程、异步代码示例&#xff0c;模拟20个网页的爬取&#xff0c;每个网页假设要0.5-2秒完成。 代码 Python多线程爬虫教程 核心概念 多线程&#xff1a;允许程序同时执行多个任务&#xff0c;提高IO密集型任务&#xff08;如网络请求&#xff09;的效率…...

k8s业务程序联调工具-KtConnect

概述 原理 工具作用是建立了一个从本地到集群的单向VPN&#xff0c;根据VPN原理&#xff0c;打通两个内网必然需要借助一个公共中继节点&#xff0c;ktconnect工具巧妙的利用k8s原生的portforward能力&#xff0c;简化了建立连接的过程&#xff0c;apiserver间接起到了中继节…...

QT: `long long` 类型转换为 `QString` 2025.6.5

在 Qt 中&#xff0c;将 long long 类型转换为 QString 可以通过以下两种常用方法实现&#xff1a; 方法 1&#xff1a;使用 QString::number() 直接调用 QString 的静态方法 number()&#xff0c;将数值转换为字符串&#xff1a; long long value 1234567890123456789LL; …...

如何在最短时间内提升打ctf(web)的水平?

刚刚刷完2遍 bugku 的 web 题&#xff0c;前来答题。 每个人对刷题理解是不同&#xff0c;有的人是看了writeup就等于刷了&#xff0c;有的人是收藏了writeup就等于刷了&#xff0c;有的人是跟着writeup做了一遍就等于刷了&#xff0c;还有的人是独立思考做了一遍就等于刷了。…...

QT3D学习笔记——圆台、圆锥

类名作用Qt3DWindow3D渲染窗口容器QEntity场景中的实体&#xff08;对象或容器&#xff09;QCamera控制观察视角QPointLight点光源QConeMesh圆锥几何网格QTransform控制实体的位置/旋转/缩放QPhongMaterialPhong光照材质&#xff08;定义颜色、反光等&#xff09;QFirstPersonC…...

Unity中的transform.up

2025年6月8日&#xff0c;周日下午 在Unity中&#xff0c;transform.up是Transform组件的一个属性&#xff0c;表示游戏对象在世界空间中的“上”方向&#xff08;Y轴正方向&#xff09;&#xff0c;且会随对象旋转动态变化。以下是关键点解析&#xff1a; 基本定义 transfor…...

MySQL的pymysql操作

本章是MySQL的最后一章&#xff0c;MySQL到此完结&#xff0c;下一站Hadoop&#xff01;&#xff01;&#xff01; 这章很简单&#xff0c;完整代码在最后&#xff0c;详细讲解之前python课程里面也有&#xff0c;感兴趣的可以往前找一下 一、查询操作 我们需要打开pycharm …...