html项目前端交互服务器代码,php之接口与前端数据交互实现示例代码

最近在做前后端数据交互的尝试,也跳了很多坑,使用的是php+bootstrap-table+js,把一些收获记录在这里,方便查询。

这个小项目,仅有3个文件,分别为:

1.crud.html

2.data.php

3.crud.sql相关学习推荐:PHP编程从入门到精通

数据交互实现1:查询

1.mysql 数据库建表

2.php查询接口

3.前端数据展现

mysql 数据库建表数据库名称:crud第一个表名:t_users主键:user_id,自增长排列

php:<?php

//测试php是否可以拿到数据库中的数据

/*echo "44444";*/

//做个路由 action为url中的参数

$action = $_GET['action'];

switch($action) {

case 'init_data_list':

init_data_list();

break;

case 'add_row':

add_row();

break;

case 'del_row':

del_row();

break;

case 'edit_row':

edit_row();

break;

}

//查询方法

function init_data_list(){

//测试 运行crud.html时是否可以获取到 下面这个字符串

/*echo "46545465465456465";*/

//查询表

$sql = "SELECT * FROM `t_users`";

$query = query_sql($sql);

while($row = $query->fetch_assoc()){

$data[] = $row;

}

$json = json_encode(array(

"resultCode"=>200,

"message"=>"查询成功!",

"data"=>$data

),JSON_UNESCAPED_UNICODE);

//转换成字符串JSON

echo($json);

}

/**查询服务器中的数据

* 1、连接数据库,参数分别为 服务器地址 / 用户名 / 密码 / 数据库名称

* 2、返回一个包含参数列表的数组

* 3、遍历$sqls这个数组,并把返回的值赋值给 $s

* 4、执行一条mysql的查询语句

* 5、关闭数据库

* 6、返回执行后的数据

*/

function query_sql(){

$mysqli = new mysqli("127.0.0.1", "root", "root", "crud");

$sqls = func_get_args();

foreach($sqls as $s){

$query = $mysqli->query($s);

}

$mysqli->close();

return $query;

}

?>

前端实现:

#table {

padding: 0;

}

#table>tbody>tr {

cursor: pointer;

}

#table>tbody>tr>td.bs-checkbox {

vertical-align: middle;

}

增删改查

删除

新建

var $table = $('#table'),

$remove = $('#remove');

$(function() {

searchData();

});

function prepareDisplayData(data) {

return {

total: data.data.length,

fixedScroll: false,

rows: data.data

};

}

function searchData() {

var search_url = "./php/data.php";

//url 中问号后面的参数 action,这个对象就是查询的参数

var dataParam = {

action: "init_data_list"

};

$.ajax({

type: "get",

url: search_url,

data: dataParam,

dataType: 'json',

contentType: 'application/json; charset=utf-8',

success: function(data) {

//测试是否可以拿到php中的数据

console.log(data);

//遍历这个数组

if(data.resultCode == 200) {

var itemArr = data.data;

for(var i = 0; i < itemArr.length; i++) {

var item = itemArr[i];

console.log(item);

}

}

//bootstrap-table 组织数据

var displayData = prepareDisplayData(data);

if(displayData.total > 0) {

$('#table').bootstrapTable('load', displayData);

} else {

console.log("last page or empty.");

}

},

error: function(data) {

alert('服务器出错');

},

});

}

$('#table').bootstrapTable({

pagination: true,

sidePagination: 'server', //设置为服务器端分页

pageNumber: 1,

pageSize: 10,

pageList: [10, 20, 50, 100],

search: true,

showColumns: true,

showRefresh: true,

columns: [{

field: 'state',

checkbox: true,

}, {

field: 'user_id',

title: '用户Id',

width: '50',

align: 'center',

valign: 'middle'

}, {

field: 'user_name',

title: '用户名称',

width: '500',

align: 'center',

valign: 'middle'

}, {

field: 'user_age',

title: '用户年龄',

width: '500',

align: 'center',

valign: 'middle'

}, {

field: 'user_sex',

title: '用户性别',

width: '500',

align: 'center',

valign: 'middle'

}, {

field: 'user_add',

title: '编辑',

formatter: forwardFormatter,

width: '500',

align: 'center',

valign: 'middle'

}]

}).on('page-change.bs.table', function(e, page, size) {

fillData();

}).on('check.bs.table uncheck.bs.table check-all.bs.table uncheck-all.bs.table', function() {

var tes = !$table.bootstrapTable('getSelections').length

$remove.prop('disabled', !$table.bootstrapTable('getSelections').length);

});

function forwardFormatter(value, row, index) {

var value = "修改";

return "" + value + "";

}

实现效果:

数据交互实现2:删除

在做删除时遇到不少的坑,究其原因是因为对SQL语句不熟悉,对php不熟悉,不过,总结了以下几点,供参考:

1.delete 返回的参数只能用 $_GET 获取;

2.delete 返回的参数要放在URL中,不能放在body中;body中的参数是用来查询的;

3.SQL语句一定要熟练,一步错,步步错;

4.要在数据库中执行SQL语句检查语句是否执行正确,要使用 Rest Client 测试URL请求是否正确;

php:<?php

//测试php是否可以拿到数据库中的数据

/*echo "44444";*/

//做个路由 action为url中的参数

$action = $_GET['action'];

switch($action) {

case 'init_data_list':

init_data_list();

break;

case 'add_row':

add_row();

break;

case 'del_row':

del_row();

break;

case 'edit_row':

edit_row();

break;

}

//删除方法

function del_row(){

//测试

/*echo "ok!";*/

//接收传回的参数

$rowId = $_GET['rowId'];

$sql = "delete from t_users where user_id='$rowId'";

if(query_sql($sql)){

echo "ok!";

}else{

echo "删除失败!";

}

}

?>

前端实现JS部分:var $table = $('#table'),

$remove = $('#remove');

$(function() {

delData();

});

function delData() {

$remove.on('click', function() {

if(confirm("是否继续删除")) {

var rows = $.map($table.bootstrapTable('getSelections'), function(row) {

//返回选中的行的索引号

return row.user_id;

});

}

$.map($table.bootstrapTable('getSelections'),function(row){

var del_url = "./php/data.php";

//根据userId删除数据,因为这个id就是 传给服务器的参数

var rowId = row.user_id;

$.ajax({

type:"delete",

url:del_url + "?action=del_row&rowId=" + rowId,

dataType:"html",

contentType: 'application/json;charset=utf-8',

success: function(data) {

$table.bootstrapTable('remove',{

field: 'user_id',

values: rows

});

$remove.prop('disabled', true);

},

error:function(data){

alert('删除失败!');

}

});

});

})

}

调试方法:

数据交互实现3:新增

在写php的方法上,我觉得我的方法是有问题的,因为所有的参数,也就是所有的需要新增的数据都是通过 接口以 ? 后跟参数的方式添加成功的。功能是可以实现,但是如果新增的数据较大,这个方法显示是不可行的,但是还没有找到合适的方法,烦请大侠们指点。

php:<?php

//测试php是否可以拿到数据库中的数据

/*echo "44444";*/

//做个路由 action为url中的参数

$action = $_GET['action'];

switch($action) {

case 'init_data_list':

init_data_list();

break;

case 'add_row':

add_row();

break;

case 'del_row':

del_row();

break;

case 'edit_row':

edit_row();

break;

}

//新增方法

function add_row(){

/*获取从客户端传过来的数据*/

$userName = $_GET['user_name'];

$userAge = $_GET['user_age'];

$userSex = $_GET['user_sex'];

//INSERT INTO 表名 (列名1,列名2,...)VALUES ('对应的数据1','对应的数据2',...)

// VALUES 的值全为字符串,因为表属性设置为字符串

$sql = "INSERT INTO t_users (user_name,user_age,user_sex) VALUES ('$userName','$userAge','$userSex')";

if(query_sql($sql)){

echo "ok!";

}else{

echo "新增成功!";

}

}

function query_sql(){

$mysqli = new mysqli("127.0.0.1", "root", "root", "crud");

$sqls = func_get_args();

foreach($sqls as $s){

$query = $mysqli->query($s);

}

$mysqli->close();

return $query;

}

?>

前端实现JS部分:

html使用了bootstrap 的 modal作为新增时的弹出框

×

用户名称

用户年龄

用户性别

请选择

关闭

保存

$remove = $('#remove');

$(function() {

searchData();

delData();

$('#save').click(function(){

addData();

});

});

function addData(){

var userName = $('#userName').val();

var userAge = $("#userAge").val();

var userSex = $('#user-sex').val() == '0' ? '男' : '女';

var addUrl = "./php/data.php?action=add_row&user_name=" + userName + "&user_age=" + userAge + "&user_sex=" + userSex;

$.ajax({

type:"post",

url:addUrl,

dataType:'json',

contentType:'application/json;charset=utf-8',

success:function(data){

console.log("success");

},

error:function(data){

console.log("data");

//添加成功后隐蒧modal框

setTimeout(function(){

$('#exampleModal').modal('hide');

},500);

//隐藏modal框后重新加载当前页

setTimeout(function(){

searchData();

},700);

}

});

}

至此,还没有解决如下问题:

1.表单验证;

2.添加多条数据后,php如何接收参数;

3.新增成功后,在$.ajax的方法中,为什么,新增成功后的其它操作要在 error 这个对象中实现?而不是在 sucess 中实现?

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值