【Jetpack篇】Paging的新增与删除

一、整体思路:

创建新的数据源装载旧数据以及新增/删除数据。利用List集合进行增加和删除,通过loadInitial将最新的List数据返回给PagedList,最后调用submitList更新数据。

以PageKeyedDataSource作为数据源为例,首先新建一个DataSource的类PageKeyedDataSourceExtension继承PageKeyedDataSource,

在新的DataSource中创建一个List装载新的数据,也是后续用来增加和删除数据的集合。

 public List<ExBean> mDataList = new ArrayList<>();

在实现的loadInitial()方法中将最新的mDataList数据通过LoadInitialCallback返回给PagedList,loadBefore和loadAfter只需要传入空的List即可。

 @Override
    public void loadInitial(@NonNull LoadInitialParams<Integer> params, @NonNull LoadInitialCallback<Integer, ExBean> callback) {
        callback.onResult(mDataList, null, null);
    }

    @Override
    public void loadBefore(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, ExBean> callback) {
        callback.onResult(Collections.<ExBean>emptyList(), null);

    }

    @Override
    public void loadAfter(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, ExBean> callback) {
        callback.onResult(Collections.<ExBean>emptyList(), null);
    }

在PageKeyedDataSourceExtension中创建一个新的PagedList用来重新绑定Adapter,

    public PagedList<ExBean> createNewPagedList(PagedList.Config config) {
        @SuppressLint("RestrictedApi") PagedList<ExBean> pagedList
        = new PagedList.Builder<>(this, config)
                .setFetchExecutor(ArchTaskExecutor.getIOThreadExecutor())
                .setNotifyExecutor(ArchTaskExecutor.getMainThreadExecutor())
                .build();
        return pagedList;
    }

准备好新的数据源之后,可以开始进行增删的具体操作。

二、新增

//增加
public void add(ExBean exBean) {
        //获取当前PagedList
        PagedList<ExBean> curList = getCurrentList();
        PageKeyedDataSourceExtension source = new PageKeyedDataSourceExtension();
        //将当前数据以及所要增加的数据添加到新的数据集中
        source.mDataList.addAll(curList);
        source.mDataList.add(exBean);
        
        //创建新的数据PagedList
        PagedList<ExBean> pagedList = source.createNewPagedList(curList.getConfig());
        submitList(pagedList);
    }

获取当前的PagedList,并且将其添加到PageKeyedDataSourceExtension的List集合中,同时新增一条新的数据exBean,获取完新的数据后,通过createNewPagedList(即new PagedList.Builder<>)来触发loadInitial,返回新的PagedList,最后则利用submitList绑定新数据。

三、删除

删除与新增是一个道理,利用PagedListAdapter的getItem(int positon)获取到需要删除的数据,通过遍历剔除需要删除的数据,创建新的数据源后再次绑定到Adapter上。

//删除
public void delete(int position) {
        //获取当前PagedList
        PagedList<ExBean> curList = getCurrentList();
        PageKeyedDataSourceExtension source = new PageKeyedDataSourceExtension();
        ExBean b = getItem(position);
        //遍历当前PagedList,剔除需要删除的item
        for(ExBean bean : curList){
           if(bean != b){
               source.mDataList.add(bean);
             }
        }
        
        //创建新的数据PagedList
        PagedList<ExBean> pagedList = source.createNewPagedList(curList.getConfig());
        submitList(pagedList);
    }

四、其它问题

在新增和删除中,由于创建了新的数据源并且绑定到了Adapter上,Paging的滑动也就被新的数据源所接管。

从代码PageKeyedDataSourceExtension类的loadAfter中可以知道,传入了一个空的List集合,

    ...
  @Override
    public void loadAfter(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, ExBean> callback) {
        callback.onResult(Collections.<ExBean>emptyList(), null);
    }
    ...

导致在新增或者删除之后,如果用户继续想要向下滑动请求数据,是没有数据返回的。

如果有需求说要在新增或者删除后继续滑动请求,这也就需要做特殊的处理。我们都了解loadAfter是用来返回下一页数据的,我们在loadAfter继续用新增/删除之前的DataSource去接管,如下:

 @Override
    public void loadAfter(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, ExBean> callback) {
        //callback.onResult(Collections.<ExBean>emptyList(), null);
        mDataSource.loadAfter(params,callback)//mDataSource为旧的数据源
    }

https://juejin.cn/post/6901296420410638343

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于 Room 数据库的升级,您需要遵循以下步骤: 1. 在新版本的数据库中定义新表结构或对旧表结构进行更,例如添加、删除或修表的列。 2. 在您的 `AppDatabase` 类中增加数据库版本号,可以在类上使用 `@Database` 注解指定版本号,例如: ```kotlin @Database(entities = [User::class], version = 2) abstract class AppDatabase : RoomDatabase() { //... } ``` 3. 创建一个实现 `Migration` 接口的类,该类将包含从旧版本升级到新版本所需的所有更。例如: ```kotlin val migration_1_2 = object : Migration(1, 2) { override fun migrate(database: SupportSQLiteDatabase) { database.execSQL("ALTER TABLE users ADD COLUMN age INTEGER NOT NULL DEFAULT 0") } } ``` 该示例代码表示,从版本 1 升级到版本 2,需要在 `users` 表中添加一个名为 `age` 的整数类型的列。 4. 在 `AppDatabase` 类中,使用 `addMigrations()` 方法将 `Migration` 对象添加到数据库中,例如: ```kotlin @Database(entities = [User::class], version = 2) abstract class AppDatabase : RoomDatabase() { //... companion object { val migration_1_2 = object : Migration(1, 2) { override fun migrate(database: SupportSQLiteDatabase) { database.execSQL("ALTER TABLE users ADD COLUMN age INTEGER NOT NULL DEFAULT 0") } } } //... init { if (BuildConfig.DEBUG) { // 在调试模式下,如果发现数据结构变化,将会清空数据 fallbackToDestructiveMigration() } else { // 在正式发布模式下,如果发现数据结构变化,将会执行升级脚本 addMigrations(migration_1_2) } } } ``` 在上述示例代码中,我们将 `migration_1_2` 对象添加到 `AppDatabase` 类的伴生对象中,并在 `init` 块中进行了初始化。我们还使用了 `fallbackToDestructiveMigration()` 方法,如果在调试模式下发现数据结构变化,将会清空数据。在正式发布模式下,我们使用了 `addMigrations()` 方法,将 `migration_1_2` 对象添加到数据库中,以执行升级脚本。 这样,在您的应用程序使用新版本的数据库时,将自动执行升级脚本,以将旧数据结构转换为新数据结构。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值