React Native【实战范例】网格导航 FlatList

在这里插入图片描述

import React from "react";
import {FlatList,Image,SafeAreaView,StyleSheet,Text,View,
} from "react-native";
interface GridItem {id: string;title: string;imageUrl: string;
}
// 网格布局数据
const gridData = Array.from({ length: 30 }, (_, i) => ({id: `grid-${i}`,title: `项目 ${i + 1}`,imageUrl: `https://picsum.photos/seed/${i}/200/200`,
}));
const GridFlatList = () => {// 渲染网格列表项const renderGridItem = ({ item }: { item: GridItem }) => (<View style={styles.gridItem}><Imagesource={{ uri: item.imageUrl }}style={styles.gridImage}resizeMode="cover"/><Text style={styles.gridTitle}>{item.title}</Text></View>);return (<SafeAreaView style={styles.container}><View style={styles.section}><Text style={styles.sectionTitle}>网格导航</Text><FlatListdata={gridData}renderItem={renderGridItem}keyExtractor={(item) => item.id}numColumns={3}contentContainerStyle={styles.gridContent}/></View></SafeAreaView>);
};
const styles = StyleSheet.create({container: {flex: 1,backgroundColor: "#f5f5f5",},section: {marginBottom: 20,},sectionTitle: {fontSize: 18,fontWeight: "bold",padding: 15,},iconText: {fontSize: 24,marginBottom: 5,},gridContent: {paddingHorizontal: 5,},gridItem: {width: "33.33%",padding: 5,},gridImage: {width: "100%",height: 100,borderRadius: 8,},gridTitle: {fontSize: 12,textAlign: "center",marginTop: 5,},
});
export default GridFlatList;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/bicheng/84936.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

KJY0047-J1阶段测试

KJY0047 - J1阶段测试题解 题目1&#xff1a;SYAP0001. 闯关 解题思路&#xff1a; 暴力思路&#xff1a;每次碰到奇数都使用一次 f o r for for 循环将后续的数值 1 1 1, 时间复杂度 O ( n 2 ) O(n^2) O(n2) 优化思路&#xff1a;可以用一个计数器 c n t cnt cnt 来存…

键盘按键枚举 Key 说明文档

键盘按键枚举 Key 说明文档 该文档介绍了 Key 枚举中定义的键盘按键常量及其对应编号&#xff0c;适用于标准 105 键的美式键盘布局。常用于浏览器或桌面端的键盘事件监听、游戏开发、快捷键映射等场景。 electron-jest ⌨️ 功能键&#xff08;Function Keys&#xff09; …

函数调用过程中的栈帧变化

int add(int a, int b) {int c a b;return c; }int main() {int result add(1, 2);return 0; }生成汇编代码&#xff1a;g -S Cplus.cpp -o Cplus.s .file "Cplus.cpp".text.globl _Z3addii.def _Z3addii; .scl 2; .type 32; .endef.seh_proc _Z3addii _Z3addii:p…

【Java面试笔记:实战】41、Java面试核心考点!AQS原理及应用生态全解析

引言:AQS在Java并发体系中的核心地位 AQS(AbstractQueuedSynchronizer)作为Java并发包的底层基石,是理解ReentrantLock、Semaphore等同步工具的关键。 在Java架构师面试中,AQS的原理与应用是高频考点,掌握其核心机制对理解JUC包和构建高并发系统至关重要。 本文将从原…

硕士课题常用命令

ros常用命令&#xff1a; 1.环境变量刷新 source devel/setup.bash2.ROS_INFO的信息在终端显示为乱码或者问号&#xff0c;则在main函数中加入&#xff1a; setlocale(LC_ALL, "");3.刷新bashrc文件 source ~/.bashrcPX4 roslaunch px4 mavros_posix_sitl.launc…

2.6 激光雷达消息格式

新建终端&#xff0c;执行命令 roslaunch wpr_simulation wpb_simple.launch 在新建终端&#xff0c;执行命令 roslaunch wpr_simulation wpb_rviz.launch 显示/Scan话题消息&#xff0c;后面的参数是noarr无数组&#xff0c;防止刷屏 rostopic echo /scan --noarr 参考官…

常见的网络协议有哪些

1.应用层 1.1 HTTP/HTTPS 前端与服务器通信的基础协议&#xff0c;用于传输 HTML、CSS、JS、图片等资源。 1.2WebSocket&#xff08;如社交聊天、股票实时报价、视频会议、在线教育等&#xff09; WebSocket协议建立在TCP协议之上&#xff0c;实现了浏览器与服务器之间的实时…

Prometheus + Grafana 监控 RabbitMQ 实践指南

文章目录 Prometheus Grafana 监控 RabbitMQ 实践教程一、前言二、环境搭建2.1 环境准备2.2 安装 Prometheus2.3 安装 Grafana 三、集成 RabbitMQ Exporter3.1 下载 RabbitMQ Exporter3.2 解压文件3.3 配置环境变量3.4 启动 RabbitMQ Exporter3.6 验证 Exporter 状态 四、Prom…

Babylon.js场景加载器(Scene Loader)使用指南

在3D开发中&#xff0c;Babylon.js的场景加载器(Scene Loader)是加载各种3D模型格式的核心工具。本文将详细介绍如何高效使用Scene Loader加载多种格式的3D模型文件。 一、基本概念与支持格式 要加载特定类型的文件&#xff0c;Babylon.js需要先注册对应的文件类型插件。目前…

编程学习网站大全(C++/OpenCV/QT方向)—— 资源导航与深度评测

工欲善其事&#xff0c;必先利其器 本文系统整理了C、OpenCV、QT三大方向的优质学习网站&#xff0c;结合技术特点与平台优势&#xff0c;助你精准选择学习资源&#xff0c;少走弯路&#xff01; 一、C 学习网站精选 &#x1f4da; 1. cppreference.com 权威性最高&#xff1a…

逆向入门(5)程序逆向篇-AD_CM#2

打开程序 常规注册界面&#xff0c;打开OD&#xff0c;随便找找就看到关键字了 没有壳逻辑也挺简单的 获取输入框&#xff0c;用5比较输入内容的长度&#xff0c;小于则跳转提示密码长度不够 否则就进入下一个流程&#xff0c;去获取序列号&#xff0c;其实可以直接将jnz换…

OD 算法题 B卷【路灯照明II】

文章目录 路灯照明II 路灯照明II 在一条笔直的公路上安装了N个路灯&#xff0c;从位置0开始安装&#xff0c;间距固定为100米&#xff1b;每个路灯都有自己的照明半径&#xff0c;计算第一个路灯和最后一个路灯之间&#xff0c;无法照明的区间长度和&#xff1b; 输入描述: 第…

JUC核心解析系列(四)——同步工具类 (Synchronizers)深度解析

在多线程开发中&#xff0c;死锁、资源竞争、线程协调等问题如同暗礁&#xff0c;稍有不慎就会导致程序崩溃。而JUC同步工具类正是解决这些问题的瑞士军刀&#xff01; 一、同步工具类核心价值&#xff1a;线程协作的艺术 在高并发系统中&#xff0c;线程协作是保证数据一致性…

板凳-------Mysql cookbook学习 (十--6)

第7章&#xff1a;排序查询结果 7.0 引言 mysql> use cookbook Database changed mysql> select * from driver_log; ---------------------------------- | rec_id | name | trav_date | miles | ---------------------------------- | 1 | Ben | 2014-07-30 …

从入门到精通:C# 中 AutoMapper 的深度解析与实战应用

在 C# 开发领域&#xff0c;尤其是企业级应用开发过程中&#xff0c;不同层次和模块之间的数据传递与对象转换是常见需求。例如&#xff0c;从数据库读取的实体类&#xff0c;在传递到前端时&#xff0c;往往需要转换为更简洁、安全的数据传输对象&#xff08;DTO&#xff09; …

【热更新知识】学习一 Lua语法学习

1、注释 1.1 单行注释 --注释内容 --单行注释 print打印函数 1.2 多行注释&#xff0c;三种方式 --[[注释内容]] --[[注释内容]]-- --[[注释内容--]] --[[ 多行 注释 ]]--[[ 第二种多行注释 1 2 ]]----[[ 第三种 多行 注释 --]] 2、简单变量 2.1 声明变量&#xff0c…

React 第三方状态管理库的比较与选择

在现代前端开发中,状态管理是一个重要的环节。选择合适的状态管理库可以极大地提高项目的可维护性和开发效率。本文将对几种流行的状态管理库进行比较,包括Valtio、XState、MobX、Recoil和Zustand,帮助开发者在实际项目中做出明智的选择。 1. Valtio 1.1. 设计理念 Valti…

《Kafka 在实时消息系统中的高可用架构设计》

Kafka 在实时消息系统中的高可用架构设计 引言 在当今互联网社交应用中&#xff0c;实时消息系统已成为核心基础设施。以中性互联网公司为例&#xff0c;其每天需要处理数十亿条消息&#xff0c;涵盖一对一聊天、群组互动、直播弹幕等多种场景。特别是在大型直播活动中&#…

SKUA-GOCAD入门教程-第八节 线的创建与编辑3

8.1.4根据面对象创建曲线 (1)从曲面生成曲线 从曲面边界生成曲线您可以从选定的曲面边界创建一条单段曲线。 1、选择 Curve commands > New > Borders > One 打开从曲面的一条边界创建曲线对话框。 图1 在“Name名称”框中,输入要创建的曲线的名称。

Unity编辑器-获取Projectwindow中拖拽内容的路径

参考 Unity Editor 实现给属性面板上拖拽赋值资源路径 API Event DragAndDrop 示例 Mono脚本 using UnityEngine; public class TestScene : MonoBehaviour {[SerializeField] string testName; }Editor脚本 重写InspectorGUI&#xff0c;在该函数中通过Event的Type参数获…