jquery事件在使用Datatables插件的表格只有第一页生效解决方法 @勤勤学长

一开始我还以为代码写错了,因为我用来测试的表格数据都放在后边,点击删除按钮都没用反应。

然后发现连其他事件都没反应了,比如change。

通过排查法得知,第一页的数据正常,翻页之后的数据就不行了。

搜索后知道解决方法:

 

使用jquery中的on方法。

$(selector).on(event,childSelector,data,function);

 

实例代码:

     <table id="example" class="am-table am-table-bordered table"  width="100%">
        <thead>
            <tr>
                <th>#</th>
                <th>ico地址</th>
                <th>链接标题</th>
                <th>链接地址</th>
                <th>排序</th>
                <th>操作</th>
            </tr>
        </thead>
        <tbody>
        	{foreach $data1  as $vo}
            <tr>
            	<input type="hidden" name="url_id[]" id="url_id[]" value="{$vo.id}" />
                <td>{$vo.id}</td>
                <td><input class="am-u-md-20 form-control ico_url" name="ico_url[]" placeholder="不填写调用调用默认ico地址" value="{$vo.ico_url}"></td>
                <td><input class="am-u-md-8 form-control title" name="title[]"  placeholder="输入链接标题" value="{$vo.title}"></td>
                <td><input class="am-u-md-18 form-control url"  placeholder="输入链接地址" name="url[]" value="{$vo.url}"></td>
                <td><input class="am-u-md-6 form-control sort"  placeholder="输入排序数字" name="sort[]" value="{$vo.sort}"></td>
                <td><input type="button" id="delete[]" value="删除" class="am-btn am-btn-danger" name="delete[]" url_id='{$vo.id}' /></td>
            </tr>
            {/foreach}
        </tbody>
    </table>
<script type="text/javascript">
    
    $(document).ready(function() {

     	$('#example').dataTable();

    $('.table tbody').on('click','input[name="delete[]"]',function(){

	  alert('666');

    });

		});     	
	});
</script>

参考链接

jQuery on() 方法:http://www.runoob.com/jquery/event-on.html

datatables 组件翻页后 JS 不生效:https://www.oschina.net/question/97615_163097

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Java中使用jQuery表格插件datatables,您需要将datatables插件的JavaScript和CSS文件添加到您的项目中,并将它们链接到您的HTML页面。然后,您可以使用以下步骤来在Java中使用datatables插件: 1.在HTML页面中创建一个表格,并添加一个唯一的ID。 2.在JavaScript代码中初始化datatables插件,并将其绑定到表格的ID。 例如,以下是初始化datatables插件并将其绑定到表格ID为"example"的代码示例: ``` $(document).ready(function() { $('#example').DataTable(); } ); ``` 3.在Java代码中,您需要从数据库中检索数据,并将其转换为JSON格式。 4.将JSON数据传递给您的HTML页面,以便datatables插件可以使用它来填充表格。 例如,以下是从Java中检索数据并将其转换为JSON格式的代码示例: ``` List<Employee> employees = employeeService.getEmployees(); Gson gson = new Gson(); String json = gson.toJson(employees); model.addAttribute("employeesJson", json); ``` 5.在HTML页面中,使用datatables插件的"ajax"选项将JSON数据传递给表格。 例如,以下是将JSON数据传递给表格的代码示例: ``` $(document).ready(function() { $('#example').DataTable( { "ajax": "/employees", "columns": [ { "data": "id" }, { "data": "name" }, { "data": "position" }, { "data": "salary" } ] } ); } ); ``` 在上述代码中,"ajax"选项指向您的Java控制器中的URL,该控制器返回JSON数据。"columns"选项指定表格的列。每个"columns"对象中的"data"属性指定JSON数据对象中的属性。 希望这可以帮助您开始在Java中使用datatables插件

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值