基础Ajax,增删改查案例

<!DOCTYPE html>
<html>

<head>

    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">


    <title>表签设置</title>
    <link rel="shortcut icon" href="favicon.ico"> <link href="css/bootstrap.min.css?v=3.3.6" rel="stylesheet">
    <link href="css/font-awesome.css?v=4.4.0" rel="stylesheet">
    <link href="css/plugins/iCheck/custom.css" rel="stylesheet">
    <link href="css/animate.css" rel="stylesheet">
    <link href="css/style.css?v=4.1.0" rel="stylesheet">

    <!--open-->
    <link href="css/jquery.dialogbox-1.0.css" rel="stylesheet">

    <!-- Sweet Alert -->
    <link href="css/plugins/sweetalert/sweetalert.css" rel="stylesheet">
    <style>
        .ibox-title{
            min-height:55px;
            min-width: 207%;
        }
        .ibox-content{
            min-width: 207%;
        }
        .col-sm-2 {
            width: 4.666667%;
        }
        .ibox-content{
            padding:0px 20px 0px 20px;
        }
        .ibox {
            margin-bottom: 0px;
        }
    </style>
</head>

<body class="gray-bg">
<div class="wrapper wrapper-content animated fadeInRight">
    <div class="row">
        <div class="col-sm-12">
            <div class="ibox float-e-margins">
                <div class="ibox-content">
                    <form method="post" class="form-horizontal m-t" action="selectCount" name="query" id="query">
                        <div class="form-group">
                            <label class="col-sm-2 control-label">添加标签:</label>
                            <div class="col-sm-2">
                                <button class="btn btn-outline btn-primary open_add_page" data-type="0" type="reset">添加</button>
                            </div>
                        </div>
                        <!-- 隐藏表单域,记录当前页面跳转地址,出现异常时获取此值 -->
                        <input type="hidden" name="current_page" value="authterm_data" >
                    </form>
                </div>

            </div>
        </div>
    </div>
    <div class="row">
        <div class="col-sm-6">
            <div class="ibox float-e-margins">
                <div class="ibox-title">
                    <div class="ibox-tools">
                        <a class="collapse-link">
                            <i class="fa fa-chevron-up"></i>
                        </a>
                        <a class="dropdown-toggle" data-toggle="dropdown" href="table_basic.html#">
                            <i class="fa fa-wrench"></i>
                        </a>
                        <a class="close-link">
                            <i class="fa fa-times"></i>
                        </a>
                    </div>
                </div>
                <div class="ibox-content">
                    <table class="table table-bordered">
                        <thead>
                        <tr>
                            <th>序号</th>
                            <th>编号</th>
                            <th>标签名称</th>
                            <th>标签编号</th>
                            <th>操作</th>
                        </tr>
                        </thead>
                        <tbody class="list">
                        </tbody>
                    </table>

                </div>
            </div>
        </div>
    </div>
</div>

<!-- 全局js -->
<script src="js/jquery.min.js?v=2.1.4"></script>
<script src="js/bootstrap.min.js?v=3.3.6"></script>

<!---open--->
<script src="js/jquery.dialogbox-1.0.js"></script>
<!-- Peity -->
<script src="js/plugins/peity/jquery.peity.min.js"></script>

<!-- 自定义js -->
<script src="js/content.js?v=1.0.0"></script>


<!-- iCheck -->
<script src="js/plugins/iCheck/icheck.min.js"></script>

<!-- Peity -->
<script src="js/demo/peity-demo.js"></script>

<script>
    $(document).ready(function () {
        $('.i-checks').iCheck({
            checkboxClass: 'icheckbox_square-green',
            radioClass: 'iradio_square-green',
        });
    });
</script>

<script type="text/javascript" src="http://tajs.qq.com/stats?sId=9051096" charset="UTF-8"></script>
<!--统计代码,可删除-->
<script src="js/plugins/layer/layer.min.js"></script>
<script src="js/plugins/sweetalert/sweetalert.min.js"></script>
<script type="text/javascript">
    $(function () {
        show();
    })

    // //打开添加数据页面
    $(document).on('click','.open_add_page',function(){
        //获取下拉列表这里要用同步async:false,
        var array=[];
            $.ajax({
                url:'tab/selectListTab',
                type:'get',
                dataType:'json',
                success:function(res){
                    var datas=res.obj;
                    for(var i=0;i< datas.length ;i++){
                        //先创建好select里面的option元素
                        var option = document.createElement("option");
                        //转换DOM对象为JQ对象,好用JQ里面提供的方法 给option的value赋值
                        $(option).val(datas[i].tId);
                        //给option的text赋值,这就是你点开下拉框能够看到的东西
                        $(option).text(datas[i].tName);
                        //获取select 下拉框对象,并将option添加进select
                        $('#problemTypeId').append(option);
                    }
                }
            })
        //iframe层   parent 注意  把  parent 去掉
        var index=layer.open({
                type : 1,
                title : '数据添加页面',
                shadeClose : false,//是否点击遮罩关闭  如果是true就关闭   false不能关闭
                shade : 0.3,//遮罩层的透明度  0-1
                area : [ '40%', '51%' ],//弹框的大小   宽和高
                content : "<div class='dialogbox-main' style='border-left-width: 5px; direction: ltr; border-color: rgb(90, 90, 90); display: block;'><div class='dialogbox-message'><div id='companySelectFotmTable' style='display:table;width:100%;'>\n" +
                "<div id='comapnyRowId1' style='display:table-row;height: 40px'><div style='display:table-cell;'><label for='companyRdoID1'>编号</label></div><div style='display:table-cell;height: 40px;'>\n" +
                "<input id='firstname' name='firstname' type='text' autocomplete='off'>\n" +
                "</div></div>\n" +
                "    \n" +
                "<div id='comapnyRowId1' style='display:table-row;height: 40px'><div style='display:table-cell;'><label for='companyRdoID1'>标签名称</label></div><div style='display:table-cell;'>\n" +
                "<select data-placeholder=' ' class='chosen-select' style='width:76.2%;' tabindex='4' id='problemTypeId'><option>请选择</option>\n</select>" +
                "</div></div><div style='display:table-row;height: 40px'><div style='display:table-cell'>&nbsp;</div><button class='btn btn-primary' type='submit' id='add' ids=''  data-type='0'>保存</button></div></div></div></div>" //iframe的url
            });
    })


    // //打开修改数据页面
    $(document).on('click','.open_add_page1',function(){
        //获取下拉列表这里要用同步async:false,
        var array=[];
        var me=$(this);
        var ttId=me.attr("id");
        var str ="";
        var str1="";
        var strhidden="";
        $.ajax({
            url:'tab/selectListTab',
            type:'get',
            dataType:'json',
            success:function(res){
                var datas=res.obj;
                for(var i=0;i< datas.length ;i++){
                    //先创建好select里面的option元素
                    var option = document.createElement("option");
                    //转换DOM对象为JQ对象,好用JQ里面提供的方法 给option的value赋值
                    $(option).val(datas[i].tId);
                    //给option的text赋值,这就是你点开下拉框能够看到的东西
                    $(option).text(datas[i].tName);
                    //获取select 下拉框对象,并将option添加进select
                    $('#problemTypeId').append(option);
                }
            }
        });
        $.ajax({
            url:'tabrecord/TabSelectOne',
            type:'get',
            async:false,
            data:{ ttId:ttId,},
            dataType:'json',
            success:function(res){
                var datas=res.object;
                if(datas.deviceId){
                    str ="<input id='firstname' name='firstname' type='text' value='"+datas.deviceId+"'>";
                }else {
                    str ="<input id='firstname' name='firstname' type='text' value=''>";
                }
                if(datas.tId){
                    str1="<option value='"+datas.tId+"' selected = 'selected'>"+datas.tName+"</option>"
                }else {
                   str1="<option value='' selected = 'selected'></option>"
                }
                  strhidden="<input type='hidden' id='field_name'  name='field_name' value='"+datas.ttId+"'>"
            }
        });
        //iframe层   parent 注意  把  parent 去掉
       var index1= layer.open({
            type : 1,
            title : '数据修改页面',
            shadeClose : false,//是否点击遮罩关闭  如果是true就关闭   false不能关闭
            shade : 0.3,//遮罩层的透明度  0-1
            area : [ '40%', '51%' ],//弹框的大小   宽和高
            content : "<div class='dialogbox-main' style='border-left-width: 5px; direction: ltr; border-color: rgb(90, 90, 90); display: block;'><div class='dialogbox-message'><div id='companySelectFotmTable' style='display:table;width:100%;'>\n" +
            "<div id='comapnyRowId1' style='display:table-row;height: 40px'><div style='display:table-cell;'><label for='companyRdoID1'>编号</label></div><div style='display:table-cell;height: 40px;'>\n" +
            str+strhidden+
            "</div></div>\n" +
            "    \n" +
            "<div id='comapnyRowId1' style='display:table-row;height: 40px'><div style='display:table-cell;'><label for='companyRdoID1'>标签名称</label></div><div style='display:table-cell;'>\n" +
            "<select data-placeholder=' ' class='chosen-select' style='width:76.2%;' tabindex='4' id='problemTypeId'>"+str1+"</select>" +
            "</div></div><div style='display:table-row;height: 40px'><div style='display:table-cell'>&nbsp;</div><button class='btn btn-primary' type='submit' id='update' ids=''  data-type='0'>保存</button></div></div></div></div>" //iframe的url
        });
    });



    $(document).on('click','.del',function(){//删除数据
        var me=$(this);
        var ttId=me.attr("id");
        swal({
                    title: "您确定要删除这条信息吗",
                    text: "删除后将无法恢复,请谨慎操作!",
                    type: "warning",
                    showCancelButton: true,
                    confirmButtonColor: "#DD6B55",
                    confirmButtonText: "是的,我要删除!",
                    cancelButtonText: "让我再考虑一下…",
                    closeOnConfirm: false,
                    closeOnCancel: false,
                },
                function (isConfirm) {
                    if (isConfirm) {
                        $.ajax({
                            url:'tabrecord/tabDelet',
                            type:'get',
                            data:{ ttId:ttId,},
                            dataType:'json',
                            success:function(res){
                                if(res.msg=='ok'){
                                    swal("删除成功!","成功","success");
                                    show();
                                }else {
                                    swal("删除失败!","失败","error");
                                }
                            }
                        })
                    } else {
                        swal("已取消", "您取消了删除操作!", "warning");
                    }
                });
    })

    $(document).on('click','#add',function(){//添加
        var me=$(this);
        var deviceId=$('#firstname').val();
        var tId=$('#problemTypeId option:selected').val();
        $.ajax({
            url:'tabrecord/TabInsert',
            type:'get',
            data:{deviceId:deviceId,
                tId:tId,},
            dataType:'json',
            success:function(res){
                if(res.msg=='ok'){
                    parent.layer.msg('保存成功!');
                    layer.close(layer.index);
                }else {
                    parent.layer.msg('保存失败!');
                    refresh()
                }
            }
        })
    })

    $(document).on('click','#update',function(){//修改
        var ttId=$('#field_name').val();
        var deviceId=$('#firstname').val();
        var tId=$('#problemTypeId option:selected').val();
        console.log(ttId);
        $.ajax({
            url:'tabrecord/tabUpadte',
            type:'get',
            data:{ttId:ttId,
                deviceId:deviceId,
                tId:tId,},
            dataType:'json',
            success:function(res){
                if(res.msg=='ok'){
                    parent.layer.msg('修改成功!');
                    layer.close(layer.index);
                }else {
                    parent.layer.msg('修改失败!');
                    refresh()
                }
            }
        })
    })


    //    重置
    function refresh(){
        $('input[name="firstname"]').val('');//表签名称
        $('input[name="firstids"]').val('');//表签编号
    }


    function show(){
        $.ajax({
            url:'tabrecord/tabSelectList',
            type:'get',
            //data:{sid:sId},
            dataType:'json',
            success:function(res){
                var datas=res.obj;
                var str="";
                for(var i=0;i<datas.length;i++){
                    str+='<tr id="'+datas[i].ttId+'" class="idt">' +
                            '                    <td>'+[i+1]+'</td>' +
                            '                    <td>'+datas[i].deviceId+'</td>' +
                            '                    <td>'+datas[i].tName+'</td>' +
                            '                    <td>'+datas[i].tCoud+'</td>' +
                            '                    <td class="parent" id="'+datas[i].ttId+'"> ' + '                        ' +
                            '                    <a href="javascript:;" class="choose open_add_page1" id="'+datas[i].ttId+'">修改</a>' +
                            '                    <a href="javascript:;" class="del" id="'+datas[i].ttId+'">删除</a>' +
                            '</td> ' +
                            '                </tr>'
                }
                $('.list').html(str)
            }
        })
    }

</script>


</body>

</html>

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这里是一个简单的示例,使用PHP和jQuery实现基本的增删改查功能。 假设我们有一个名为“users”的数据库表,其中包含以下字段:id、name、email、phone。我们将创建一个Web应用程序,使用户能够执行以下操作: - 显示所有用户 - 添加新用户 - 编辑用户信息 - 删除用户 以下是实现这些功能的代码: index.php: ```html <!DOCTYPE html> <html> <head> <title>AJAX CRUD Example with PHP and jQuery</title> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> <script src="script.js"></script> </head> <body> <h1>AJAX CRUD Example with PHP and jQuery</h1> <div id="users"> <table> <tr> <th>ID</th> <th>Name</th> <th>Email</th> <th>Phone</th> <th>Action</th> </tr> </table> </div> <br> <div id="add_user"> <h2>Add User</h2> <form id="add_user_form"> <label>Name:</label> <input type="text" name="name" required> <br><br> <label>Email:</label> <input type="email" name="email" required> <br><br> <label>Phone:</label> <input type="text" name="phone" required> <br><br> <button type="submit">Add User</button> </form> </div> </body> </html> ``` script.js: ```javascript $(document).ready(function() { // 显示所有用户 showUsers(); // 添加用户 $('#add_user_form').submit(function(event) { event.preventDefault(); var name = $('input[name="name"]').val(); var email = $('input[name="email"]').val(); var phone = $('input[name="phone"]').val(); $.ajax({ url: 'add_user.php', type: 'POST', data: {name: name, email: email, phone: phone}, success: function(data) { alert('User added successfully'); showUsers(); } }); }); // 编辑用户信息 $(document).on('click', '.edit_user', function() { var id = $(this).data('id'); $('#edit_user_form').attr('data-id', id); $.ajax({ url: 'get_user.php', type: 'POST', data: {id: id}, success: function(data) { var user = JSON.parse(data); $('input[name="edit_name"]').val(user.name); $('input[name="edit_email"]').val(user.email); $('input[name="edit_phone"]').val(user.phone); } }); }); $('#edit_user_form').submit(function(event) { event.preventDefault(); var id = $(this).data('id'); var name = $('input[name="edit_name"]').val(); var email = $('input[name="edit_email"]').val(); var phone = $('input[name="edit_phone"]').val(); $.ajax({ url: 'edit_user.php', type: 'POST', data: {id: id, name: name, email: email, phone: phone}, success: function(data) { alert('User updated successfully'); showUsers(); } }); }); // 删除用户 $(document).on('click', '.delete_user', function() { var id = $(this).data('id'); $.ajax({ url: 'delete_user.php', type: 'POST', data: {id: id}, success: function(data) { alert('User deleted successfully'); showUsers(); } }); }); }); function showUsers() { $.ajax({ url: 'get_users.php', type: 'GET', success: function(data) { var users = JSON.parse(data); $('#users table').empty(); $('#users table').append('<tr><th>ID</th><th>Name</th><th>Email</th><th>Phone</th><th>Action</th></tr>'); $.each(users, function(i, user) { $('#users table').append('<tr><td>' + user.id + '</td><td>' + user.name + '</td><td>' + user.email + '</td><td>' + user.phone + '</td><td><button class="edit_user" data-id="' + user.id + '">Edit</button> <button class="delete_user" data-id="' + user.id + '">Delete</button></td></tr>'); }); } }); } ``` get_users.php: ```php <?php $conn = mysqli_connect('localhost', 'username', 'password', 'database'); $result = mysqli_query($conn, 'SELECT * FROM users'); $users = array(); while ($row = mysqli_fetch_assoc($result)) { $users[] = $row; } echo json_encode($users); ?> ``` add_user.php: ```php <?php $conn = mysqli_connect('localhost', 'username', 'password', 'database'); $name = mysqli_real_escape_string($conn, $_POST['name']); $email = mysqli_real_escape_string($conn, $_POST['email']); $phone = mysqli_real_escape_string($conn, $_POST['phone']); mysqli_query($conn, "INSERT INTO users (name, email, phone) VALUES ('$name', '$email', '$phone')"); ?> ``` get_user.php: ```php <?php $conn = mysqli_connect('localhost', 'username', 'password', 'database'); $id = mysqli_real_escape_string($conn, $_POST['id']); $result = mysqli_query($conn, "SELECT * FROM users WHERE id=$id"); $user = mysqli_fetch_assoc($result); echo json_encode($user); ?> ``` edit_user.php: ```php <?php $conn = mysqli_connect('localhost', 'username', 'password', 'database'); $id = mysqli_real_escape_string($conn, $_POST['id']); $name = mysqli_real_escape_string($conn, $_POST['name']); $email = mysqli_real_escape_string($conn, $_POST['email']); $phone = mysqli_real_escape_string($conn, $_POST['phone']); mysqli_query($conn, "UPDATE users SET name='$name', email='$email', phone='$phone' WHERE id=$id"); ?> ``` delete_user.php: ```php <?php $conn = mysqli_connect('localhost', 'username', 'password', 'database'); $id = mysqli_real_escape_string($conn, $_POST['id']); mysqli_query($conn, "DELETE FROM users WHERE id=$id"); ?> ``` 这些代码将创建一个简单的Web应用程序,用户可以使用它来执行基本的增删改查操作,而无需刷新页面。当用户执行任何操作时,都会使用AJAX通过PHP与MySQL数据库进行通信。 ### 回答2: PHP AJAX 实现增删改查是一种常用的Web开发技术,可以提供实时的数据交互和无需刷新页面的操作体验。下面以一个简单的用户信息管理作为例子进行说明: 增加操作(Create):通过AJAX发送请求,将用户输入的信息传递给PHP后台,PHP将信息插入数据库中,然后将插入结果返回给前端页面,可以实现实时更新显示。 删除操作(Delete):通过AJAX发送请求,将要删除的用户id传递给PHP后台,PHP根据接收到的id删除相应的用户数据,然后将删除结果返回给前端页面。 修改操作(Update):通过AJAX发送请求,将用户修改的信息以及要修改的用户id传递给PHP后台,PHP根据id更新数据库中的用户信息,然后将更新结果返回给前端页面。 查询操作(Retrieve):通过AJAX发送请求,将查询条件传递给PHP后台,PHP根据条件从数据库中检索相应的用户信息,然后将查询结果返回给前端页面。 在实现增删改查的过程中,可以使用jQuery等库来简化AJAX的操作,并使用JSON格式进行数据的传输。同时,为了保证数据的安全性和完整性,需要对用户输入进行合法性验证,并使用prepared statement等方式来防止SQL注入攻击。 总之,PHP AJAX 实现增删改查可以提高用户体验和操作效率,实现数据的实时交互和无刷新更新。同时,开发者需要注意数据的安全性和完整性,以及代码的健壮性和可维护性。 ### 回答3: PHP和Ajax是两种不同的编程语言和技术,在Web开发中常常一起使用来实现增删改查(CRUD)操作。 增(Create)操作是指向数据库中插入新的数据。当用户提交表单时,PHP可以接收到表单的数据并将其插入数据库中,然后通过Ajax向服务器发送请求,更新页面上的数据,以显示新的数据。 删(Delete)操作是指从数据库中删除数据。当用户点击删除按钮时,Ajax会向服务器发送请求,并通过PHP来删除数据库中的数据,然后通过Ajax更新页面上的数据,以实现删除效果。 改(Update)操作是指修改数据库中的数据。当用户编辑某个数据时,通过Ajax向服务器发送请求,PHP接收到请求后,会将修改的数据更新到数据库中,然后通过Ajax更新页面上的数据,以显示修改后的数据。 查(Read)操作是指从数据库中获取数据。当用户需要查看某个数据时,通过Ajax向服务器发送请求,PHP接收到请求后,会从数据库中获取对应的数据,并通过Ajax返回给前端,然后前端使用Ajax来更新页面上的数据,以显示查询结果。 综上所述,通过PHP和Ajax可以实现增删改查操作。当用户进行相关操作时,通过Ajax向服务器发送请求,PHP接收请求并处理数据库操作,然后通过Ajax更新页面上的数据,以达到实时更新和操作的效果。这种方式可以提升用户体验,减少刷新页面的次数,更加灵活和高效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值