什么是ListContainer
ListContainer是用于显示列表的UI控件.效果图:
- 在主布局文件"ability_main.xml"中增加
ListContainer
2. 新增一个Provider用于展示列表中每一行内容
- 布局文件:list_container_item.xml
java代码:MyProvider.java
import ohos.agp.components.*;
import java.util.List;
public class MyProvider extends BaseItemProvider {
private final List dataList;
public MyProvider(List dataList) {
this.dataList = dataList;
}
@Override
public int getCount() {
return dataList == null ? 0 : dataList.size();
}
@Override
public Object getItem(int i) {
if (dataList != null && i >= 0 && i < dataList.size()) {
return dataList.get(i);
}
return null;
}
@Override
public long getItemId(int i) {
return i;
}
@Override
public Component getComponent(int i, Component component, ComponentContainer componentContainer) {
final Component cpt;
if (component == null) {
cpt = LayoutScatter.getInstance(componentContainer.getContext()).parse(ResourceTable.Layout_list_container_item, null, false);
} else {
cpt = component;
}
String data = this.dataList.get(i);
Text titleText = (Text) cpt.findComponentById(ResourceTable.Id_titleText);
titleText.setText(data);
return cpt;
}
}
- 在Slice中实例化Provider,设置数据,并将provider设置给ListContainer
public class MainAbilitySlice extends AbilitySlice {
@Override
public void onStart(Intent intent) {
super.onStart(intent);
super.setUIContent(ResourceTable.Layout_ability_main);
ListContainer listContainer = (ListContainer) findComponentById(ResourceTable.Id_list_container);
MyProvider myProvider = new MyProvider(getData());
listContainer.setItemProvider(myProvider);
}
private List getData() {
List dataList = new ArrayList();
for (int i = 1; i
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?