Bootstrap Table 再次点击当前页按钮会跳转首页或者退出登录问题解决办法

如图,Bootstrap Table 的分页条,当前是第1页,当再次点击第1页标签时候,会跳转至首页或者退出登录了,下面将分析怎么解决这个问题。

image.png

问题分析

使用谷歌浏览器检查该标签源码得到的是下面的结果(同时贴上第2页第2页的代码):

<li class="page-number active"><a href="#">1</a></li>
<li class="page-number"><a href="#">2</a></li>
<li class="page-number"><a href="#">3</a></li>

复制其链接地址是:

http://localhost:8955/xxx/#

执行该链接确实跳转到了登陆页或者首页,可见当再次点击当前页按钮时候,其实际上是跳转该链接,并没有再次调用查询数据接口。

解决办法

在前面的分析中知道了问题所在,那解决问题的方向就有了,我们只需要阻止a标签中的href动作执行就可以了。

因为分页条是 BootstrapTable 的一部分,因此其标签是由BootstrapTable 框架的js生成的,打开bootstrap-table.min.js文件,搜索page-number,可以看到查找到两处结果,因为分页标签是a标签,只有下面的代码片段有

('<li class="page-number'+(b===this.options.pageNumber?" active":"")+'">','<a href="#" >',b,"</a>","</li>");

再结合前面的浏览器中看到的源码,可见该处就是生成分页条代码的js源代码,在这里我们可以对a标签进行自定义以阻止href动作,下面提供两种修改方式。

方式1、把a标签的href属性值改为href="javascript:void(0)",让其href动作无效,修改后代码:

('<li class="page-number'+(b===this.options.pageNumber?" active":"")+'">','<a href="javascript:void(0)" >',b,"</a>","</li>");

2、给a标签加上 onclick="return false" 以停止其点击事件,修改后的代码如下:

('<li class="page-number'+(b===this.options.pageNumber?" active":"")+'">','<a href="#" onclick="return false" >',b,"</a>","</li>");

总结

至于为什么限制了href动作不会导致其分页点击无效,应该是BootstrapTable有js代码通过监听标签click动作时候执行了操作吧。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,702评论 1 92
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,695评论 25 709
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 14,757评论 4 61
  • 秋风卷起一地金黄, 我拾起一片黄色的银杏叶, 小心的把它夹在我的课本中, 我想等来年的春天, 它将又会结出满树的青...
    莉莉安L阅读 1,531评论 0 0
  • “习惯成自然”,可见习惯是一种形成了固定模式的自然的习性,如同身体器官一样,最后始终伴随自己的一种行为模式,正如我...
    三板斧阅读 2,144评论 0 0

友情链接更多精彩内容