javascript - 关于AJAX数据提交后台无法获取的问题
大家讲道理
大家讲道理 2017-04-11 12:46:17
[JavaScript讨论组]

问题

前台可以获取到表格的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数据问题……我试了下直接传值,显示结果一样。就是我直接从控制台输出数据中复制到代码中——


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

请问这个有解决办法吗?

大家讲道理
大家讲道理

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

全部回复(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数组中了

结果如下:

天蓬老师

table里可能触发了默认的submit

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号