0

0

如何获取 Spinner 选中项的索引位置(行号)

心靈之曲

心靈之曲

发布时间:2025-12-25 17:10:02

|

473人浏览过

|

来源于php中文网

原创

如何获取 Spinner 选中项的索引位置(行号)

android 开发中,spinner 的 `getselecteditemposition()` 方法可直接返回当前选中项的零基索引(即“行号”),而非文本内容,适用于保存数据库 id 或进行位置关联操作。

在使用 Spinner 时,开发者常误用 getSelectedItem().toString() 获取显示文本,但实际业务中(如保存数据到数据库)往往需要的是该选项在数据源中的位置索引(即第几项,从 0 开始计数),而非其显示文字。此时,应使用 Spinner.getSelectedItemPosition() 方法——它返回一个 int 类型的整数,代表当前选中项在适配器(Adapter)中的位置。

✅ 正确用法示例:

// 假设 universite 是已初始化并设置好 Adapter 的 Spinner
int selectedIndex = universite.getSelectedItemPosition();

// 该索引可直接用于关联数据源(如 ArrayList 或 Cursor 中的第 n 条记录)
// 例如:保存对应数据库记录的 _id 或作为外键引用
if (selectedIndex >= 0) {
    // 安全访问:确保有有效选择(Spinner 默认可能无选中项)
    long databaseId = yourDataSourceList.get(selectedIndex).getId(); // 示例:从 List 获取 ID
    saveToDatabase(databaseId);
} else {
    Toast.makeText(this, "请先选择一项", Toast.LENGTH_SHORT).show();
}

⚠️ 注意事项:

Zeemo AI
Zeemo AI

一款专业的视频字幕制作和视频处理工具

下载
  • getSelectedItemPosition() 返回值为 -1 时表示尚未有任何项被选中(例如 Spinner 刚初始化、未触发用户选择),务必做非负判断;
  • 该索引与数据源顺序严格一致,因此需确保 ArrayAdapter 或自定义 CursorAdapter 的数据顺序稳定且与业务逻辑匹配;
  • 若需将位置映射到数据库 _id,建议在填充 Spinner 时同步维护一个 List 存储对应 ID,避免依赖位置间接查询(提升健壮性与可读性)。

? 总结:getSelectedItemPosition() 是获取 Spinner “行号”的标准、高效且轻量的方式,应优先于文本解析或手动遍历,既符合 Android 最佳实践,也利于代码可维护性与性能优化。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

311

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

510

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

46

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

177

2025.08.29

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

325

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2066

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

346

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

250

2023.09.05

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

147

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 9.5万人学习

Java 教程
Java 教程

共578课时 | 37.4万人学习

Uniapp从零开始实现新闻资讯应用
Uniapp从零开始实现新闻资讯应用

共64课时 | 6.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号