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

Maven和MyBatis学习总结

目录

Maven

1.Maven的概念:

2.在具体的使用中意义:

3.与传统项目引入jar包做对比:

传统方式:

在maven项目当中:

4.在创建maven项目后,想要自定义一些maven配置

5.maven项目的结构

6.maven指令的生命周期,其中红色为常用的生命周期

7.当导入的jar包有依赖关系时,会将被依赖的包全部一起导入进来,为了防止版本冲突,我们可以采用以下四种解决办法:

Mybatis

1.Mybatis的概念

2.在具体使用中的意义:

3.与传统项目进行对比:

传统项目:

mybatis的使用:

4.自动映射与手动映射

5.mapper接口中需要传入多个属性

6.Like模糊匹配

7.sql片段

8.动态sql

9.mybatisX插件的使用

10.项目结构总结


Maven

1.Maven的概念:

Maven 是一个项目管理工具 ,可以对 Java 项目进行 一键构建、依赖管理

2.在具体的使用中意义:

由于传统java项目中要想引入其他jar包,需要经过非常多的步骤才可以成功将jar包引入到当前java项目,而我们为了实现代码逻辑,需要频繁引入jar包,因此主要为了简化jar包的引入过程,我们在新建项目时,直接选择maven项目即可。

3.与传统项目引入jar包做对比:

以引入servlet包为例

传统方式:

1).在官网找到对应jar包,并下载下来
2).点击Project Structure
3).将下载好的jar包引入到 Libraries(可以实现跨模块的调用,不同模块都可以使用到的jar包可以直接存放在这里,或者直接全部都存放在这里)
4).将Libraries当中的jar文件引入具体的模块当中

 

在maven项目当中:

1.创建maven项目

2.在pom.xml文件进行配置即可

3.在中心仓库或私服当中找想要使用的具体jar包

maven中心仓库

将对应gav坐标复制下来粘贴在pom.xml的
<dependencies>
</dependencies>标签下即可

4.在创建maven项目后,想要自定义一些maven配置

1)找到自己下载的maven安装目录,并打开conf的配置文件夹

2)对settings文件进行修改,其中url放具体地址,这样就可以将服务器改为私服或者中心仓库的镜像
3)除此之外,为了将所有引入的jar包保存下来,就不用每次去中心仓库搜索,我们需要配置jar包存放目录
4)在idea当中进行应用

5.maven项目的结构

6.maven指令的生命周期,其中红色为常用的生命周期

7.当导入的jar包有依赖关系时,会将被依赖的包全部一起导入进来,为了防止版本冲突,我们可以采用以下四种解决办法:

1)
2)和  3)
4)版本锁定

Mybatis

1.Mybatis的概念

它是一个持久化框架,用于对关系型数据库操作,底层封装了 JDBC

2.在具体使用中的意义:

在传统老式项目当中,由于未使用到Mybatis,要想使用mysql需要进行复杂的JDBC操作,然而随着Mybatis的引入我们大大简化了JDBC操作,便可以对数据库进行增删改查。

3.与传统项目进行对比:

传统项目:

以Druid数据库连接线程池为例
1).首先引入Druid的jar包文件
2). 进行基本的配置以及调用
由于需要频繁的获取数据库连接,为了简化,我们单独设置一个工具类,在需要使用时进行调用即可。

此处使用到的静态代码块,原因在于静态代码块尽在编译时运行一次,而我们需要操作的数据库连接始终不变,因此不必频繁建立连接,写在静态代码块中即可。

这一部分封装的是具体给外部调用的方法,此处使用到了接口

SelectQuery<T> query

,而接口的实现采用匿名内部类的方式由调用者实现,同时使用到了泛型类,使得内部方法都可以使用到该泛型,由于返回值类型是不确定的,所以该方法的返回值为泛型T,由调用者自行定义。

该executselect方法的主要功能为执行查找操作,首先建立连接,然后将sql语句包装为preparedstatement类,以便使用其中的方法,params传来需要补充的参数,这样做是为了防止sql注入,因为where后如果条件被更改为恒对,则所有信息将被泄露,所以传来的sql语句多为String sql="SELECT * from student where account=?";这样的形式。而...params以剩余参数的方式,接收了所有需要额外填充在?处值。并通过statement.setObject来填充到对应位置,注意:需要填充的位置的下标从1开始,而对应的元素位置为0开始。

执行statement.executeQuery();操作之后我们获取到的是ResultSet 对象,也就是结果集,结果集交给调用该方法者来处理。其中set是最初指向该结果集的第一行数据的指针,相当于依次将每一行数据传给调用者,由调用者来处理

 try(DruidPooledConnection conn=dataSource.getConnection();PreparedStatement statement = conn.prepareStatement(sql);) {for (int i=1;i<=params.length;i++){statement.setObject(i,params[i-1]);}ResultSet set=statement.executeQuery();ArrayList<T> datas = new ArrayList<>();while (set.next()){//获取一行数据,该操作需要交给外界使用该工具的开发人员实现T data=query.selectQuery(set);datas.add(data);}return datas;} catch (SQLException e) {throw new RuntimeException(e);}}

 executeall封装的则是增删改操作

 public  static Integer executeAll(String sql,Object ...parmas){try(DruidPooledConnection conn=dataSource.getConnection();PreparedStatement statement = conn.prepareStatement(sql)) {for (int i=1;i<=parmas.length;i++){statement.setObject(i,parmas[i-1]);}Integer i=statement.executeUpdate();return i;} catch (SQLException ex) {throw new RuntimeException(ex);}}
}

以下是调用的实例,由前端传入的账号,来查询对应数据库中存放的密码

 String sql="SELECT * from student where account=?";ArrayList<String> passwordList=DBUtils.excuteSelect(sql,(ResultSet resultset)->{String password1= null;try {password1 = resultset.getString("password");} catch (SQLException e) {throw new RuntimeException(e);}return password1;},account);

接下来根据passwordlist当中存放的password与用户输入的password进行比对,同时如果密码正确检查token,如果没过期,则直接登录,过期了需要重新生成token

 if (!passwordList.isEmpty()){if(passwordList.get(0).equals(password)){//查找对应token是否存在String sql1="select * from token where account=?";ArrayList<HashMap<String , Object>> results=DBUtils.excuteSelect(sql1,(ResultSet set)->{HashMap<String, Object> data = new HashMap<>();data.put("token", set.getString("token"));//获取数据库中dateTime类型的数据data.put("time", set.getTimestamp("date"));return data;},account);if(!results.isEmpty()){//有token需要检测是否过期,如果过期需要更新Timestamp oldTime =(Timestamp)results.get(0).get("time");Date newTime = new Date();if(newTime.getTime() - oldTime.getTime() > 60000){//设置有效期1分钟,过期String token = TokenUtil.getToken(10);sql = "update token set token=?, date=? where account=?";Integer num = DBUtils.executeAll(sql, token, newTime, account);if(num > 0){HttpSession session = req.getSession();session.setAttribute("token", token);session.setAttribute("time", newTime);RespUtil.success(200, "success",  resp,token);}else{RespUtil.success(200, "success", resp);}}else{String token = (String) results.get(0).get("token");HttpSession session = req.getSession();session.setAttribute("token", token);session.setAttribute("time", oldTime);RespUtil.success(200, "success",  resp,token);}}else {//没有token需要添加tokensql="INSERT INTO token (account,date,token) VALUES (?,?,?)";String token= TokenUtil.getToken(10);Date date = new Date();Integer i = DBUtils.executeAll(sql, account, date, token);HttpSession session = req.getSession();session.setAttribute("token", token);session.setAttribute("time", date);if(i > 0){RespUtil.success(200, "success",  resp,token);}else{RespUtil.success(200, "success", resp);}}}else {RespUtil.fail(500,"密码错误",resp);}

mybatis的使用:

此处并没有结合springboot和spring的使用,而是单独的使用mybatis

mybatis则无需这么麻烦的自己写函数,以下是具体步骤

1)首先创建maven项目

2)引入mybatis的jar包和mysql的jar包

3)创建并开始配置mybatis-config.xml文件(该文件为mybatis总配置文件,后续引入的映射也均需要在该文件当中声明)

3.配置数据源

以下是2,3步后对应的mybatis-config.xml文件中具体内容

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><settings><!-- 启用驼峰命名转换 --><setting name="mapUnderscoreToCamelCase" value="true"/></settings>
<!--  给类和包起别名--><typeAliases><typeAlias type="com.mybatis.entity.Pinpai" alias="pinpai"/><package name="com.mybatis.entity"/></typeAliases><plugins><!-- 配置 PageHelper 分页插件 --><plugin interceptor="com.github.pagehelper.PageInterceptor"><!-- 参数配置(可选) --><property name="helperDialect" value="mysql"/>  <!-- 指定数据库类型 --><property name="reasonable" value="true"/>      <!-- 分页合理化(页码越界时自动调整) --><property name="supportMethodsArguments" value="true"/> <!-- 支持接口参数传递分页 --><property name="params" value="count=countSql"/> <!-- 优化 COUNT 查询 --></plugin></plugins>
<!--环境:指定要连接的数据库--><environments default="mysql8"><environment id="mysql8">
<!--            事务管理器--><transactionManager type="JDBC"/>
<!--            datasource的type有三种取值:POOLED,UNPOOLED,JNDI-->
<!--            mybatis提供数据库链接池技术,type=pooled代表使用数据库链接池--><dataSource type="POOLED">
<!--   数据源:数据库的连接信息,配置好以下四个信息--><!--配置驱动方式-->    <property name="driver" value="com.mysql.cj.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/yoyoshop?serverTimezone=GMT%2B8"/><property name="username" value="root"/><property name="password" value="123456"/></dataSource></environment><environment id="mysql9"><!--            事务管理器--><transactionManager type="JDBC"/><!--            datasource的type有三种取值:POOLED,UNPOOLED,JNDI--><!--            mybatis提供数据库链接池技术,type=pooled代表使用数据库链接池--><dataSource type="POOLED"><!--   数据源:数据库的连接信息,配置好以下四个信息--><!--配置驱动方式-->    <property name="driver" value="com.mysql.cj.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/yoyoshop?serverTimezone=GMT%2B8"/><property name="username" value="root"/><property name="password" value="123456"/></dataSource></environment></environments><!--映射器:指定要操作的映射文件--><mappers><mapper resource="mapper/PinpaiMapper.xml"/><mapper resource="mapper/BookMapper.xml"/></mappers></configuration>

以上就完成了数据库连接操作

接着是执行具体sql语句:

1.根据数据库表生成对应的实体类文件

2.创建该类所对应的mapper接口,一定要主意好返回值类型和参数名和类型,否则报错不好找

3.创建映射文件

编写接口方法对应的 sql 语句,其中头部内容是固定的,namespace为对应被映射接口的详细地址信息
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.mybatis.mapper.PinpaiMapper">
</mapper>

插入操作为insert,查询select,更新为update,删除为delete,id绑定具体的实现方法,比如insert当中id绑定为被映射接口的add方法,select其中一个绑定对应被映射接口的selectById方法。parametertype为输入参数类型,resulttype为输出参数类型,为完整的实体类地址。sql语句当中通过#{}即可实现对应形参对sql语句的绑定,当输入的类型为一个类时,同样可以通过#{类中属性名}对应属性的绑定。

4.在总配置文件文件mybatis-config.xml中进行声明

  <mappers><mapper resource="mapper/PinpaiMapper.xml"/><mapper resource="mapper/BookMapper.xml"/></mappers>

接着便可被调用,调用时分为以下几步:

//        1、读取mybatis的主配置文件mybatis-config.xmlReader reader= null;try {reader = Resources.getResourceAsReader("mybatis-config.xml");} catch (IOException e) {throw new RuntimeException(e);}
//        2、创建SqlSessionFactoryBuilder对象SqlSessionFactoryBuilder factoryBuilder = new SqlSessionFactoryBuilder();
//        3、创建SqlSessionFactory对象factory = factoryBuilder.build(reader);
//        4、创建SqlSession会话对象(获取链接)SqlSession sqlSession = factory.openSession();
//5.获取对应接口实现类PinpaiMapper mapper=sqlSession.getMapper(PinpaiMapper.class);//6.调用方法int result=mapper.add(pinpai);System.out.println(result);
//        7、提交事务sqlSession.commit();//        8、关闭资源sqlSession.close();

由于1,2,3,4,6,7,8步骤为固定的,因此我们还可以封装为一个工具类来调用。

4.自动映射与手动映射

传统使用自动映射,在实体类的属性名和数据库当中的列名一致时可以使用。当实体类定义的属性名和数据库不一致时,我们需要引入手动映射

右侧column为数据库中的名称,左侧为实体类属性名

<!--    自动映射--><select id="selectAll" resultType="com.mybatis.entity.Book">select * from book</select><!--    手动映射--><select id="selectAll" resultMap="bookMap">select * from book</select><resultMap id="bookMap" type="com.mybatis.entity.Book"><id property="bookid" column="book_id"/><result property="bookname" column="book_name"/><result property="price" column="price"/><result property="deleted" column="deleted"/></resultMap>

5.mapper接口中需要传入多个属性

mapper接口默认只能传入一个属性值,当需要传入多个属性值时,由以下几种方法

1.转为单属性值

        HashMap<String,Object> map = new HashMap<>();map.put("bookName","红楼梦");map.put("pageNum",1);map.put("pageSize",2);final SqlSession sqlSession = MybatisUtil.getSqlSession();BookMapper mapper = sqlSession.getMapper(BookMapper.class);List<Book> books2 = mapper.selectBookByNameAndPage2(map);
List<Book> selectBookByNameAndPage2(Map<String,Object> map);
 <select id="selectBookByNameAndPage2" parameterType="Map" resultType="Book">select * from book where book_name=#{bookName} limit #{pageNum},#{pageSize}</select>

2.使用param1,param2等来访问对应位置

List<Book> selectBookByNameAndPage(String bookName, int pageNum, int pageSize);
     List<Book> books = mapper.selectBookByNameAndPage("红楼梦", 1, 2);
<select id="selectBookByNameAndPage" resultType="com.mybatis.entity.Book">select * from book where book_name=#{param1} limit #{param2},#{param3}</select>

6.Like模糊匹配

7.sql片段

8.动态sql

where标签的主要作用是去除掉对应位置的and关键字,搭配if来使用,而if判断的是如果前端没有传入对应属性值,则对应属性值没有被赋值,为初始值,所以判断是否为初始值即可实现对应是否动态增加判断条件。

set标签也搭配if标签使用,去除后面多余的“,”逗号。

9.mybatisX插件的使用

一键完成所有的配置。

10.项目结构总结

相关文章:

Maven和MyBatis学习总结

目录 Maven 1.Maven的概念&#xff1a; 2.在具体的使用中意义&#xff1a; 3.与传统项目引入jar包做对比&#xff1a; 传统方式&#xff1a; 在maven项目当中&#xff1a; 4.在创建maven项目后&#xff0c;想要自定义一些maven配置 5.maven项目的结构 6.maven指令的生…...

普通通话CSFB方式(2g/3g)

一、CSFB的触发条件 当模块&#xff08;或手机&#xff09;驻留在 4G LTE网络 时&#xff0c;若发生以下事件&#xff0c;会触发CSFB流程&#xff1a; 主叫场景&#xff1a;用户主动拨打电话。被叫场景&#xff1a;接收到来电&#xff08;MT Call&#xff09;。紧急呼叫&…...

揭开人工智能与机器学习的神秘面纱:开发者的视角

李升伟 编译 人工智能&#xff08;AI&#xff09;和机器学习&#xff08;ML&#xff09;早已不再是空洞的流行语——它们正在彻底改变我们构建软件、做出决策以及与技术互动的方式。无论是自动化重复性任务&#xff0c;还是驱动自动驾驶汽车&#xff0c;AI/ML都是现代创新的核…...

AndroidTV 当贝播放器-v1.5.2-官方简洁无广告版

AndroidTV 当贝播放器 链接&#xff1a;https://pan.xunlei.com/s/VONXRf0g3cT0ECVt6GEsoODFA1?pwds4qv# AndroidTV 当贝播放器-v1.5.2-官方简洁无广告版...

BERT - MLM 和 NSP

本节代码将实现BERT模型的两个主要预训练任务&#xff1a;掩码语言模型&#xff08;Masked Language Model, MLM&#xff09; 和 下一句预测&#xff08;Next Sentence Prediction, NSP&#xff09;。 1. create_nsp_dataset 函数 这个函数用于生成NSP任务的数据集。 def cr…...

Python生成exe

其中的 -w 参数是 PyInstaller 用于窗口模式&#xff08;Windowed mode&#xff09;&#xff0c;它会关闭命令行窗口的输出&#xff0c;这通常用于 图形界面程序&#xff08;GUI&#xff09;&#xff0c;比如使用 PyQt6, Tkinter, PySide6 等。 所以&#xff1a; 如果你在没有…...

MySql 自我总结

目录 1. 数据库约束 1.1约束类型 2. 表的设计 2.1 一对一 2.2 一对多 2.3 多对多 3. 新增 4. 查询 4.1 聚合查询 4.2 GROUP BY 4.3 HAVING 4.4 联合查询 4.5 内连接 4.5.1 内连接的核心概念 4.5.2 内连接的语法 4.5.3 ON 与 WHERE 的区别 4.6 自连接 4.6.1 定…...

uni-app app 安卓和ios防截屏

首先可参考文档 uni.setUserCaptureScreen 这里需要在项目中引入这个插件 uni-usercapturescreen - DCloud 插件市场 否则会报错,在需要防止截屏录屏的页面中,加入 uni.setUserCaptureScreen({enable: false,success() {console.log(全局截屏录屏功能已禁用);},fail(err)…...

Android Input——查找并添加目标窗口(七)

在 Android 输入系统中,InputDispatcher 的核心职责之一是将输入事件正确地传递到目标窗口。上一篇文章我们介绍到 InputDispatcher 事件分发调用到 findFocusedWindowTargetsLocked() 函数查找焦点窗口,并将焦点窗口添加到目标窗口,这里我们继续往下看。 一、获取焦点窗口…...

ruby内置全局变量

以下是 Ruby 中常见的 内置全局变量 及其用途的详细说明。这些变量以 $ 开头&#xff0c;由 Ruby 解释器自动管理&#xff0c;用于访问系统状态、异常、输入输出等核心信息。 一、异常处理相关 全局变量说明示例$!当前作用域最后抛出的异常对象&#xff08;等同于 rescue >…...

pytorch查询字典、列表维度

输出tensor变量维度 print(a.shape)输出字典维度 for key, value in output_dict.items():if isinstance(value, torch.Tensor):print(f"{key} shape:", value.shape)输出列表维度 def get_list_dimensions(lst):# 基线条件&#xff1a;如果lst不是列表&#xff0…...

【Go】windows下的Go安装与配置,并运行第一个Go程序

【Go】windows下的Go安装与配置&#xff0c;并运行第一个Go程序 安装环境&#xff1a;windows10 64位 安装版本&#xff1a;go1.16 windows/amd64 一、安装配置步骤 1.到官方网址下载安装包 https://golang.google.cn/dl/ 默认情况下 .msi 文件会安装在 c:\Go 目录下。可自行配…...

Windows上使用Qt搭建ARM开发环境

在 Windows 上使用 Qt 和 g++-arm-linux-gnueabihf 进行 ARM Linux 交叉编译(例如针对树莓派或嵌入式设备),需要配置 交叉编译工具链 和 Qt for ARM Linux。以下是详细步骤: 1. 安装工具链 方法 1:使用 MSYS2(推荐) MSYS2 提供 mingw-w64 的 ARM Linux 交叉编译工具链…...

CNN(卷积神经网络)

什么是CNN CNN&#xff08;卷积神经网络&#xff09;&#xff0c;是通过提取特征来压缩计算的一个网络结构&#xff0c;主要由卷积层、池化层、全连接层组成。 卷积层 在卷积层中&#xff0c;通过卷积核的移动对不同的区域提取特征生成一个新的矩阵&#xff0c;比如一个原始…...

Linux 内核网络协议栈中的 struct packet_type:以 ip_packet_type 为例

在 Linux 内核的网络协议栈中,struct packet_type 是一个核心数据结构,用于注册特定协议类型的数据包处理逻辑。它定义了如何处理特定协议的数据包,并通过协议类型匹配机制实现协议分发。本文将通过分析 ip_packet_type 的定义和作用,深入探讨其在网络协议栈中的重要性。 …...

网络问题之TCP/UDP协议

1. TCP是什么&#xff1f; TCP&#xff08;Transmission Control Protocol&#xff0c;传输控制协议&#xff09;是互联网核心协议之一&#xff0c;属于传输层协议&#xff0c;为应用程序提供可靠的、面向连接的字节流服务。 基本特性 可靠性&#xff1a;通过确认机制、重传机…...

vue3腾讯云直播 前端拉流(前端页面展示直播)

1、引入文件&#xff0c;在index.html <link href"https://tcsdk.com/player/tcplayer/release/v5.3.2/tcplayer.min.css" rel"stylesheet" /><!--播放器脚本文件--><script src"https://tcsdk.com/player/tcplayer/release/v5.3.2/t…...

【MYSQL从入门到精通】数据库基础操作、数据类型

目录 一些基础操作语句 创建库名 选择要操作的数据库 删除数据库 磁盘中删除文件的原理 数据库安全的各种措置 查看MYSQL的帮助 数值类型 字符串类型 日期类型 一些基础操作语句 1.使用客户端工具连接数据库服务器&#xff1a;mysql -uroot -p 2.查看所有数据库&am…...

JS里对于集合的简单介绍

JS的集合 前言一、集合二、基本使用1. 创建集合2. 添加元素3. 删除元素4. 检查元素5. 清空集合6. 集合的大小 三、扩展使用1. 遍历集合2. 从数组创建集合3. 集合的应用场景 四、总结 前言 JS里对于集合的简单介绍 同数学的集合&#xff0c;有无序性、唯一性 注意&#xff1a;…...

论文阅读笔记——Multi-Token Attention

MTA 论文 在 Transformer 中计算注意力权重时&#xff0c;仅依赖单个 Q 和 K 的相似度&#xff0c;无法有效捕捉多标记组合信息。&#xff08;对于 A、B 两个词&#xff0c;单标记注意力需要分别计算两个词的注意力分数&#xff0c;再通过后处理定位共同出现的位置或通过多层隐…...

Sql with as 语句

在SQL查询中&#xff0c;经常会遇到需要重复使用的子查询。为了简化查询语句并提高可读性&#xff0c;SQL引入了WITH AS语法。通过使用WITH AS&#xff0c;我们可以创建临时表或视图&#xff0c;将子查询的结果保存起来&#xff0c;并在主查询中使用。本文将通过示例介绍SQL中W…...

vue3 antdesign table表格特定单元格背景变色

效果&#xff1a; <a-table :columns"columnsAll" :data-source"tableAllData"bordered size"middle" :scroll"{ x: 100,y: 600 }" :pagination"false"style"margin: 0 10px 10px 10px;" ><template #…...

【C语言】--- 编译和链接

编译和链接 1. 翻译环境和运行环境2. 翻译环境2.1 预处理2.2 编译2.2.1 词法分析2.2.2 语法分析2.2.3 语义分析 2.3 汇编2.4 链接 3. 运行环境 1. 翻译环境和运行环境 计算机只能运行二进制指令&#xff0c;所以我们的.c的文本程序需要先翻译为二进制程序才能被计算机执行。在…...

Qwen2.5-7B-Instruct FastApi 部署调用教程

1 环境准备 基础环境最低要求说明&#xff1a; 环境名称版本信息1Ubuntu22.04.4 LTSCudaV12.1.105Python3.12.4NVIDIA CorporationRTX 3090 首先 pip 换源加速下载并安装依赖包 # 升级pip python -m pip install --upgrade pip # 更换 pypi 源加速库的安装 pip config set g…...

深入解析Python爬虫技术:从基础到实战的功能工具开发指南

一、引言:Python 爬虫技术的核心价值 在数据驱动的时代,网络爬虫作为获取公开数据的重要工具,正发挥着越来越关键的作用。Python 凭借其简洁的语法、丰富的生态工具以及强大的扩展性,成为爬虫开发的首选语言。根据 Stack Overflow 2024 年开发者调查,68% 的专业爬虫开发者…...

前端 Vue: Cannot find module XX or its corresponding type declarations.

记一个常见错误&#xff0c;每次创建完新的vuetsvite项目&#xff0c;在配置路由的时候总会找不到vue文件&#xff0c;我用的是Webstorm&#xff0c;在设置里面修改以下设置&#xff0c;即可消除警告。...

数字内容体验案例解析与行业应用

数字内容案例深度解析 在零售行业头部品牌的实践中&#xff0c;数字内容体验的革新直接推动了用户行为模式的转变。某国际美妆集团通过搭建智能内容中台&#xff0c;将产品信息库与消费者行为数据实时对接&#xff0c;实现不同渠道的动态内容生成。其电商平台首页的交互式AR试…...

Webpack中的文件指纹:给资源戴上个“名牌”

你是否想过&#xff0c;当你修改代码后&#xff0c;浏览器为什么仍然拿着旧版资源不放&#xff1f;秘密就在于——文件指纹&#xff01;简单来说&#xff0c;文件指纹就像给每个构建出来的文件贴上独一无二的“姓名牌”&#xff0c;告诉浏览器&#xff1a;“嘿&#xff0c;我更…...

HBuilderX中uni-app打包Android(apk)全流程超详细打包

一、Android生成打包证书 1、Android平台签名证书(.keystore)生成指南_android 签名生成-CSDN博客&#xff08;如果不上架应用商店可以跳过&#xff0c;可以使用云端证书&#xff09; 二、打开manifest.json配置基础设置 三、配置安卓应用图标 四、配置安卓启动页图片 五、…...

多模态大模型重塑自动驾驶:技术融合与实践路径全解析

目录 1、 引言&#xff1a;AI与自动驾驶的革命性融合 2、五大领先多模态模型解析 2.1 Qwen2.5-Omni&#xff1a;全模态集大成者 2.2. LLaVA&#xff1a;视觉语言理解专家 2.3. Qwen2-VL&#xff1a;长视频理解能手 2.4. X-InstructBLIP&#xff1a;跨模态理解框架 2.5. …...