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

日常学习开发记录-input组件

实现

  • 1.实现
  • 2.inline-table和table-cell实现
    • 2.1 表格布局的特性
    • 2.2 示例
  • 3.clear清除事件未生效
    • 3.1 原因
    • 3.2 解决
  • 4. 增加type为text和textarea
    • 4.1 rows,autosize的实现
  • 5.拓展-composition事件

1.实现

<template><div class="my-input":class="{'is-disabled': disabled,'is-focus': focused,'my-input--suffix': showSuffix,'my-input--prefix': showPrefix,'my-input-group': $slots.prepend || $slots.append,'my-input-group--prepend': $slots.prepend,'my-input-group--append': $slots.append}"><!-- 前置元素 --><span class="my-input-group__prepend" v-if="$slots.prepend"><slot name="prepend"></slot></span><!-- 前缀图标--><span class="my-input__prefix" v-if="showPrefix"><i :class="prefixIcon" v-if="prefixIcon"></i><slot name="prefix"></slot></span><!-- 输入框 --><inputref="input"class="my-input__inner":type="type":placeholder="placeholder":disabled="disabled":readonly="readonly":value="value"@input="handleInput"@focus="handleFocus"@blur="handleBlur"@change="handleChange"><!-- 后缀图标,包括清空按钮 --><span class="my-input__suffix" v-if="showSuffix"><span class="my-input__suffix-inner"><iclass="my-input__clear my-icon-circle-close"v-if="clearable && value && !disabled && !readonly"@click="clear"></i><i :class="suffixIcon" v-if="suffixIcon"></i><slot name="suffix"></slot></span></span><!-- 后置元素 --><span class="my-input-group__append" v-if="$slots.append"><slot name="append"></slot></span></div>
</template><script>
export default {name: 'MyInput',props: {// v-model 绑定值value: {type: [String, Number],default: ''},// 输入框类型type: {type: String,default: 'text'},// 占位文本placeholder: String,// 是否禁用disabled: Boolean,// 是否只读readonly: Boolean,// 是否可清空clearable: Boolean,// 前缀图标prefixIcon: String,// 后缀图标suffixIcon: String},data() {return {focused: false,// 用于存储内部值,支持可控和非可控模式currentValue: this.value};},computed: {// 是否显示前缀showPrefix() {return this.prefixIcon || this.$slots.prefix;},// 是否显示后缀showSuffix() {return this.suffixIcon || this.clearable || this.$slots.suffix;}},watch: {value(val) {this.currentValue = val;}},methods: {/*** 处理输入事件*/handleInput(event) {const value = event.target.value;this.$emit('input', value);this.currentValue = value;},/*** 处理聚焦事件*/handleFocus(event) {this.focused = true;this.$emit('focus', event);},/*** 处理失焦事件*/handleBlur(event) {this.focused = false;this.$emit('blur', event);},/*** 处理变更事件*/handleChange(event) {this.$emit('change', event.target.value);},/*** 清空输入框*/clear() {this.$emit('input', '');this.$emit('change', '');this.$emit('clear');this.currentValue = '';},/*** 聚焦输入框*/focus() {this.$refs.input.focus();},/*** 失焦输入框*/blur() {this.$refs.input.blur();}}
};
</script>

2.inline-table和table-cell实现

使用prefix和suffix插槽会有问题:
在这里插入图片描述
能看到在定宽的组件中重叠错位了。
Element UI的input组件中使用的display:inline-table和display:table-cell布局技术确实很巧妙。这种布局方式允许父元素有一个固定宽度,而子元素却可以根据内容自适应并且可以超出父元素的宽度限制。

2.1 表格布局的特性

CSS表格布局有一个独特的特性:表格单元格(table cells)会根据其内容自动调整大小,并且可以超出表格本身的设定宽度。这与普通的块级元素完全不同,块级元素默认会受到父元素宽度的限制。
display: inline-table:使元素像内联元素一样在行内显示,但内部使用表格布局规则
display: table-cell:使元素表现为表格单元格

为什么可以超出父元素宽度?
表格布局有一个特殊的宽度计算算法:
先考虑内容的实际宽度
然后根据可用空间和其他单元格调整。

2.2 示例

关键点是:表格单元格会优先满足内容需求,即使这意味着需要超出表格的指定宽度

<style>
.input-wrapper {/* 普通块级元素布局 */width: 300px;border: 1px solid #ccc;
}.table-input-wrapper {/* 表格布局 */display: inline-table;width: 300px;border: 1px solid #ccc;
}.addon {display: table-cell;background: #f5f7fa;padding: 0 10px;white-space: nowrap;
}.input {display: table-cell;width: 100%;border: none;padding: 8px;
}
</style><!-- 普通布局 - 会被截断或换行 -->
<div class="input-wrapper"><span>这是一个非常长的前置文本内容可能会超出父容器</span><input type="text" placeholder="输入内容">
</div><!-- 表格布局 - 会完整显示 -->
<div class="table-input-wrapper"><span class="addon">这是一个非常长的前置文本内容可能会超出父容器</span><input class="input" type="text" placeholder="输入内容">
</div>

结果:
在这里插入图片描述

3.clear清除事件未生效

在这里插入图片描述在这里插入图片描述

点击清除,clear没执行。

3.1 原因

点击清空按钮时,事件顺序如下:
mousedown 事件首先触发
由于清空按钮在输入框内部,输入框会失去焦点(blur)
输入框触发 blur 事件
如果值有变化,输入框还会触发 change 事件
然后才是清空按钮的 click 事件,此时才执行 clear 方法
问题在于:change事件在clear方法之前触发了,而且由于输入框已经失去焦点,您的清空操作可能不会生效。

3.2 解决

事件处加上 @mousedown.prevent,

1.阻止了mousedown的默认行为
2.阻止了输入框失去焦点
3.因此不会触发blur和change事件
4.让清空按钮的click事件和clear方法能够正常执行

4. 增加type为text和textarea

4.1 rows,autosize的实现

直接将input标签换成一个textarea标签是可以进行双向绑定的。但是还是差了点味。
思路(学习借鉴的elementui源码):创建一个隐藏的 textarea,放到 body 标签下,将 Textarea 组件的 value 值赋值给隐藏的 textarea,通过获取这个隐藏的 textarea 的 scrollHeight(scrollHeight 会返回该元素在不使用滚动条时的高度),来设置组件上面的 textarea 的高度。主要通过calcTextareaHeight 方法用于计算 textarea 的动态高度。

/*** 用于动态计算文本域(textarea)高度的模块* 通过创建隐藏的textarea元素复制样式和内容,计算理想高度*/// 全局隐藏textarea引用,避免重复创建
let hiddenTextarea/*** 应用于隐藏textarea的CSS样式* 确保元素完全不可见且不影响页面布局*/
const HIDDEN_STYLE = `height:0 !important;visibility:hidden !important;overflow:hidden !important;position:absolute !important;z-index:-1000 !important;top:0 !important;right:0 !important
`/*** 需要从目标textarea复制的CSS属性列表* 这些属性会影响文本渲染和尺寸计算*/
const CONTEXT_STYLE = ['letter-spacing', // 字符间距'line-height', // 行高'padding-top', // 上内边距'padding-bottom', // 下内边距'font-family', // 字体族'font-weight', // 字体粗细'font-size', // 字体大小'text-rendering', // 文本渲染方式'text-transform', // 文本转换'width', // 宽度'text-indent', // 文本缩进'padding-left', // 左内边距'padding-right', // 右内边距'border-width', // 边框宽度'box-sizing', // 盒模型类型
]/*** 计算目标元素的样式参数* @param {HTMLElement} targetElement - 目标textarea元素* @returns {Object} 包含上下文样式和关键尺寸参数的对象*/
function calculateNodeStyling(targetElement) {// 获取目标元素的计算样式const style = window.getComputedStyle(targetElement)// 获取盒模型类型(border-box或content-box)const boxSizing = style.getPropertyValue('box-sizing')// 计算上下padding总和const paddingSize =parseFloat(style.getPropertyValue('padding-bottom')) +parseFloat(style.getPropertyValue('padding-top'))// 计算上下border总和const borderSize =parseFloat(style.getPropertyValue('border-bottom-width')) +parseFloat(style.getPropertyValue('border-top-width'))// 构建CSS样式字符串,包含所有CONTEXT_STYLE中定义的属性const contextStyle = CONTEXT_STYLE.map(name => `${name}:${style.getPropertyValue(name)}`).join(';')console.log({ contextStyle, paddingSize, borderSize, boxSizing })return { contextStyle, paddingSize, borderSize, boxSizing }
}/*** 计算textarea的理想高度* @param {HTMLElement} targetElement - 目标textarea元素* @param {number} minRows - 最小行数,默认为1* @param {number|null} maxRows - 最大行数,默认为null(无限制)* @returns {Object} 包含计算得到的高度信息,格式为{height: 'XXpx', minHeight: 'XXpx'}*/
export default function calcTextareaHeight(targetElement, minRows = 1, maxRows = null) {// 创建隐藏文本域(如果尚未创建)if (!hiddenTextarea) {hiddenTextarea = document.createElement('textarea')document.body.appendChild(hiddenTextarea)}// 从目标元素获取样式参数let { paddingSize, borderSize, boxSizing, contextStyle } = calculateNodeStyling(targetElement)// 设置隐藏文本域的样式,确保渲染特性与目标元素一致hiddenTextarea.setAttribute('style', `${contextStyle};${HIDDEN_STYLE}`)// 复制目标元素的内容或占位符到隐藏文本域hiddenTextarea.value = targetElement.value || targetElement.placeholder || ''// 获取隐藏文本域的内容滚动高度let height = hiddenTextarea.scrollHeightconst result = {}// 根据盒模型调整高度计算if (boxSizing === 'border-box') {// border-box模型:滚动高度不包含border,需要加上height = height + borderSize} else if (boxSizing === 'content-box') {// content-box模型:滚动高度包含padding,需要减去height = height - paddingSize}// 计算单行高度(用于行数限制计算)hiddenTextarea.value = '' // 清空内容let singleRowHeight = hiddenTextarea.scrollHeight - paddingSize // 空文本域的高度减去padding// 应用最小行数限制if (minRows !== null) {let minHeight = singleRowHeight * minRows // 计算最小高度if (boxSizing === 'border-box') {// border-box模型下需加上padding和borderminHeight = minHeight + paddingSize + borderSize}// 取计算高度和最小高度的较大值height = Math.max(minHeight, height)result.minHeight = `${minHeight}px`}// 应用最大行数限制if (maxRows !== null) {let maxHeight = singleRowHeight * maxRows // 计算最大高度if (boxSizing === 'border-box') {// border-box模型下需加上padding和bordermaxHeight = maxHeight + paddingSize + borderSize}// 取计算高度和最大高度的较小值height = Math.min(maxHeight, height)}// 设置最终计算结果result.height = `${height}px`// 清理:移除隐藏文本域以释放资源hiddenTextarea.parentNode && hiddenTextarea.parentNode.removeChild(hiddenTextarea)hiddenTextarea = nullreturn result
}

实现效果:
在这里插入图片描述

5.拓展-composition事件

现在的input搭配输入法有个问题还
在这里插入图片描述

我输入一个“啊”字,事件分发出去了两次。

composition相关事件是HTML
DOM的标准事件,专门用于处理输入法编辑器(IME)输入过程。在使用中文、日文、韩文等需要组合多个按键输入的语言时特别重要。
这三个事件的作用是: compositionstart: 当用户开始使用输入法输入时触发 代码中将isComposing标记为true
防止在组合输入过程中触发正常的input事件处理 compositionupdate: 当输入法正在组合字符时触发
代码中检查最后输入的字符是否是韩文(isKorean函数) 根据检测结果更新isComposing标志 compositionend:
当输入法完成组合输入,确认文字时触发 代码中重置isComposing为false 然后手动触发handleInput事件
这种设计解决了一个重要问题:避免在使用输入法时,未完成的组合文字过早触发input事件导致的问题。

完善后,结果:
在这里插入图片描述

相关文章:

日常学习开发记录-input组件

实现 1.实现2.inline-table和table-cell实现2.1 表格布局的特性2.2 示例 3.clear清除事件未生效3.1 原因3.2 解决 4. 增加type为text和textarea4.1 rows,autosize的实现 5.拓展-composition事件 1.实现 <template><div class"my-input":class"{is-dis…...

【数据库系统原理】简答题

真题 2024-10 31.数据模型的三大要素是什么? 32.简述关系模型的参照完整性规则。 33.什么是视图?视图的作用是什么? 34.简述两个实体型之间联系的三种形式,并举例说明。 35.什么是数据库备份?MySQL使用什么语句实现备份与恢复数据库中表的数据? 2024-04 31.请解释数据…...

20250319在荣品的PRO-RK3566开发板的buildroot系统下使用集成的QT应用调试串口UART3

stty -F /dev/ttyS3 115200 -echo cat /dev/ttyS3 & echo serialdata > /dev/ttyS3 20250319在荣品的PRO-RK3566开发板的buildroot系统下使用集成的QT应用调试串口UART3 2025/3/19 14:17 缘起&#xff1a;在荣品的PRO-RK3566开发板的buildroot系统下&#xff0c;在命令…...

C#基于MVC模式实现TCP三次握手,附带简易日志管理模块

C#基于MVC模式实现TCP三次握手 1 Model1.1 ServerModel1.2 ClientModel1.3 配置参数模块1.4 日志管理模块1.4.1 数据结构1.4.1 日志管理工具类1.4.1 日志视图展示1.4.1.1 UcLogManage.cs1.4.1.2 UcLogManage.Designer.cs 2 视图&#xff08;View&#xff09;2.1 ViewServer2.1.…...

大语言模型的多垂类快速评估与 A/B 测试

简介 行业领先的模型构建企业携手澳鹏&#xff08;Appen&#xff09;开展了一项极具挑战性的项目。针对 3 至 6 个大型语言模型&#xff08;LLM&#xff09;&#xff0c;在广泛的通用领域及复杂专业领域&#xff08;如医疗保健、法律、金融、编程、数学和汽车行业等&#xff0…...

一个成功的Git分支模型

本作品原发布账号为【白鸽子中文网】&#xff0c;现转至当前账号【飞翔中文网】。 反思备录(2020/3/5) 这个模型构思于2010年&#xff0c;现已过去10余年&#xff0c;(2010年)那时正处于Git诞生后不久。在这10年间&#xff0c;git-flow(本文中提到的分支模型) 在许多软件队伍里…...

MySQL 在 CentOS 7 上安装的步骤指南

&#x1f3dd;️专栏&#xff1a;Mysql_猫咪-9527的博客-CSDN博客 &#x1f305;主页&#xff1a;猫咪-9527-CSDN博客 “欲穷千里目&#xff0c;更上一层楼。会当凌绝顶&#xff0c;一览众山小。” 目录 1. 卸载不需要的环境 2. 获取 MySQL YUM 仓库 3. 安装 MySQL 4. 启动…...

DeepSeek-R1深度解读

deepseek提出了一种通过强化学习&#xff08;RL&#xff09;激励大语言模型&#xff08;LLMs&#xff09;推理能力的方法&#xff0c;个人认为最让人兴奋的点是&#xff1a;通过RL发现了一个叫“Aha Moment”的现象&#xff0c;这个时刻发生在模型的中间版本中。在这个阶段&…...

吴恩达机器学习笔记复盘(六)梯度下降算法

简介 梯度下降&#xff08;Gradient Descent&#xff09;是一种常用的优化算法&#xff0c;广泛应用于机器学习、深度学习等领域&#xff0c;在这里是用于求J&#xff08;w,b&#xff09;局部最小值。 我自己觉得这样说有点过于抽象。换个直观点的说法就是&#xff0c;一个人…...

【环境配置】windows下vscode下无法激活conda环境、创建虚拟环境报错

前言 我的本地的系统&#xff0c;绝大部分是使用的ubuntu。去年下半年开始切换成windows&#xff0c;然后windows下使用vscode还需要注意一些小的配置。为了避免反复搜索&#xff0c;这里记录下。   当已经在 windows 下安装了anaconda、vscode&#xff0c;之后的使用有可能存…...

【Linux笔记】动态库与静态库的理解与加载

&#x1f525;个人主页&#x1f525;&#xff1a;孤寂大仙V &#x1f308;收录专栏&#x1f308;&#xff1a;Linux &#x1f339;往期回顾&#x1f339;&#xff1a;【Linux笔记】动态库与静态库的制作 &#x1f516;流水不争&#xff0c;争的是滔滔不 一、ELF文件二、ELF的形…...

ollama docker设置模型常驻显存

参考&#xff1a; https://github.com/ollama/ollama/issues/5272 https://deepseek.csdn.net/67cfd7c93b685529b708fdee.html 通过-e传入环境变量&#xff0c;ollama运行&#xff1a; docker run -d --gpusall -e OLLAMA_KEEP_ALIVE-1 -v ollama:/root/.ollama -p 11434:114…...

SAP-ABAP:SAP 主数据管理体系深度解析与学习路径介绍

Ⅰ. 主数据体系全景认知 1.1 主数据核心定位 #mermaid-svg-Lf3tZAfcROs5hlN4 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-Lf3tZAfcROs5hlN4 .error-icon{fill:#552222;}#mermaid-svg-Lf3tZAfcROs5hlN4 .error-t…...

Redis解决缓存击穿问题——两种方法

目录 引言 解决办法 互斥锁&#xff08;强一致&#xff0c;性能差&#xff09; 逻辑过期&#xff08;高可用&#xff0c;性能优&#xff09; 设计逻辑过期时间 引言 缓存击穿&#xff1a;给某一个key设置了过期时间&#xff0c;当key过期的时候&#xff0c;恰好这个时间点对…...

FGPA学习(二)实现LED流水灯

目录 一、6个LED灯实现流水灯 &#xff08;一&#xff09;实验逻辑 1、时钟和复位信号的处理 2、按键停止信号的处理 3、计数器的计数逻辑 4、LED 状态更新逻辑 &#xff08;二&#xff09;代码实现 &#xff08;三&#xff09;效果展示 二、vscode插件下载及其模块分…...

【蓝桥杯】每天一题,理解逻辑(4/90)【Leetcode 二进制求和】

题目描述 我们解析一下题目 我们可以理解到两个主要信息 给的是二进制的字符串返回他们的和 我们知道&#xff0c;十进制的加减法需要进位&#xff0c;例如&#xff1a;9716是因为91之后进了一位&#xff0c;二进制也是如此&#xff0c;只不过十进制是逢10进1&#xff0c;二…...

docker利用ollama +Open WebGUI在本地搭建部署一套Deepseek-r1模型

系统&#xff1a;没有限制&#xff0c;可以运行docker就行 磁盘空间&#xff1a;至少预留50GB; 内存&#xff1a;8GB docker版本&#xff1a;4.38.0 桌面版 下载ollama镜像 由于docker镜像地址&#xff0c;网络不太稳定&#xff0c;建议科学上网的一台服务器拉取ollama镜像&am…...

精准git动图拆解​

参考原文&#xff1a;精准git动图拆解​​ 该工具可精准识别并提取.git 动图的每一帧&#xff0c;无论是代码运行演示&#xff0c;还是项目流程展示的动图&#xff0c;都能完美处理。​ 快速格式转换​ 提取的动图帧会快速转换为 PNG 格式。PNG 无损压缩、支持透明背景&…...

让vscode远程开发也可以图形显示

目录 0. 摘要1. 保存查看2. jupyter内置inline渲染3. jupyter浏览器4. matplot修改后端5. SSH X11转发[※]6. 参考 0. 摘要 vscode登录远程服务器进行开发遇到图形显示需求时&#xff0c;该怎么处理&#xff1f;一般有几种方式&#xff1a; 保存下来查看jupyter内置的inline图…...

996引擎 - 红点系统

996引擎 - 红点系统 总结NPC 红点(TXT红点)Lua 红点1. Red_Point.lua2. UI_Ex.lua参考资料以下内容是在三端 lua 环境下测试的 总结 红点系统分几个部分组成。 M2中设置变量推送。 配置红点表。 Envir\Data\cfg_redpoint.xls 2.1. UI元素中找到ID填写 ids 列。 主界面挂载…...

Springboot List集合的校验方式

pom.xml 引入 <dependency><groupId>org.hibernate.validator</groupId><artifactId>hibernate-validator</artifactId><version>6.2.0.Final</version></dependency><dependency><groupId>org.springframework.b…...

基于图像识别的医学影像大数据诊断系统的设计与实现

标题:基于图像识别的医学影像大数据诊断系统的设计与实现 内容:1.摘要 随着医学影像技术的快速发展&#xff0c;医学影像数据量呈爆炸式增长&#xff0c;传统的人工诊断方式在处理海量数据时效率低下且容易出现误差。本研究的目的是设计并实现一个基于图像识别的医学影像大数据…...

黑马node.js教程(nodejs教程)——AJAX-Day01-04.案例_地区查询——查询某个省某个城市所有地区(代码示例)

文章目录 代码示例效果 代码示例 axiosTest.html <!DOCTYPE html> <!-- 文档类型声明&#xff0c;告诉浏览器这是一个HTML5文档 --> <html lang"en"> <!-- HTML根元素&#xff0c;设置文档语言为英语 --><head> <!-- 头部区域&am…...

PySide(PyQt),使用types.MethodType动态定义事件

以PySide(PyQt)的图片项为例&#xff0c;比如一个视窗的场景底图是一个QGraphicsPixmapItem&#xff0c;需要修改它的鼠标滚轮事件&#xff0c;以实现鼠标滚轮缩放显示的功能。为了达到这个目的&#xff0c;可以重新定义一个QGraphicsPixmapItem类&#xff0c;并重写它的wheelE…...

c语言基础编程入门练习题

[编程入门]成绩评定 题目描述 给出一百分制成绩&#xff0c;要求输出成绩等级‘A’、‘B’、‘C’、‘D’、‘E’。 90分以及90分以上为A&#xff0c;80-89分为B&#xff0c;70-79分为C&#xff0c;60-69分为D&#xff0c;60分以下为E。 输入格式 一个整数0&#xff0d;100…...

汽车安全确认等级-中国等保

1、概念解析 网络安全保证等级&#xff08;Cybersecurity Assurance Level&#xff09;通常指在不同标准或框架下&#xff0c;根据系统或数据的敏感性、重要性以及潜在风险划分的等级&#xff0c;用于指导组织采取相应的安全防护措施。以下是几个常见的网络安全保证等级体系及…...

Quartus + VScode 实现模块化流水灯

文章目录 一、通过VScode编写Verilog代码二、模块化编程三、代码示例 一、通过VScode编写Verilog代码 1、下载Vscode 2、下载相关插件 搜索Verilog就会弹出有如图所示的插件&#xff0c;下载并安装 3、创建Quartus项目 4、创建完成后点击Tools&#xff0c;选择Options 然后在…...

从两指到三指:Robotiq机器人自适应夹持器技术解析

工业自动化离不开高效工具的支持。Robotiq机器人工具凭借其模块化设计和智能化编程技术&#xff0c;提升了设备的灵活性和操作效率。Robotiq机器人工具精准的传感器和自适应夹持器技术&#xff0c;能够满足多样化的应用需求&#xff0c;为制造业、物流和科研等领域提供可靠的解…...

网络安全应急入门到实战

奇安信&#xff1a;95015网络安全应急响应分析报告&#xff08;2022-2024年&#xff09;官网可以下载 https://github.com/Bypass007/Emergency-Response-Notes 应急响应实战笔记 网络安全应急响应技术实战指南 .pdf 常见场景 第4章 勒索病毒网络安全应急响应 第5章 挖矿木…...

Flutter IconButton完全指南:高效使用与性能优化秘籍

目录 一、引言 二、IconButton 的基本用法 三、 进阶技巧 3.1 自定义形状与背景 3.2 带文本的 IconButton&#xff08;使用 Column 组合&#xff09; 3.3 自定义交互反馈 3.4 动态图标切换 3.5 组合式按钮&#xff08;图标 文字&#xff09; 四、高级应用 4.1 与主题…...

跨国生产制造企业:如何破解远距离数据传输难题?

在全球制造业数字化转型的背景下&#xff0c;跨国生产制造企业的文件传输需求正呈现指数级增长。无论是设计图纸、生产计划、质量控制数据&#xff0c;还是供应链协同信息&#xff0c;跨国文件传输已成为制造业高效运营的核心环节。 然而&#xff0c;制造业文件大数据传输具有文…...

大模型如何赋能安全防御?威胁检测与漏洞挖掘的“AI革命”

&#x1f680; 引言&#xff1a;大模型是“安全守护神”还是“双刃剑”&#xff1f; 当黑客用AI生成恶意代码&#xff0c;安全团队也能用大模型“魔法打败魔法”&#xff01; 划重点&#xff1a;大模型不仅是“生产力工具”&#xff0c;更是安全防御的“智能武器库”&#xff0…...

uniapp常用组件

写在前面 今天将uniapp中的组件都过了一遍&#xff0c;上手难度不大&#xff0c;但是还是遇到了一些问题&#xff1a; HBuilder实在是太难用&#xff0c;不管是插件生态还是设计之类的&#xff0c;总之就是用的哪哪不顺手虽然打开内置浏览器是挺方便的&#xff0c;但是不知道…...

Oracle OCP认证没落了吗?

Oracle OCP认证没落了吗? Oracle的OCP认证是数据库领域必考的一个认证&#xff0c;但随着国产化的发展&#xff0c;国内很多企业开发了自己的数据库产品&#xff0c;这种情况对很多人造成了错误的认识&#xff1a;OCP被淘汰了吗?不然&#xff0c;从行业需求、技术趋势、认证体…...

洛谷 P3986 斐波那契数列

P3986 斐波那契数列 题目描述 定义一个数列&#xff1a; f ( 0 ) a , f ( 1 ) b , f ( n ) f ( n − 1 ) f ( n − 2 ) f(0) a, f(1) b, f(n) f(n - 1) f(n - 2) f(0)a,f(1)b,f(n)f(n−1)f(n−2) 其中 a, b 均为正整数&#xff0c;n ≥ 2。 问有多少种 (a, b)&…...

使用fastapi部署stable diffusion模型

使用vscode运行stable diffusion模型&#xff0c;每次加载模型都需要10分钟&#xff0c;为算法及prompt调试带来了极大麻烦。使用jupyter解决自然是一个比较好的方案&#xff0c;但如果jupyter由于种种原因不能使用时&#xff0c;fastapi无疑成为了一个很好的选择。 参考github…...

PyTorch使用(3)-张量类型转换

文章目录 张量类型转换1. 张量转换为 numpy 数组1.1. 默认行为&#xff1a;共享内存1.2. 避免内存共享1.2.1. 使用 .copy()1.2.2. 使用 torch.clone() .numpy() 1.3. 处理 GPU 张量1.4. 分离梯度跟踪1.5. 代码示例1.6. 关键注意事项1.7. 总结 2. 标量张量和数字的转换2.1. tor…...

基于FPGA的DDS连续FFT 仿真验证

基于FPGA的 DDS连续FFT 仿真验证 1 摘要 本文聚焦 AMD LogiCORE IP Fast Fourier Transform (FFT) 核心,深入剖析其在 FPGA 设计中的应用。该 FFT 核心基于 Cooley - Tukey 算法,具备丰富特性,如支持多种数据精度、算术类型及灵活的运行时配置。文中详细介绍了其架构选项、…...

【Spring 默认是否管理 Request 和 Session Bean 的生命周期?】

要测试 Spring 默认是否管理 Request 和 Session 作用域的 Bean 的生命周期&#xff0c;可以通过以下步骤实现&#xff1a; 验证 Spring 是否创建了 Bean&#xff1a;检查 Spring 容器是否成功加载并管理了 Request 和 Session 作用域的 Bean。验证 Bean 的生命周期回调方法是…...

Git的基本指令

一、回滚 1.git init 在项目文件夹中打开bash生成一个.git的子目录&#xff0c;产生一个仓库 2.git status 查看当前目录下的所有文件的状态 3.git add . 将该目录下的所有文件提交到暂存区 4.git add 文件名 将该目录下的指定文件提交到暂存区 5.git commit -m 备注信…...

【微信小程序(云开发模式)变通实现DeepSeek支持语音】

整体架构 前端&#xff08;微信小程序&#xff09;&#xff1a; 使用微信小程序云开发能力&#xff0c;实现录音功能。将录音文件上传到云存储。调用云函数进行语音识别和 DeepSeek 处理。界面模仿 DeepSeek&#xff0c;支持文本编辑。 后端&#xff08;云函数 Node.js&#…...

前端使用 crypto-js库AES加解密

前端使用 crypto-js库AES加解密 为什么需要前端加密&#xff1f; 现在项目使用http协议&#xff0c;且登录界面的用户登录密码是明文传输&#xff0c;项目真正上线后&#xff0c;存在信息泄露风险。 所以准备用前端框架加密处理用户输入的密码再传输。 crypto-js 库 crypto…...

七天MySQL密集学习计划

七天MySQL密集学习计划 第1天&#xff1a;MySQL基础和环境搭建 上午&#xff08;理论安装&#xff09; 数据库基本概念MySQL是什么关系型数据库基础安装MySQL Windows/Mac下安装步骤MySQL Workbench安装 基本配置和连接 下午&#xff08;基础操作&#xff09; 数据库和表的…...

Python程序常用的配置文件格式及例子(上)

Python 中常用的配置文件格式有多种&#xff0c;每种格式都有其特点和适用场景。以下是常见的配置文件类型及简要说明&#xff1a; 1. INI 格式 特点&#xff1a;简单键值对&#xff0c;支持分节&#xff08;Section&#xff09;。文件扩展名&#xff1a;.ini, .cfgPython 库&…...

Go语言对于MySQL的基本操作

一.下载依赖 终端中输入&#xff1a; go get -u github.com/go-sql-driver/mysql 导入包 import ("database/sql"_ "github.com/go-sql-driver/mysql" ) 二.案例 package main//go get-u github.com/go-sql-driver/mysql 获取驱动 import ("databa…...

一键批量txt转DWG,DWG转txt——插件实现 CAD c#二次开发

如下图&#xff0c;我们有大量dwg需要转为txt格式&#xff0c;或txt格式坐标需要转为dwg格式&#xff0c;此插件可一键完成一个文件夹下所有文件的转换。 插件使用方式 命令行输入&#xff1a; netload 加载此dll插件&#xff0c; 输入&#xff1a; dwg2txt 可将dwg转为t…...

SpringBoot 集成 Minio (附带工具类)

Minio 官方文档&#xff1a; https://www.minio.org.cn/docs/minio/container/index.html MinIO是一个对象存储解决方案&#xff0c;它提供了与Amazon Web Services S3兼容的API&#xff0c;并支持所有核心S3功能。 MinIO有能力在任何地方部署 - 公有云或私有云&#xff0c;裸…...

图论——Prim算法

53. 寻宝(第七期模拟笔试) 题目描述 在世界的某个区域,有一些分散的神秘岛屿,每个岛屿上都有一种珍稀的资源或者宝藏。国王打算在这些岛屿上建公路,方便运输。 不同岛屿之间,路途距离不同,国王希望你可以规划建公路的方案,如何可以以最短的总公路距离将 所有岛屿联通…...

Linux系统上后门程序的原理细节,请仔细解释一下

在Linux系统上&#xff0c;后门程序通常通过隐蔽的方式绕过正常的安全机制&#xff0c;允许攻击者未经授权访问系统。以下是其工作原理的详细解释&#xff1a; 1. 隐蔽性 隐藏进程&#xff1a;后门程序常通过修改进程列表或使用rootkit技术隐藏自身&#xff0c;避免被ps、top…...

Cursor与Blender-MCP生成3D模型

随着DeepSeek的热度&#xff0c;各行各业接入AI智能&#xff0c;当然作为一个深受3D爱好者喜爱的软件——Blender&#xff0c;也接入了AI智能&#xff0c;通过Blender-MCP&#xff0c;开启一场Blender的智能化模型创建的世界之旅。 目录 1.准备工作2.环境配置2.1 Mac安装2.2 W…...