- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在我的回收站 View 上使用 gridLayoutManager 并想在其上实现分页。我的问题是,当我到达 View 的底部并从服务添加数据并且我使用 notifyDataSetChanged 或 notifyItemRangeChanged 时,recyclerView 不会更新,直到我向上滚动它。如果我再次设置适配器并将位置设置为之前的位置,则会出现闪烁效果,这并不平滑。这是我尝试过的,但似乎没有任何效果
//adding data to my list
mNewsList.addAll((List<NewDataModel>) response.body());
// i set the adapter again
int currentPosition =
gaggeredGridLayoutManager.findLastVisibleItemPosition();
adapter = new RecyclerViewAdapter(mNewsList, Utilities.getThin(getActivity()), (AppCompatActivity) getActivity(), mHeaderTextView.getText().toString());
recyclerView.setAdapter(adapter);
gaggeredGridLayoutManager.scrollToPosition(currentPosition+1);
和
//adding data to my list
mNewsList.addAll((List<NewDataModel>) response.body());
adapter.notifyDataSetChanged();
和
adapter.notifyItemRangeChanged(0,adapter.getItemCount());
最佳答案
为避免闪烁效果,您必须在适配器设置后使用处理程序
Handler handler = new Handler();
handler.postDelayed(new Runnable() {
@Override
public void run() {
//do anything
rv_products.scrollToPosition(lastPos);
}
}, 100);
我已经使用以下方式实现分页
rv_products.addOnScrollListener(new RecyclerView.OnScrollListener() {
@Override
public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
super.onScrolled(recyclerView, dx, dy);
visibleItemCount = rv_products.getChildCount();
if (productListAdapter.getViewType() == 1)
totalItemCount = mGridLayoutManager.getItemCount();
else
totalItemCount = mSingleLayoutManager.getItemCount();
if (productListAdapter.getViewType() == 1)
firstVisibleItem = mGridLayoutManager.findFirstVisibleItemPosition();
else
firstVisibleItem = mSingleLayoutManager.findFirstVisibleItemPosition();
if (loading) {
if (totalItemCount > previousTotal) {
loading = false;
previousTotal = totalItemCount;
}
}
if (!loading && (totalItemCount - visibleItemCount)
<= (firstVisibleItem + visibleThreshold)) {
if (lstProducts.size() < totalCount)
getProducts(category_id);
loading = true;
}
}
});
public void getProducts(String id) {
pDialog.setCancelable(false);
pDialog.show();
PreferenceSetting preferenceSetting = PreferenceSetting.getInstance(activity);
Map<String, String> postParam = new HashMap<String, String>();
postParam.put("category_id", id);
postParam.put("customer_id", preferenceSetting.getCustomerId());
postParam.put("eventName", Constants.EVENT_GET_PRODUCTS);
postParam.put("page", (pageIndex++) + "");
CommonUtility.setLog("getProducts", postParam.toString());
JsonObjectRequest jsonObjReq = new JsonObjectRequest(Request.Method.POST,
Constants.Server_URL, new JSONObject(postParam),
new Response.Listener<JSONObject>() {
@Override
public void onResponse(JSONObject response) {
Log.e(getBaseActivity().getLocalClassName(), response.toString());
pDialog.dismiss();
try {
String message = response.getString(Constants.KEY_MESSAGE);
if (response.getString(Constants.KEY_STATUS).equals(Constants.VALUE_STATUS_SUCCESS)) {
Gson gson = new Gson();
ProductsReponse productsReponse = gson.fromJson(response.toString(), ProductsReponse.class);
((MainActivity) activity).setCartListCount(productsReponse.getData().getCartItemCount());
lstProducts.addAll(productsReponse.getData().getProductDetail());
totalCount = Integer.parseInt(productsReponse.getData().getTotalItem());
productListAdapter.notifyDataSetChanged();
tv_count.setText("(" + totalCount + " items)");
} else {
// CommonUtility.ShowToast(activity, message, "");
}
} catch (JSONException e) {
e.printStackTrace();
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
pDialog.dismiss();
}
}) {
/**
* Passing some request headers
*/
@Override
public Map<String, String> getHeaders() throws AuthFailureError {
HashMap<String, String> headers = new HashMap<String, String>();
headers.put("Content-Type", "application/json; charset=utf-8");
return headers;
}
};
// Adding request to request queue
MyApp.getInstance().addToRequestQueue(jsonObjReq);
}
关于android - RecyclerView 未使用 notifyDatasetChanged 更新,直到向上滚动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44897986/
如果我有如下列, 1 2 2 1 3 4 5 我如何找到从已知值向上的特定数字的第一次出现,比如 4。我知道 4 在列中的位置,我希望第一次出现 1 的行号从 4 向上(行号 4在这种情况下)。 我的
我这里有一个 fiddle http://jsfiddle.net/BB3JK/47/我改编自上一个问题( How can I move selected option in multiselect
大家好,我的应用程序遇到问题。我的复选框中的复选框,一旦我选中该复选框并向下/向上滚动,该复选框就消失了,我不知道这是怎么发生的。谁能帮我这个?谢谢您的帮助 :)这是我的代码: public clas
我想使用 jQuery scrollTo 函数或其他一些类似的函数来实现以下功能,以达到相同的结果。 我的页面上基本上会有一个 DIV 部分,其中包含大约 10 个类别 URL 链接。 例如: div
我有这个标记 Sample 1 Sample 2 Sample 3 Sample 4
我得到了一个包含项目的列表。他们都有一个“排序”列。排序列是int类型,并且是唯一的。 场景: sort 1; sort 2; sort 3; 如果用户在列表中向上移动一个项目(例如排序 3)(例如到
在我的网页上,我在一个可滚动的 DIV 中放置了一个表格。 当我向下滚动时,我想突出显示表格中最可见的中间行。 我该怎么做? 我发现以下脚本接近我的期望 --> www.rgagnon.com/jsd
我已经训练了完全相同的模型(使用完全相同的训练数据集)两次,但结果非常不同,而且我对它们的损失曲线的行为感到困惑。 第一个实验的损失曲线(红色曲线)在第一个时期结束时突然上升,然后缓慢稳定下降。 但是
我希望主导航的子菜单在鼠标悬停时向下滑动并在鼠标移开时向上滑动。 以下是我正在处理的页面:http://jaspreetkaur.com/marg-moll/ 以下是我尝试创建效果的 jQuery 代
我有一个 UIPageViewController,其中每个 VC 的中心都有一个数字。 我希望当我从一个 View 滑动到另一个 View 时,数字将从 0 开始并向上计数,直到达到正确的数字(或者
我一直在谷歌搜索,但找不到正确的脚本。也许有人可以指出我正确的方向? 我需要显示用户自访问某个页面以来在网站上处于事件状态的时间。我正忙于测试站点,例如用户有 1 小时来完成测试,因此我需要显示用户忙
向上/向下箭头滚动在 jquery scrollify 插件中不起作用。我想使用页面向上/向下按钮和向上/向下箭头按钮单击进行滚动。页面向上/向下箭头工作正常,正如我所期望的。向上/向下按钮单击不随着
我想在按下左右箭头时使用数组创建一个上下计数动画。 我有 3 个数组,每个箭头将链接到一个 ID。 var KEY = { LEFT: 37, RIGHT: 39 } $(function(
我对那个 JS 有点问题.. - 有一个 divs 并且这是在随机变化的行中自动变化的... 我需要将向上移动的 div 的颜色更改为绿色.. div 正在向下移动以更改为红色.. 我尝试这样做,但我
我希望能够使用我的键盘键在 ul 列表中滚动。经过几次尝试后,我成功了。 不幸的是,我遇到了一个很长的列表的问题。我希望能够通过提供 css 规则 overflow:auto; 来滚动浏览它们; 键盘
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 7 年前。 Improve this q
在我的应用程序中,我允许用户通过使用 ProcessCmdKey 按住右箭头键来滚动电影。现在我想让用户能够在需要时提高滚动速度。理想情况下,用户应该能够按住右箭头键,然后当他决定提高速度时,他应该在
我已经在 listview 上设置了 smoothScrollToPosition 并且效果很好!但是...我宁愿将位置放在 listview 的顶部,而不是仅仅放在屏幕上(如果需要向下滚动,则主要放
我想构建一个脚本来向上/向下滚动到页面的部分标记。我的源代码如下所示: HTML: UP DOWN First Second Third Fourth CSS: section{
我正在使用 Google 搜索结果实现创建一个自定义 ComboBox 控件,但我在使用箭头键时遇到了一些问题。 问题详情 请观看此视频,因为我演示了向上和向下箭头键的问题,并查看输出面板。 http
我是一名优秀的程序员,十分优秀!