javascript - 关于AJAX数据提交后台无法获取的问题
大家讲道理
大家讲道理 2017-04-11 12:46:17
0
2
297

问题

前台可以获取到表格的JSON数据,但是通过AJAX POST提交后台没有接收到数据。

前台代码

这里贴的都是主要部分,其他的我就省略了,使用了bootstrap-table插件和bootbox插件,后台使用Thinkphp3.2.3。

HTML代码

... ...

table是通过插件.bootstrapTable直接创建的,主键是student_id

JS代码

$('#btn_del').on('click', function () { var selection = $('#studentTable').bootstrapTable('getAllSelections'); var json=JSON.stringify(selection); function getSelectionId(data) { var result=[]; var temp={}; for(var i=0;i

这是我最新试过的一种方法,想直接获取student_id,但是后台还是没有获取到。

PHP代码

public function delStudent() { $post = I('post.'); dump($post); ... }

显示结果

控制台中显示的是注释掉的两行console.log(),可以看到获取到了student_id,然后传递的data中也有数据(这块会不会出错?)——

然后后台是执行了AJAX请求,但是获取的POST数据不正确?

这是其中一种情况,如果我把上面JS代码中AJAX提交的数据改为data:JSON.stringify(selection)提交的结果如下:

目前还是不知道问题出在哪里?

后续补充

目前已知应该是JSON数据问题……我试了下直接传值,显示结果一样。就是我直接从控制台输出数据中复制到代码中——


然后后台返回结果还是一样的……

请问这个有解决办法吗?

大家讲道理
大家讲道理

光阴似箭催人老,日月如移越少年。

reply all (2)
刘奇

问题解决了……主要问题就是bootstrapTable获取数据的问题,官方文档上写的就是Return selected rows, when no record selected, an empty array will return.意思就是返回的是一个JSON数组。所以直接调用就行~

$.ajax({ ... data:{json:selection} });

这样返回的数组就是在POST['json']中了~,然后后台直接读取就是

$post=I('post.json');//我用的是TP3的内置函数,这样读出来的数据都在$post数组中了

结果如下:

    Peter_Zhu

    table里可能触发了默认的submit

      Latest Downloads
      More>
      Web Effects
      Website Source Code
      Website Materials
      Front End Template
      About us Disclaimer Sitemap
      php.cn:Public welfare online PHP training,Help PHP learners grow quickly!