- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
现在,我正在使用 jQuery DataTable。使用 JavaScript 数据数组初始化数据表一切顺利。
在我的表格中,它包括删除行按钮。当我单击每行的删除按钮时,我使用以下函数删除记录。
function removeRow(itemList, recordIndex){
itemList.splice(recordIndex, 1);
dataTable.clear();
dataTable.rows.add(itemList);
dataTable.columns.adjust().draw(false);
}
该函数执行良好,没有出现错误。此时,我将 false 设置为 draw()
函数,以防止在删除任何其他页面中的记录时转到第一页。这也对我有用。
问题是,当我的itemList
有11条记录时,我转到数据表的第二页并删除第11条记录。
所以,我的itemList
将只留下10条记录,我的数据表应该显示分页的首页页。
但是,jQuery 数据表并没有这样做。它仍然在第二页中没有记录。
我不知道如何解决这个问题。我想在删除当前页面的所有记录后显示上一页。
我知道没有 false 参数的 `draw()`` 函数将转到第一页。但每次删除它都会转到第一页。
当我删除当前页面的所有记录时,我只想转到上一页。
请帮帮我。谢谢。
最佳答案
我发现了一种hacky方法来在当前已清空时获取上一个分页。
它特定于 jQuery DataTable,因为使用它的类命名。
尝试一下CodePen .
function removeRow(recordIndex){
// Get previous pagination number
var previousPagination= parseInt( $(document).find(".paginate_button.current").data("dt-idx") ) -1;
// Splice the data.
data.splice(recordIndex,1);
myTable.clear();
myTable.rows.add(data);
myTable.columns.adjust().draw(false); // May ajust the pagination as empty... `.draw(false)` is needed.
// Decide to redraw or not based on the presence of `.deleteBtn` elements.
var doIdraw=false;
if($(document).find(".deleteBtn").length==0){
doIdraw=true;
}
myTable.columns.adjust().draw(doIdraw); // Re-draw the whole dataTable to pagination 1
// If the page redraws and a previous pagination existed (except the first)
if(previousPagination>1 && doIdraw){
var previousPage = $(document).find("[data-dt-idx='" + previousPagination + "']").click();
}
// Just to debug... Console.log the fact that only one pagination is left. You can remove that.
if(previousPagination==0 && doIdraw){
}
}
注意我使用了:
#myTable
作为表格 id
.deleteBtn
作为删除按钮class
data
作为 dataTable 数据我删除了上面代码中的所有 console.log()
和示例相关代码(但不在 CodePen 中)。
“删除此→”按钮处理程序是:
$("#myTable").on("click",".deleteBtn",function(){
var rowElement = $(this).closest("tr");
var rowIndex = myTable.row(rowElement).index();
removeRow(rowIndex);
});
关于javascript - jQuery 数据表 : Delete row and reload,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40301861/
请帮助修复算法并防止点击提交后重新加载:我的网站必须检查,用户是否曾经输入过昵称。如果他有,那么网站必须显示他的名字,如果没有,则要求输入。如果用户决定更改它,他将单击“重置用户名”。 点击“重置”后
我最近在 Chrome 中发现了这个新功能: 我可以找出选项 1 和选项 3 之间的区别,选项 2 可能介于两者之间,但我在任何地方都找不到更精确的信息。 有人知道这 3 个选项的确切行为吗? 最佳答
当我在模拟器上开发时一切都很好,但现在我正处于我的应用程序几乎完成但必须在真实设备上更改一些视觉小东西的阶段。出于这个原因,我希望有与在模拟器上测试时相同的选项:实时重载或热重载。 这是我摇动设备时的
所以,我在我的项目中使用了 gulp。 我使用 gulp-compass 来编译我的 Assets 。 而且,我的任务之一是监视开发人员的任务。像这样: gulp.task('live', funct
在 lein REPL 中有一个奇怪且非常烦人的行为,更不用说经常耗时了。 即,如果我将 :reload-all 与命名空间一起使用,并且它所需的命名空间有错误,则 repl 不会告诉我任何相关信息。
我需要使用 JavaScript 刷新页面。我尝试了 window.location.reload() 和 location.reload()。两者都在工作并重新加载页面。我应该使用哪一个? 最佳答案
我知道这很愚蠢,但我真的想了解 Location.reload() 和 window.location.reload() 之间的区别; 如果我使用 location.reload() 会发生什么?如果
In this plunk你有两个 ui-router 状态,一个父状态和一个子状态。当通过单击链接调用子级时,由于它具有选项 reload: true,因此它始终会重新加载。这很好,但问题是父状态也
当我用 expo 打开开发者菜单时,它显示: 实时重新加载不可用 和 热重载不可用 我已根据需要登录,我也尝试过使用二维码加载应用程序,但没有帮助。 .expo/settings.json: {
为什么 Live Reload、Hot Reload 和 Remote Debugger 都不可用?我试过了 重新加载 JS 包 重启模拟器 重新启动打包器 重新启动打包程序并清除缓存 重置模拟器 重
我在 Controller 中有这个: $scope.foo = function(){ return RolesService.remove({ data: rol
Angular.js 中的 $window.location.reload() 和 $route.reload() 有什么区别? 我已经使用了这两个东西,但它们的工作进度相同。 谁能解释一下区别? 最
只是一个简短的问题。我想知道是否有一个选项或开关可以启用重新加载按钮下的“硬重新加载”和“清空缓存和硬重新加载”选项而无需打开devtools,以便它们始终弹出,即使devtools没有开放。 我知道
我已经使用 flutter_web 有一段时间了,从来没有真正质疑过它在按下“热重载”时总是重新启动整个应用程序,但自从现在 flutter_web 被合并到主要的 flutter channel 我
例如,我希望导航中的此更改能够重新加载状态: #/detail/1 #/detail/2 但是我不希望这个导航重新加载状态: #/detail/1?search=blah #/detail/1?sea
遵循 uvicorn-gunicorn-fastapi-docker 中的文档我应该通过运行来运行我的图像: docker run -d -p 80:80 -v $(pwd):/app myimage
我看过很多关于 的帖子和出版物实时重载 , 热重载 , 和 热模块更换 ,指的是在 Web 客户端/FE 层工作时,在浏览器中立即反射(reflect)代码更改的不同做法。 我对这些术语指的是什么有一
我有一个脚本可以检查两个或多个选项是否相似。如果它们相似,我会阻止提交该页面。它有效,但仅当我在显示警报消息后刷新页面时才有效。如果我选择了一个合适的选项,除非刷新页面,否则错误警报仍保留在内存中。
我有一个脚本,可以动态地将一些参数写入配置文件,我需要根据更新的参数从链接模块调用一些函数。但是,当我在配置文件上调用 reload() 时,有时我看不到任何变化。 以下代码片段将解释该场景: imp
我已连接到远程 mysql 服务器,但在几次连接不良(由于自动化)后,我被服务器阻止。我正在尝试解锁自己。 提示建议我执行mysqladinlush-hosts # This was done loc
我是一名优秀的程序员,十分优秀!