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

【源码阅读/Vue Flask前后端】简历数据查询功能

目录

  • 一、Flask后端部分
    • model
    • Service
    • route
  • 二、Vue前端部分
    • index.js
  • main.vue
    • 功能界面
      • template
      • script
      • style

一般就是三个层面,model层面用来建立数据库的字段,service用来对model进行操作,写一些数据库操作的代码,route就是具体的功能了,其中会包含一些数据库service层的函数

一、Flask后端部分


model

# 创建基础模型类
Base = declarative_base()# 创建数据库连接
engine = create_engine('sqlite:data/hyq/code/llf/yuanshenqidong/backend/app/models/test.db')
Session = sessionmaker(bind=engine)
class ExternalResume(Base):__tablename__ = 'external_resume'uuid = Column(String(255), primary_key=True, unique=True)person_id = Column(Integer, ForeignKey('person.person_id'))name = Column(String(255), nullable=False)gender = Column(String(255))age = Column(Integer)brith_date = Column(DateTime)email = Column(String(255))phone = Column(String(255))educational_background = Column(String(255))work_experience = Column(String(255))project_experience = Column(String(255))skill = Column(String(255))research_achievement = Column(String(255))award = Column(String(255))person = relationship("Person", back_populates="external_resume")

tablename = ‘external_resume’ 指定了数据库中对应的表名
类继承自 Base,这是 SQLAlchemy 的声明性基类
person = relationship(“Person”, back_populates=“external_resume”):定义了与 Person 模型的双向关系
declarative_base() 是 SQLAlchemy 提供的一个工厂函数,用于创建所有模型类的基类
继承自这个 Base 的类会被 SQLAlchemy 自动识别为数据库模型
create_engine() 创建了一个数据库引擎实例
注意 SQLite 的连接字符串是三个斜杠 (sqlite:///) 后接文件路径
sessionmaker 创建了一个会话工厂类
bind=engine 将这个会话工厂绑定到之前创建的数据库引擎
之后可以通过 Session() 来创建实际的数据库会话实例,用于执行数据库操作
在这里插入图片描述
将不同的模型分类到 model.py 和 newmodel.py 中,便于管理。通过 init.py 统一导出,使外部代码可以方便地导入所有模型。
潜在问题
User 类重复
model.py 和 newmodel.py 都定义了 User 类,可能会导致冲突。
如果两个 User 是不同的模型,应该重命名其中一个(如 NewUser)。
如果相同,应该统一放在一个文件中。
Session 可能混淆
Session 是 SQLAlchemy 的会话类,但通常建议命名为 DBSession 或类似名称,避免与标准库的 session 混淆。
Base 的导出
Base 是 SQLAlchemy 的基类,通常不需要在 all 中导出,除非外部代码需要直接访问它(如创建表)。

Service

def get_all_resume_data():"""查询数据库中所有简历数据返回:List[Dict]: 包含所有简历数据的列表,每个简历是一个字典"""try:with Session() as session:resumes = session.query(ExternalResume).all()results=[]for resume in resumes:resume_dict = {'name': resume.name,'gender': resume.gender,'age': resume.age,'birth_date': resume.brith_date.strftime('%Y-%m-%d') if resume.brith_date else None,'email': resume.email,'phone': resume.phone,'educational_background': resume.educational_background,'work_experience': resume.work_experience,'project_experience': resume.project_experience,'skill': resume.skill,'research_achievement': resume.research_achievement,'award': resume.award}results.append(resume_dict)print(resume_dict)print(f"成功查询到 {len(results)} 条简历记录")return resultsexcept Exception as e:print(f"查询数据库时发生错误: {str(e)}")return []

with Session():
使用上下文管理器创建数据库会话,确保会话在使用后自动关闭。(这个写法很像打开文件)
session.query(ExternalResume).all():
查询 ExternalResume 表的所有记录,返回一个包含所有简历对象的列表。对象列表,遍历每一个对象,并获取数据库对象的属性
在返回的时候,也构造类似的数据,列表中是字典,每个字典对应着数据库中的一行,键是每一行的属性。字典列表。

route

# 查询知识库
@resume_bp.route('/resume-files', methods=['GET'])
def get_resume_files():try:result = get_all_resume_data()if result is None:return jsonify({'error': '获取简历文件失败'}), 500return jsonify(result), 200except Exception as e:print(f"获取简历文件时出错: {str(e)}")return jsonify({'error': f'服务器内部错误: {str(e)}'}), 500

字典列表是可以直接用jsonify加工成json数据的,然后回传给前端
jsonify 是 Flask 框架中一个非常实用的函数,用于将 Python 数据结构转换为 JSON 格式的 HTTP 响应。

二、Vue前端部分


前端部分主要为三部分,一个是路由.js文件,一个main.vue主界面,还有一个我们的功能界面

index.js

import RecruitmentView from '@/views/RecruitmentView.vue'
import AbilityView from '@/views/AbilityView.vue'

用于导入页面文件
在这里插入图片描述

const routes = [{ path: '/main', component: Main },{ path: '/', component: Login },{ path: '/register', component: Register },{ path: '/modify', component: Modify },{path: '/recruitment',name: 'recruitment',component: RecruitmentView},{path: '/ability',name: 'ability',component: AbilityView},
];

routes 是一个数组,定义了应用程序的所有路由规则。
每个路由规则是一个对象,包含:

path: URL 路径(就是浏览器访问的地址)

component: 对应的 Vue 组件(页面)

const router = createRouter({history: createWebHistory(),routes
});export default router;

使用 createRouter 创建路由实例。
history: 使用 createWebHistory() 创建基于 HTML5 History API 的路由模式(干净的 URL,无 #)
routes: 传入上面定义的路由配置
导出创建的路由实例,以便在 Vue 应用程序的主文件(通常是 main.js 或 app.js)中使用。

main.vue

 <el-button class="aside-btn upload-file-btn" type="primary" :icon="Plus":class="{ 'icon-only': isCollapsed }"@click="goToRecruitmentPage">{{ isCollapsed ? '' : '人才招聘分析' }}</el-button>

type=“primary”:

设置按钮类型为 primary(主按钮,通常是蓝色)
:icon=“Plus”:

动态绑定图标属性,使用 Element Plus 的 Plus(加号)图标

需要从 Element Plus 导入 Plus 图标:import { Plus } from ‘@element-plus/icons-vue’
:class=“{ ‘icon-only’: isCollapsed }”:

动态绑定 class,当 isCollapsed 为 true 时,添加 icon-only 类

这通常用于侧边栏折叠时只显示图标不显示文字的场景
@click=“goToRecruitmentPage”:

点击事件绑定,点击按钮时调用 goToRecruitmentPage 方法

 goToRecruitmentPage() {// 使用 Vue Router 进行页面跳转this.$router.push('/recruitment');},

在script的methods下完成跳转
.push() 方法:

Vue Router 的核心导航方法

作用:向浏览器的历史记录栈添加一个新记录,并跳转到指定路由

等效于用户点击 的效果
在这里插入图片描述

功能界面

template

整体结构,分为三行

<div class="recruitment-container"><el-row :gutter="20"><!-- 三个主要部分 --><el-col :span="24">标题和总览卡片</el-col><div v-show="showAnalysis">数据分析图表区域</div><el-col :span="24">表格区域</el-col></el-row>
</div>

在这里插入图片描述
标题和总览区域

<el-card class="overview-card" shadow="hover"><div class="dashboard-header"><h2>人才池运营看板</h2><div class="header-actions"><el-button type="primary" @click="showAnalysis = !showAnalysis":icon="showAnalysis ? 'Close' : 'DataAnalysis'" >{{ showAnalysis ? '关闭分析' : '数据分析' }}</el-button></div><div class="total-stats"><div class="stat-item"><div class="stat-value">{{ total }}</div><div class="stat-label">简历总数</div></div><div class="stat-item"><div class="stat-value">{{ todayNew }}</div><div class="stat-label">今日新增</div></div></div></div>
</el-card>

使用 el-card 创建卡片式布局

包含:

主标题 “人才池运营看板”

一个切换按钮,用于显示/隐藏分析图表区域

两个统计数字:简历总数和今日新增简历
卡片式布局,应该就是标签并排着一个一个

数据分析图表区域 (条件渲染)

<div v-show="showAnalysis" class="analysis-container"><el-row :gutter="20"><el-col :span="24"><!-- 技术栈分布图表 --><el-card class="chart-card" shadow="hover"><template #header><span class="chart-title">技术栈分布</span></template><div ref="skillChart" class="chart-container skill-chart"></div></el-card><!-- 学历分布图表 --><el-card class="chart-card" shadow="hover"><template #header><span class="chart-title">学历分布</span></template><div ref="educationChart" class="chart-container education-chart"></div></el-card></el-col></el-row>
</div>

使用 v-show 控制显示/隐藏

包含两个图表卡片:

技术栈分布图表

学历分布图表

使用 ref 属性为图表容器注册引用,便于后续用 ECharts 等库渲染图表

表格区域

<el-card class="table-card" shadow="hover"><el-table :data="resumeList" stripe v-loading="loading"height="calc(100vh - 600px)"><!-- 多个表格列 --><el-table-column prop="name" label="姓名" /><el-table-column prop="gender" label="性别" /><!-- 其他列... --><!-- 特殊处理的列 --><el-table-column prop="skill" label="技能"><template #default="scope"><el-tag v-for="skill in scope.row.skill?.split(',')">{{ skill.trim() }}</el-tag></template></el-table-column><!-- 长文本使用 tooltip 显示 --><el-table-column prop="work_experience" label="工作经验"><template #default="scope"><el-tooltip :content="scope.row.work_experience"><div class="truncate">{{ scope.row.work_experience }}</div></el-tooltip></template></el-table-column></el-table><!-- 分页组件 --><el-paginationv-model:current-page="currentPage"v-model:page-size="pageSize"@size-change="handleSizeChange"@current-change="handleCurrentChange"/>
</el-card>

在这里插入图片描述

script

导入依赖

import { ref, onMounted, computed, watch, nextTick } from 'vue'
import axios from 'axios'
import { ElMessage } from 'element-plus'
import * as echarts from 'echarts'
import { DataAnalysis, Close } from '@element-plus/icons-vue'

Vue 相关:Composition API 的核心方法

Axios:用于 HTTP 请求

Element Plus:消息提示组件和图标

ECharts:数据可视化图表库
响应式数据

const allResumeList = ref([])        // 所有简历数据
const currentPage = ref(1)           // 当前页码
const pageSize = ref(10)             // 每页条数
const loading = ref(false)           // 加载状态
const total = ref(0)                 // 数据总数
const todayNew = ref(0)              // 今日新增简历数
const showAnalysis = ref(false)      // 是否显示分析图表
const analysisType = ref('skill')    // 当前分析维度
// 图表 DOM 引用
const skillChart = ref(null)         
const educationChart = ref(null)
// 图表实例
let skillChartInstance = null
let educationChartInstance = null

计算属性

const resumeList = computed(() => {const start = (currentPage.value - 1) * pageSize.valueconst end = start + pageSize.valuereturn allResumeList.value.slice(start, end)
})

根据当前分页参数计算当前页显示的数据
核心方法
数据获取

const fetchResumeData = async () => {loading.value = truetry {const response = await axios.get('http://10.1.108.220:18000/resume/resume-files')allResumeList.value = response.datatotal.value = response.data.lengthtodayNew.value = Math.floor(Math.random() * 10) // 模拟数据if (response.data.length === 0) {ElMessage.warning('暂无简历数据')} else {ElMessage.success('数据加载成功')}} catch (error) {ElMessage.error('获取数据失败')} finally {loading.value = false}
}

在这里插入图片描述
当点击事件发生的时候,就获取简历数据

返回值

return {resumeList,currentPage,pageSize,total,loading,handleSizeChange,handleCurrentChange,skillChart,educationChart,todayNew,showAnalysis,DataAnalysis,Close
}

暴露给模板使用的所有变量和方法

style

相关文章:

【源码阅读/Vue Flask前后端】简历数据查询功能

目录 一、Flask后端部分modelServiceroute 二、Vue前端部分index.js main.vue功能界面templatescriptstyle 一般就是三个层面&#xff0c;model层面用来建立数据库的字段&#xff0c;service用来对model进行操作&#xff0c;写一些数据库操作的代码&#xff0c;route就是具体的…...

R语言对偏态换数据进行转换(对数、平方根、立方根)

我们进行研究的时候经常会遇见偏态数据&#xff0c;数据转换是统计分析和数据预处理中的一项基本技术。使用 R 时&#xff0c;了解如何正确转换数据有助于满足统计假设、标准化分布并提高分析的准确性。在 R 中实现和可视化最常见的数据转换&#xff1a;对数、平方根和立方根转…...

链表(C++)

这是本人第二次学习链表&#xff0c;第一次学习链表是在大一上的C语言课上&#xff0c;首次接触&#xff0c;感到有些难&#xff1b;第二次是在大一下学习数据结构时&#xff08;就是这次&#xff09;&#xff0c;使用C再次理解链表。同时&#xff0c;这也是开启数据结构学习写…...

算法-前缀和与差分

一、前缀和&#xff08;Prefix Sum&#xff09; 1. 核心思想 前缀和是一种预处理数组的方法&#xff0c;通过预先计算并存储数组的前缀和&#xff0c;使得后续的区间和查询可以在**O(1)**时间内完成。 2. 定义 给定数组 nums&#xff0c;前缀和数组 prefixSum 的每个元素 p…...

网关接口超时?用Java实现接口快速返回,后台继续执行的方法

网关接口超时&#xff1f;用Java实现接口快速返回&#xff0c;后台继续执行的方法 在开发过程中&#xff0c;我们经常会遇到网关接口由于超时限制而导致请求失败的情况。然而&#xff0c;有些接口本身就需要较长时间来执行任务&#xff0c;这时我们不能简单地增加超时时间&…...

HTTP---基础知识

天天开心&#xff01;&#xff01;&#xff01; 文章目录 一、HTTP基本概念1. 什么是HTTP&#xff0c;又有什么用&#xff1f;2. 一次HTTP请求的过程3.HTTP的协议头4.POST和GET的区别5. HTTP状态码6.HTTP的优缺点 二、HTTP的版本演进1.各个版本的应用场景2、注意要点 三、HTTP与…...

python基础学习三(元组及字符串的使用)

文章目录 元组什么是元组元组的创建方式为什么要将元组设计成不可变序列元组的遍历集合集合的相关操作集合操作集合的数学操作集合生成式列表&#xff0c;字典&#xff0c;元组&#xff0c;集合总结 字符串字符串的驻留机制判断字符串的操作方法字符串的比较操作字符串的切片操…...

c#winform,倒鸭子字幕效果,typemonkey字幕效果,抖音瀑布流字幕效果

不废话 直接上效果图 C# winform 开发抖音的瀑布流字幕。 也是typemonkey插件字幕效果 或者咱再网上常说的倒鸭子字幕效果 主要功能 1&#xff0c;软件可以自定义添加字幕内容 2&#xff0c;软件可以添加字幕显示的时间区间 3&#xff0c;可以自定义字幕颜色&#xff0c;可以随…...

1、C51单片机(STC8G2K64S4)串口实验

一、串口1接线图 1、下面是单片机外接电路图&#xff0c;P30,P31分别用于RXD和TXD功能引脚 2、我们来查看单片机手册 串口1需要设置的寄存器 串口1的功能脚配置选择位&#xff0c;看电路图选择的是P3.0,P3.1。 3、串口1&#xff1a;SCON控制寄存器 设置为0x50:0101 0000。&a…...

ue材质学习感想总结笔记

2025 - 3 - 27 1.1 加法 对TexCoord上的每一个像素加上一个值&#xff0c;如果加上0.1&#xff0c;0.1&#xff0c; 那么左上角原来0,0的位置变成了0.1,0.1 右上角就变成了1.1,1.1&#xff0c;那么原来0,0的位置就去到了左上角左上边&#xff0c;所以图像往左上偏移。 总而言…...

MFC TRACE 宏的使用说明

书籍&#xff1a;《Visual C 2017从入门到精通》的2.7 字符串 环境&#xff1a;visual studio 2022 内容&#xff1a;几个字符串类型->&#xff08;将单字节char*转换为宽字节wchar_t *&#xff09;&#xff08;将宽字节wchar_t* 转换为单字节char *&#xff09; 问题&am…...

latex笔记

1、基本结构 \documentclass[a4paper, 12pt]{article} %文档类型 \begin{document}\title{My First Document}\author{My Name}\date{\today}\maketitleA sentence of text. \end{document}2、带有章、节、小节的结构 \documentclass[a4paper, 12pt]{article}\begin{document…...

Unity编辑器功能及拓展(3) —[Attribute]特性

在 Unity 中&#xff0c;[Attribute]格式的特性是用于扩展编辑器功能、控制序列化行为和调整 Inspector 显示,进行编辑器拓展的核心工具。 一.基础编辑器拓展 1.基础序列化控制 1.[SerializeField] 强制显示私有变量到Inspector 2.[HideInInspector] 隐藏该字段在Inspect…...

Rust基础语法

以下是 Rust 语言基础语法的核心要点&#xff0c;结合与 JavaScript 的对比&#xff0c;帮助前端开发者快速掌握核心概念&#xff1a; 一、变量与常量 1. 变量声明 Rust&#xff1a;变量默认不可变&#xff0c;需用 mut 显式声明可变性。let x 5; // 不可变变量 le…...

<tauri><rust><GUI>基于rust和tauri,实现一个大寰电爪PGHL(串口设备)定制化控制程序

前言 本文是基于rust和tauri,由于tauri是前、后端结合的GUI框架,既可以直接生成包含前端代码的文件,也可以在已有的前端项目上集成tauri框架,将前端页面化为桌面GUI。 环境配置 系统:windows 10平台:visual studio code语言:rust、javascript库:tauri2.0概述 本文是…...

Sentinel 相关知识点

Sentinel 实现原理&#xff1f; Sentinel 是面向分布式服务架构的流量控制组件&#xff0c;主要以流量为切入点&#xff0c;从限流、流量整形、熔断降级、系统负载保护等多个维度来帮助开发者保障微服务的稳定性。以下是 Sentinel 的实现原理&#xff1a; 核心概念 资源&…...

DFS飞机降落

问题描述 NN 架飞机准备降落到某个只有一条跑道的机场。其中第 ii 架飞机在 TiTi​ 时刻到达机场上空&#xff0c;到达时它的剩余油料还可以继续盘旋 DiDi​ 个单位时间&#xff0c;即它最早可以于 TiTi​ 时刻开始降落&#xff0c;最晚可以于 TiDiTi​Di​ 时刻开始降落。降落…...

SpringCould微服务架构之Docker(5)

Docker的基本操作&#xff1a; 镜像相关命令&#xff1a; 1.镜像名称一般分两部分组成&#xff1a;[repository]:[tag]。 2. 在没有指定tag时&#xff0c;默认是latest&#xff0c;代表着最新版本的镜像。 镜像命令的案例&#xff1a; 镜像操作常用的命令&#xff1a; dock…...

音乐webpack(通杀webpack-1)

本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;不提供完整代码&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01; 本文章未经许可…...

数据结构与算法——顺序表之手撕OJ题

文章目录 一、前言二、拿捏OJ题2.1移除元素2.2删除有序数组中的重复项2.3合并两个有序数组 三、总结 一、前言 Do you study today?up在上一次已经讲解完毕了有关顺序表的所有知识&#xff0c;不知道大家是否已经沉淀完毕了呢&#xff1f;有一句老话说得好啊——光看不练假把…...

减少采样空间方法 变成后验概率

又 因为后验概率很难计算 --所以通过引入变分分布来近似 后验概率分布 同时 引入 kl散度来度量 近似的效果好不好 什么是kl散度 kl散度带变分&#xff1a; 第一个问题 &#xff1a;积分变期望 问题二&#xff1a;贝叶斯公式 第三个问题&#xff1a;为啥可以独立出来 因为相比…...

如何使用K8S快速部署测试环境

目录 一、Windows 系统使用 Rancher Desktop 二、Linux系统 集群使用 Ansible 一键部署 三、Linux系统使用 kubeadm 快速搭建单节点集群 四、Kubernetes (K8S) 快速部署测试环境 4.1 准备 K8S 集群 4.2部署测试应用 4.3访问测试服务 4.4持久化存储&#xff08;可选&…...

GAMES101-现代计算机图形学入门(Animation/simulation)

目录 一些科普Keyframe AnimatorPhysical Simulation质点弹簧系统 Mass Spring Rope粒子系统运动学 Forward Kinematics逆运动学Inverse KinematicsRiggingMotion Capture 第二次课 cont.Single Particle Simulation流体模拟 Fluid Simulation GitHub主页&#xff1a;https://g…...

2两数相加解题记录

哎呀&#xff0c;以为这道题也不用写题解的……结果还是有坑没跳出来。 最开始想法先计算总和再求出链表 func addTwoNumbers(l1 *ListNode, l2 *ListNode) *ListNode {// 先算出这个值。测试用例会int类型溢出total : 0wei : 1for l1!nil && l2!nil {total (l1.Vall…...

uniapp 获取dom信息(封装获取元素信息工具函数)

在uniapp开发中&#xff0c;需要获取到dom的信息&#xff0c;需要用到uniapp的指定方式 uni.createSelectorQuery()&#xff0c;但是每次需要用到的时候都需要很长一段的繁琐代码&#xff0c;本篇文章将呈现获取dom信息方法封装&#xff0c;话不多说&#xff0c;上菜&#xff1…...

Mybatis_Plus中常用的IService方法

查询 方法名 查询记录总数 /*** 查询总记录数** see Wrappers#emptyWrapper()*/default long count() {return count(Wrappers.emptyWrapper());} 方法实现 Testpublic void testGetCount(){long count userService.count();System.out.println("总记录数&#xff1a;&…...

【华为OD技术面试真题 - 技术面】- Java面试题(16)

华为OD面试真题精选 专栏:华为OD面试真题精选 目录: 2024华为OD面试手撕代码真题目录以及八股文真题目录 线程创建的方式 1. 通过继承Thread类 创建一个自定义线程类,继承Java中的Thread类,并重写run()方法。然后通过调用start()方法来启动线程。 示例代码: // 继承Th…...

React(六)React过渡动画-CSS编写方式

React过渡动画 react-transition-group介绍 在开发中&#xff0c;我们想要给一个组件的显示和消失添加某种过渡动画&#xff0c;提高用户体验→可通过react-transition-group实现。React曾为开发者提供过动画插件 react-addons-css-transition-group&#xff0c;后由社区维护…...

计算机视觉初步(环境搭建)

1.anaconda 建议安装在D盘&#xff0c;官网正常安装即可&#xff0c;一般可以安装windows版本 安装成功后&#xff0c;可以在电脑应用里找到&#xff1a; 2.创建虚拟环境 打开anaconda prompt&#xff0c; 可以用conda env list 查看现有的环境&#xff0c;一般打开默认bas…...

JAVA反序列化深入学习(九):CommonsCollections7与CC链总结

CC7 依旧是寻找 LazyMap 的触发点 CC6使用了 HashSet而CC6使用了 Hashtable JAVA环境 java version "1.8.0_74" Java(TM) SE Runtime Environment (build 1.8.0_74-b02) Java HotSpot(TM) 64-Bit Server VM (build 25.74-b02, mixed mode) 依赖版本 Apache Commons …...

软考《信息系统运行管理员》- 6.1 信息系统安全概述

信息系统安全的概念 信息系统安全是指保障计算机及其相关设备、设施(含网络)的安全&#xff0c;运行环境的安全&#xff0c; 信息的安全&#xff0c;实现信息系统的正常运行。 信息系统安全包括实体安全、运行安全、信息安全和 人员安全等几个部分。 影响信息系统安全的因素…...

MDK中结构体的对齐、位域、配合联合体等用法说明

测试环境:STM32H7R3MDK 5.39AC5 注&#xff1a;PC、PowerPC等环境不适用本文。 一.字节对齐 一般采用自然对齐&#xff08;默认方式&#xff09;&#xff0c;提高数据存取速度。 采用1字节对齐&#xff0c;变量在内存中无空隙&#xff0c;紧密存储&#xff0c;节省存…...

C++实现布隆过滤器

1.布隆过滤器概念 位图虽然能高效且节省存储数据&#xff0c;但是类型必须是整型&#xff0c;不能存储其它类型。布隆过滤器是由布隆提出的一中紧凑型&#xff0c;比较巧妙的概率型数据结构&#xff0c;特点是高效的插入和查询&#xff0c;可以得知什么是一定不存在或者可能存…...

React 揭秘:从新手到高手的进阶之路

目录 React&#xff1a;前端开发新宠​ React 初相识​ 什么是 React​ React 的核心特性​ 1.组件化开发 2.虚拟 DOM 与 Diff 算法 单向数据流 搭建 React 开发环境 环境准备​ 创建 React 项目 项目结构解析 React 基础语法与核心概念 JSX 语法​ 基本语法规则…...

JAVA的内存图理解

目录 一、方法区1、类常量池2、静态常量池3、方法区过程 二、栈三、堆1、字符常量池2、堆内存图的绘制 java中内存可以分为 方法区、 堆、 栈、 程序计数器、 本地方法栈&#xff0c;其中比较中重要的是方法区、堆、栈。 一、方法区 1.方法区&#xff08;Method Area&…...

k8s存储介绍(六)StorangeClass

一、Kubernetes 存储类&#xff08;StorageClass&#xff09;详解 1. 什么是 StorageClass&#xff1f; 在 Kubernetes 中&#xff0c;StorageClass&#xff08;存储类&#xff09;是一种用于动态创建 PersistentVolume&#xff08;PV&#xff09;的资源对象。它允许管理员根…...

SourceMap原理

点击查看原文 1 webpack中使用 详见 js的模块化-webpack打包示例 2 webpack的配置 const { resolve } require(path)module.exports {mode: development,devtool: source-map,entry: ./src/index.js,output: {path: resolve(__dirname, dist),filename: "bundle.js&q…...

硬件基础--14_电功率

电功率 电功率:指电流在单位时间内做的功(表示用电器消耗电能快慢的一个物理量)。 单位:瓦特(W)&#xff0c;简称瓦。 公式:PUI(U为电压&#xff0c;单位为V&#xff0c;i为电流&#xff0c;单位为A&#xff0c;P为电功率&#xff0c;单位为W)。 单位换算:进位为1000&#xff…...

练习题:110

目录 Python题目 题目 题目分析 需求理解 关键知识点 实现思路分析 代码实现 代码解释 函数定义&#xff1a; 计算值的总和&#xff1a; 测试函数&#xff1a; 运行思路 结束语 Python题目 题目 定义一个函数&#xff0c;接受一个字典作为参数&#xff0c;返回字…...

Promise使用

Promise 是 JavaScript 中用于处理异步操作的一种对象&#xff0c;它代表了一个异步操作的最终完成&#xff08;或失败&#xff09;及其结果值。Promise 有三种状态&#xff1a; 1. pending&#xff08;进行中&#xff09;&#xff1a;初始状态&#xff0c;既不是成功也不是失…...

心理咨询法律咨询预约咨询微信小程序系统源码独立部署

预约咨询微信小程序&#xff1a;基于ThinkPHPUniapp的全场景解决方案与SEO深度优化指南 在心理健康、医疗问诊、法律咨询等领域线上化需求激增的背景下&#xff0c;预约咨询微信小程序凭借其灵活部署、多场景适配与隐私安全保障&#xff0c;成为机构与从业者提升服务效率的核心…...

JavaFX基础- Button 的基本使用

说明 本文记录一下对Button的基本使用&#xff0c;包括但不限于 样式的设置&#xff0c;事件的监听等。 按钮样式的设置 方式一 &#xff1a; Java代码的方式 // 创建一个按钮Button button new Button("按钮");// 设置按钮的位置button.setLayoutX(50);button.set…...

Golang使用 ip2region 查询IP的地区信息

利用 ip2region 进行 IP 地址定位 import ("fmt""log""github.com/lionsoul2014/ip2region/binding/golang/xdb" )func main() {ip : "213.118.179.98"dbPath : ".\\cmd\\ip\\ip2region.xdb"// 1、初始化查询器//searcher,…...

阿里云数据学习20250327

课堂链接&#xff1a;阿里云培训中心 (aliyun.com) 一、课堂问题 (一)课时3 1.支持字符集的含义是什么...

RAG - 五大文档切分策略深度解析

文章目录 切分策略1. 固定大小分割&#xff08;Fixed-Size Chunking&#xff09;2. 滑动窗口分割&#xff08;Sliding Window Chunking&#xff09;3. 自然语言单元分割&#xff08;Sentence/Paragraph Segmentation&#xff09;4. 语义感知分割&#xff08;Semantic-Aware Seg…...

软件测试之接口测试

&#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 接口测试定义 接口是前后端沟通的桥梁&#xff0c;是数据传输的通道&#xff0c;包括外部接口、内部接口。内部接口又包括:上层服务与下层服务接口&#xff…...

synchronized锁与lock锁的区别

引言 在学习多线程时&#xff0c;当时为了解决线程并发问题&#xff0c;曾有两种锁&#xff0c;一种是synchronized同步块&#xff0c;同步方法&#xff0c;一种就是Lock锁&#xff0c;那么这两种锁之间有什么区别&#xff1f;谁更好用呢&#xff1f; synchronized 同步方法…...

Open HarmonyOS 5.0 分布式软总线子系统 (DSoftBus) 详细设计与运行分析报告

1. HarmonyOS 5.0 与分布式软总线 (DSoftBus) 概述 1.1 HarmonyOS 5.0 架构概览 HarmonyOS 5.0&#xff0c;又称鸿蒙星河版&#xff0c;标志着操作系统架构的重大演进&#xff0c;其核心在于转向自研的微内核系统 1。此版本摒弃了先前版本中兼容安卓的双框架模式&#xff0c;全…...

蓝桥杯备考:多米诺骨牌

这道题要求上下方格子和之差要最小&#xff0c;其实就是算每个上下格子的差求和的最小值 这道题其实是动态规划01背包问题 我们直接按步骤做吧 step1:定义状态表示f[i][j]表示从1到i个编号的差值里选出刚好j个数的最小操作次数 step2:推导状态转移方程 如图这就是我们的状态…...

C++:allocator类(动态数组续)

1.为什么需要 allocator&#xff1f; 在 C 中&#xff0c;动态内存管理通常通过 new 和 delete 完成&#xff1a; int* p new int; // 分配内存 构造对象 delete p; // 析构对象 释放内存 但 new 和 delete 有两个问题&#xff1a; 耦合性&#xff1a;将内…...