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

【QT基础入门 控件篇】QLineEdit 基础、高级和样式表使用详解

一、QLineEdit简介

  1. QLineEdit是一个单行文本编辑器,它可以让用户输入和编辑纯文本,也可以设置一些有用的编辑功能,如撤销和重做、剪切和粘贴、拖放等。
  2. QLineEdit: 可以根据不同的回显模式(echoMode)来显示不同的输入内容,例如密码或隐藏输入。QLineEdit还可以设置输入掩码(inputMask)和验证器(validator)来限制和检查用户的输入。QLineEdit还可以添加动作(action)和清除按钮(clearButton)来增加交互性。
  3. QLineEdit还可以设置占位符文本(placeholderText)来提示用户输入。QLineEdit还可以设置文本对齐方式(alignment)和文本边距(textMargins)来调整文本的显示。
  4. QLineEdit还可以设置字体(font)和样式表(styleSheet)来改变文本的外观。
  5. QLineEdit还可以使用信号和槽来响应用户的输入事件,例如文本改变(textChanged)、文本编辑完成(editingFinished)、返回键按下(returnPressed)等。

在本文中,我们将介绍QLineEdit的基础用法、高级功能和样式表设置,以及一些实用的示例代码,帮助你更好地理解和使用QLineEdit。

二、基础用法

要使用QLineEdit,首先需要包含QLineEdit头文件:

#include <QLineEdit>

然后,可以创建一个QLineEdit对象,并设置一些基本的属性,例如:

QLineEdit *edit = new QLineEdit; // 创建一个QLineEdit对象
edit->setText("Hello World"); // 设置初始文本
edit->setReadOnly(true); // 设置为只读模式
edit->setCursorPosition(0); // 设置光标位置为0
edit->setMaxLength(20); // 设置最大输入长度为20
edit->setEchoMode(QLineEdit::Normal); // 设置回显模式为正常
edit->setClearButtonEnabled(true); // 设置清除按钮
edit->setPlaceholderText("Enter something"); // 设置占位符文本

设置QLineEdit的文本内容

setText(const QString &text):这个属性用于设置QLineEdit的文本内容,它接受一个QString类型的参数,表示要显示的文本。如果文本长度超过最大输入长度,会被截断。例如:

edit->setText("Hello World"); // 设置文本内容为Hello World

返回QLineEdit的文本内容

text() const:这个属性用于返回QLineEdit的文本内容,它返回一个QString类型的值,表示当前显示的文本。如果设置了输入掩码或验证器,会返回过滤后的文本。例如:

QString text = edit->text(); // 获取文本内容

设置QLineEdit是否为只读模式

setReadOnly(bool readOnly):这个属性用于设置QLineEdit是否为只读模式,它接受一个bool类型的参数,表示是否只读。如果为true,用户不能修改文本内容,但可以选择和复制。如果为false,用户可以正常编辑文本内容。例如:

edit->setReadOnly(true); // 设置为只读模式

返回QLineEdit是否为只读模式

isReadOnly() const:这个属性用于返回QLineEdit是否为只读模式,它返回一个bool类型的值,表示是否只读。例如:

bool readOnly = edit->isReadOnly(); // 获取是否只读

设置QLineEdit的光标位置

setCursorPosition(int position):这个属性用于设置QLineEdit的光标位置,它接受一个int类型的参数,表示光标的位置。如果position小于0或大于文本长度,会被调整到合法的范围。例如:

edit->setCursorPosition(0); // 设置光标位置为0

返回QLineEdit的光标位置

cursorPosition() const:这个属性用于返回QLineEdit的光标位置,它返回一个int类型的值,表示光标的位置。例如:

int position = edit->cursorPosition(); // 获取光标位置

设置QLineEdit的最大输入长度

setMaxLength(int maxLength):这个属性用于设置QLineEdit的最大输入长度,它接受一个int类型的参数,表示最大输入长度。如果maxLength小于0,表示没有限制。例如:

edit->setMaxLength(20); // 设置最大输入长度为20

返回QLineEdit的最大输入长度

maxLength() const:这个属性用于返回QLineEdit的最大输入长度,它返回一个int类型的值,表示最大输入长度。例如:

int maxLength = edit->maxLength(); // 获取最大输入长度

设置QLineEdit的回显模式

setEchoMode(QLineEdit::EchoMode mode):这个属性用于设置QLineEdit的回显模式,它接受一个QLineEdit::EchoMode类型的参数,表示回显模式。回显模式可以是以下几种值之一:

QLineEdit::Normal:正常显示输入的文本。

QLineEdit::NoEcho:不显示输入的文本,但仍然接收输入事件。

QLineEdit::Password:显示输入的文本为圆点,用于输入密码。

QLineEdit::PasswordEchoOnEdit:在编辑时显示输入的文本,编辑完成后显示为圆点。

例如:

edit->setEchoMode(QLineEdit::Password); // 设置回显模式为密码

返回QLineEdit的回显模式

echoMode() const:这个属性用于返回QLineEdit的回显模式,它返回一个QLineEdit::EchoMode类型的值,表示回显模式。例如:

QLineEdit::EchoMode mode = edit->echoMode(); // 获取回显模式

设置QLineEdit是否显示清除按钮

setClearButtonEnabled(bool enable):这个属性用于设置QLineEdit是否显示清除按钮,它接受一个bool类型的参数,表示是否显示清除按钮。如果为true,当QLineEdit不为空时,会在右侧显示一个清除按钮,点击后可以清空文本内容。如果为false,不显示清除按钮。例如:

edit->setClearButtonEnabled(true); // 设置清除按钮

返回QLineEdit是否显示清除按钮

isClearButtonEnabled() const:这个属性用于返回QLineEdit是否显示清除按钮,它返回一个bool类型的值,表示是否显示清除按钮。例如:

bool enable = edit->isClearButtonEnabled(); // 获取是否显示清除按钮

设置QLineEdit的占位符文本

setPlaceholderText(const QString &placeholderText):这个属性用于设置QLineEdit的占位符文本,它接受一个QString类型的参数,表示占位符文本。当QLineEdit为空且没有焦点时,会显示占位符文本,用于提示用户输入。例如:

edit->setPlaceholderText("Enter something"); // 设置占位符文本

返回QLineEdit的占位符文本

placeholderText() const:这个属性用于返回QLineEdit的占位符文本,它返回一个QString类型的值,表示占位符文本。例如:

QString placeholderText = edit->placeholderText(); // 获取占位符文本

设置QLineEdit是否显示清除按钮

setClearButtonEnabled(bool enable):设置QLineEdit是否显示清除按钮,如果为true,当QLineEdit不为空时,会在右侧显示一个清除按钮,点击后可以清空文本内容。

返回QLineEdit是否显示清除按钮

isClearButtonEnabled() const:返回QLineEdit是否显示清除按钮。

三、高级功能

除了基本的属性和方法,QLineEdit还提供了一些高级的功能,例如

限制用户的输入格式

  • setInputMask(const QString &inputMask):设置QLineEdit的输入掩码,输入掩码是一个字符串,用于限制用户的输入格式,例如:
edit->setInputMask("000.000.000.000;_"); // 设置输入掩码为IP地址格式,空位用下划线填充

输入掩码的字符串由以下几种字符组成:

  • A:表示必须输入一个字母(A-Z,a-z)。

  • a:表示可以输入一个字母,也可以不输入。

  • N:表示必须输入一个字母或数字(A-Z,a-z,0-9)。

  • n:表示可以输入一个字母或数字,也可以不输入。

  • X:表示必须输入一个任意字符。

  • x:表示可以输入一个任意字符,也可以不输入。

  • 9:表示必须输入一个数字(0-9)。

  • 0:表示可以输入一个数字,也可以不输入。

  • D:表示必须输入一个非零的数字(1-9)。

  • d:表示可以输入一个非零的数字,也可以不输入。

  • #:表示可以输入一个数字或加号(+)或减号(-),也可以不输入。

  • H:表示必须输入一个十六进制字符(0-9,A-F,a-f)。

  • h:表示可以输入一个十六进制字符,也可以不输入。

  • B:表示必须输入一个二进制字符(0-1)。

  • b:表示可以输入一个二进制字符,也可以不输入。

  • :表示后面的字母都转换为大写。

  • <:表示后面的字母都转换为小写。

  • !:表示关闭大小写转换。

  • \:表示转义后面的字符,使其失去特殊含义。

  • ;:表示分隔符,后面的字符表示空位的填充字符,默认为空格。

  • inputMask() const:返回QLineEdit的输入掩码。

  • setValidator(const QValidator *validator):设置QLineEdit的验证器,验证器是一个对象,用于检查用户的输入是否符合一定的规则,例如:

验证器

QIntValidator *validator = new QIntValidator(0, 100); // 创建一个整数验证器,限制输入范围为0到100
edit->setValidator(validator); // 设置验证器

Qt提供了以下几种内置的验证器类:

  • QIntValidator:用于验证整数输入,可以设置最小值和最大值。
  • QDoubleValidator:用于验证浮点数输入,可以设置最小值,最大值和小数位数。
  • QRegExpValidator:用于验证正则表达式输入,可以设置一个QRegExp对象作为匹配模式。

自定义验证器

只需要继承QValidator类,并重写validate(QString &input, int &pos) const方法,该方法接受一个输入字符串和一个光标位置,返回一个QValidator::State枚举值,表示输入的有效性,有以下几种可能的值:

  • QValidator::Invalid:表示输入是无效的,用户不能继续输入。

  • QValidator::Intermediate:表示输入是部分有效的,用户可以继续输入,但还没有达到最终的有效状态。

  • QValidator::Acceptable:表示输入是完全有效的,用户可以结束输入。

  • validator() const:返回QLineEdit的验证器。

  • addAction(QAction *action, QLineEdit::ActionPosition position):向QLineEdit添加一个动作,动作是一个对象,可以表示一个图标,一个文本,或者一个图标和文本的组合,可以关联一个槽函数,用于执行一些操作,例如:

QAction *action = new QAction(QIcon(":/images/search.png"), "Search"); // 创建一个动作,包含一个搜索图标和文本
QObject::connect(action, &QAction::triggered, this, &search); // 连接动作的触发信号和一个搜索槽函数
edit->addAction(action, QLineEdit::Trailing); // 向输入框添加动作,放在右侧

position参数可以是以下两个值之一:

- QLineEdit::LeadingPosition:表示动作放在输入框的左侧。
- QLineEdit::TrailingPosition:表示动作放在输入框的右侧。

actions() const:返回QLineEdit的动作列表。

四、样式表设置

QLineEdit还可以使用样式表(styleSheet)来改变文本的外观,样式表是一种基于CSS的语言,用于描述控件的样式,例如:

edit->setStyleSheet("color: blue; font-size: 20px; border: 2px solid green;"); // 设置输入框的文本颜色为蓝色,字体大小为20像素,边框为2像素的绿色实线

样式表的语法和用法可以参考Qt的官方文档,这里只列出一些常用的属性和值:

设置文本字体

color:设置文本的颜色,可以使用颜色名或者RGB值,例如:

color: red; // 设置文本颜色为红色
color: rgb(255, 0, 0); // 设置文本颜色为红色,使用RGB值

font-size:设置文本的字体大小,可以使用像素或者点数,例如:

font-size: 20px; // 设置文本字体大小为20像素
font-size: 12pt; // 设置文本字体大小为12点

font-family:设置文本的字体名称,可以使用系统字体或者自定义字体,例如:

font-family: Arial; // 设置文本字体为Arial
font-family: "Times New Roman"; // 设置文本字体为Times New Roman,使用双引号包围

font-weight:设置文本的字体粗细,可以使用数字或者关键字,例如:

font-weight: 600; // 设置文本字体粗细为600
font-weight: bold; // 设置文本字体粗细为粗体,相当于700

font-style:设置文本的字体样式,可以使用以下几个关键字之一:

normal:正常样式,不倾斜也不加粗。

italic:斜体样式,倾斜显示。

oblique:倾斜样式,倾斜显示,和italic的区别是oblique是通过对normal进行变形得到的,而italic是字体本身的样式。

设置边框的样式

也可以分别设置上下左右四个方向的边框样式,例如:

border-top: 2px solid red; // 设置上边框为2像素的红色实线
border-right: 3px dashed blue; // 设置右边框为3像素的蓝色虚线
border-bottom: 4px dotted green; // 设置下边框为4像素的绿色点状线
border-left: 5px double yellow; // 设置左边框为5像素的黄色双线

border-width:设置边框的宽度,可以使用像素值,例如:

border-width: 2px; // 设置边框宽度为2像素

border-style:设置边框的样式,可以使用以下几个关键字之一:

none:无边框。

solid:实线边框。

dashed:虚线边框。

dotted:点状边框。

double:双线边框。

groove:凹槽边框。

ridge:凸起边框。

inset:内嵌边框。

outset:外凸边框。

border-color:设置边框的颜色,可以使用颜色名或者RGB值,例如:

border-color: green; // 设置边框颜色为绿色
border-color: rgb(0, 255, 0); // 设置边框颜色为绿色,使用RGB值

border-radius:设置边框的圆角半径,可以使用像素值,例如:

border-radius: 10px; // 设置边框圆角半径为10像素

设置背景图片

background-color:设置背景颜色,可以使用颜色名或者RGB值,例如:

background-color: white; // 设置背景颜色为白色
background-color: rgb(255, 255, 255); // 设置背景颜色为白色,使用RGB值

background-image:设置背景图片,可以使用图片的URL,例如:

background-image: url(":/images/background.png"); // 设置背景图片为资源文件中的background.png

background-repeat:设置背景图片的重复方式,可以使用以下几个关键字之一:

repeat:平铺重复。

repeat-x:水平方向重复。

repeat-y:垂直方向重复。

no-repeat:不重复。

background-position:设置背景图片的位置,可以使用以下几个关键字之一:

left:左对齐。

right:右对齐。

top:上对齐。

bottom:下对齐。

center:居中对齐。

background-origin:设置背景图片的原点,可以使用以下几个关键字之一:

border:相对于边框。

padding:相对于内边距。

content:相对于内容。

background-clip:设置背景图片的裁剪范围,可以使用以下几个关键字之一:

border:裁剪到边框。

padding:裁剪到内边距。

content:裁剪到内容。

background-attachment:设置背景图片的附着方式,可以使用以下几个关键字之一:

scroll:随着控件滚动。

fixed:固定不动。

local:随着内容滚动。

示例代码

下面是一个使用QLineEdit的示例代码,创建了一个简单的登录界面,包括用户名、密码和登录按钮,以及一些输入检查和提示功能:

https://download.csdn.net/download/qq_43445867/88504941

相关文章:

【QT基础入门 控件篇】QLineEdit 基础、高级和样式表使用详解

一、QLineEdit简介 QLineEdit是一个单行文本编辑器&#xff0c;它可以让用户输入和编辑纯文本&#xff0c;也可以设置一些有用的编辑功能&#xff0c;如撤销和重做、剪切和粘贴、拖放等。QLineEdit: 可以根据不同的回显模式&#xff08;echoMode&#xff09;来显示不同的输入内…...

网络安全(网络安全)小白自学

想自学网络安全&#xff08;黑客技术&#xff09;首先你得了解什么是网络安全&#xff01;什么是黑客&#xff01; 网络安全可以基于攻击和防御视角来分类&#xff0c;我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术&#xff0c;而“蓝队”、“安全运营”、“安全…...

dupeGuru 清理微信重复文件

本文摘录于&#xff1a;https://www.bilibili.com/video/BV13p4y1G75Y/?spm_id_from333.337.search-card.all.click&vd_source483e5c52353ea59d1a5eadac7737591a只是做学习备份之用&#xff0c;绝无抄袭之意&#xff0c;有疑惑请联系本人&#xff01; 微信用了七八年,文件…...

华为RS设备状态及接口配置命令

1、查看硬件信息 ①查看序列号 查看整机序列号 display esn display sn ②、查看功率 电源功率 display power 查看光模块功率 display transceiver interface gigabitethernet 1/0/0 verbose ③、查看风扇 display fan ④、查看温度 display temperature all ⑤、查看硬…...

单链表的应用(2)

环形链表的约瑟夫问题 编号为 1 到 n 的 n 个人围成一圈。从编号为 1 的人开始报数&#xff0c;报到 m 的人离开。 下一个人继续从 1 开始报数。 n-1 轮结束以后&#xff0c;只剩下一个人&#xff0c;问最后留下的这个人编号是多少&#xff1f; 利用链表实现 思路&#xff1…...

【Boost | C++】使用Boost库创建文件夹

#include <boost/filesystem.hpp> #include <iostream> bool CreateDirectory(const std::string &dir_path) {try {if (...

月报总结|Moonbeam 10月份大事一览

万圣节快乐&#xff01;时间一晃眼&#xff0c;10月已经迈入尾声&#xff0c;也即将迎来寒冷的冬天。但与季节相反&#xff0c;加密产业近期的发展可以说是高潮起伏&#xff0c;热度不断攀升。Moonbeam在10月中也发布了许多重大的更新&#xff0c;如Uniswap V3前段上线、众贷DO…...

Latex安装记录

Title:Latex 基本概念 Tex:是一种具有编译和排版功能的基础语言&#xff0c;相当于C语言。 Latex:&#xff1a;LaTex是 Tex 的扩展版本&#xff0c;拥有多种宏包&#xff0c;能实现比 Tex 更多的功能。 TexLive&#xff1a;是一种 Tex 语言的发行版本。 Texstudio: 一种软件相…...

JavaEE-博客系统2(功能设计)

本部分内容&#xff1a;实现博客列表页&#xff1b;web程序问题的分析方法&#xff1b;实现博客详情页&#xff1b; 该部分的代码如下&#xff1a; WebServlet("/blog") public class BlogServlet extends HttpServlet {//Jackson ObjectMapper类(com.fasterxml.jac…...

2023年【高处安装、维护、拆除】免费试题及高处安装、维护、拆除找解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 高处安装、维护、拆除免费试题根据新高处安装、维护、拆除考试大纲要求&#xff0c;安全生产模拟考试一点通将高处安装、维护、拆除模拟考试试题进行汇编&#xff0c;组成一套高处安装、维护、拆除全真模拟考试试题&a…...

antv/g6之交互模式mode

什么是mode 在 AntV G6 中&#xff0c;“mode” 是用于配置图表交互模式的一种属性。通过设置 “mode”&#xff0c;可以控制图表的行为&#xff0c;以满足不同的交互需求。可能在不同的场景需要展现的交互行为不一样。比如查看模式下点击一个点就选中的状态&#xff0c;在编辑…...

基于8086电压表系统仿真系统设计

**单片机设计介绍&#xff0c;1665基于8051单片机与1601LCD的计算器设计 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 一个基于8086的电压表系统仿真系统可以分为硬件和软件两部分。 硬件部分包括输入设备&#xff08;例如模拟…...

Docker与微服务实战——基础篇

Docker与微服务实战——基础篇 第一章 Docker 简介1.1 docker 理念1.2 容器与虚拟机比较 第二章 Docker 安装2.1 前提说明2.2 Docker的基本组成2.2.1 镜像&#xff08;image&#xff09;2.2.2 容器&#xff08;container&#xff09;2.2.3 仓库&#xff08;repository&#xff…...

旧手机搭建linuxcentos

centos服务器搭建termux搭建centos旧手机搭建linux服务器ubuntu旧手机搭建网站旧手机搭建linux debian ubuntu centos 旧手机搭建宝塔搭建 32位Linux搭建宝塔 Linuxdeploy搭建宝塔 旧手机搭建服务器有需要的来 包答疑包售后 Linuxdeploy需要root mobile搭建服务器 脚本/工具...

使用pandas处理excel文件【Demo】

一、代码示例 import pandas as pd from pandas import Series,DataFrame from pandasql import sqldf import matplotlib.pyplotidInfos DataFrame(pd.read_excel(home_data.xlsx))print(idInfos.head(2))print(idInfos.dtypes)# print(idInfos[:][姓名]) # 自定义一个函数s…...

【Maven】<dependencyManagement>详解

<dependencyManagement> 元素是 Maven POM 文件中的一个非常重要的元素&#xff0c;它用于集中管理项目中所有模块的依赖项版本&#xff0c;允许您在父 POM 中定义依赖版本&#xff0c;然后在子模块中引用这些版本而不需要显式指定版本号。这可以大大减少维护成本&#x…...

apache-tomcat-9.0.29 安装配置教程

链接&#xff1a;https://pan.baidu.com/s/100buXYpn8w8xjI2KdvHk2Q?pwd2mwc 提取码&#xff1a;2mwc 1.将压缩包解压到指定文件夹下 2.进入bin文件夹下 3.找到setclasspath.bat文件 4.推荐用notepad打开文件&#xff0c;并做如下配置&#xff08;可解决tomcat启动闪退问题&…...

精品基于Python的图书借阅归还管控系统

《[含文档PPT源码等]精品基于Python的图书管控系统》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程、包运行成功&#xff01; 软件开发环境及开发工具&#xff1a; 开发语言&#xff1a;python 使用框架&#xff1a;Django 前端技术&#xff1a;Ja…...

gorm的自动化工具gen

gorm的自动化工具gen 官方 https://gorm.io/zh_CN/gen/假设数据库结构如 这里使用gen-tool 安装 go install gorm.io/gen/tools/gentoollatest用法 gentool -hUsage of gentool:-c string配置文件名、默认值 “”、命令行选项的优先级高于配置文件。 -db string指定Driver…...

dubbo没有找到生产者

1、没有找到生产者 com.alibaba.dubbo.rpc.RpcException: No provider available from registry 127.0.0.1:2181 for service .... , please check status of providers(disabled, not registered or in blacklist)2、 查看是不是 对应的providers 没有 注册上去 找到 zk 对应…...

调参不再玄学:手把手教你优化智能车(电磁组)舵机PD控制参数,告别‘画龙’

智能车电磁组舵机控制实战&#xff1a;从参数原理到赛道调优的完整指南 当你的智能车在直道上像喝醉一样左右摇摆&#xff0c;或者在弯道犹豫不决时&#xff0c;大多数问题都指向同一个核心——舵机控制参数设置不当。这不是魔法&#xff0c;而是一门可以通过系统方法掌握的科学…...

5分钟学会lychee-rerank-mm:图文混合内容排序不再难

5分钟学会lychee-rerank-mm&#xff1a;图文混合内容排序不再难 1. 为什么需要多模态重排序 在日常工作和生活中&#xff0c;我们经常遇到需要从大量图文内容中找出最相关结果的情况。比如&#xff1a; 电商平台需要为用户搜索"猫咪玩具"展示最匹配的商品图片和描…...

开始你的「一人公司」

未来大部分的公司&#xff0c;都将是「一个人 N 个 AI」的模式。 这意味着你不再需要很多前置条件&#xff0c;就能开始交付真正的产品。 阻碍你行动的不再是资金、团队或资源&#xff0c;而更多是——你有没有意愿。一、AI 会让认知成本趋近于零这是最关键的判断。电的出现让…...

jless屏幕滚动命令终极指南:掌握ctrl-b、ctrl-f、PageUp、PageDown高效浏览JSON数据

jless屏幕滚动命令终极指南&#xff1a;掌握ctrl-b、ctrl-f、PageUp、PageDown高效浏览JSON数据 【免费下载链接】jless jless is a command-line JSON viewer designed for reading, exploring, and searching through JSON data. 项目地址: https://gitcode.com/gh_mirrors…...

Tinycon终极指南:如何在网站favicon上优雅显示通知气泡的完整教程

Tinycon终极指南&#xff1a;如何在网站favicon上优雅显示通知气泡的完整教程 【免费下载链接】tinycon A small library for manipulating the favicon, in particular adding alert bubbles and changing images. 项目地址: https://gitcode.com/gh_mirrors/ti/tinycon …...

开源力量:OpenClaw+gemma-3-12b-it构建低成本个人AI助手

开源力量&#xff1a;OpenClawgemma-3-12b-it构建低成本个人AI助手 1. 为什么选择开源模型OpenClaw组合&#xff1f; 去年我尝试用商业API搭建个人自动化助手时&#xff0c;发现两个致命问题&#xff1a;一是每月Token费用超过预期3倍&#xff08;主要来自长链条任务的反复调…...

SEO关键词查询工具哪个好_SEO工具的使用成本是多少

SEO关键词查询工具哪个好_SEO工具的使用成本是多少 在当今数字化时代&#xff0c;优化网站的搜索引擎表现&#xff08;SEO&#xff09;已经成为每一个企业和网站运营者必不可少的一部分。其中&#xff0c;关键词查询工具是SEO工作中不可或缺的一环。在众多的SEO工具中&#xf…...

Vue3集成百度地图GL版:从自定义样式到动态轨迹绘制实战

1. Vue3集成百度地图GL版的前期准备 第一次在Vue3项目里用百度地图GL版时&#xff0c;我踩了不少坑。这里分享下最稳妥的集成方案&#xff0c;帮你避开那些我趟过的雷。首先得明白&#xff0c;百度地图GL版是基于WebGL技术的新一代地图API&#xff0c;相比传统版本性能更好、效…...

2025年大模型年度总结:Training Recipe与业务落地思考

一、项目介绍准备 项目 1&#xff1a;基于 RAG 的大语言模型关系抽取 1、为什么不用传统语义相似度检索&#xff0c;改用关系原型检索&#xff1f; 传统相似度检索易召回伪近邻样本&#xff08;语义相近、头尾实体不同→关系不同&#xff09;&#xff0c;干扰模型判断。 我先把…...

计算机内存与缓存完全指南

计算机内存与缓存完全指南 目录 计算机存储体系概览内存&#xff08;RAM&#xff09;深度解析 2.1 RAM 的基本原理2.2 DRAM vs SRAM2.3 DDR 内存发展历史与对比2.4 内存关键参数详解2.5 内存模组类型&#xff08;DIMM / SO-DIMM / LPDDR&#xff09; CPU 缓存深度解析 3.1 缓…...