php同功能简化增改操作代码

  在做开发中经常会遇到一个功能的增删改查,如果每个方法都写一个方法,就会发现其中有很多重复代码,其中最多重复代码的就是“增改”了,在一次重构代码的时候我就在想能不能把这两个方法合并成一个呢,有了这种想法我马上就对这个想法付出实践;

  当时的想法是这样的能不能就用一个变量来判断这次操作是不是增加或者修改;

  顺着这思路下去我先定义了一个变量赋值为“add”,然后通过传输的id去查找是否有这条数据,如果有这个变量就修改成“updata”;

  $type = 'add';

  $content = M('demo')->fieid('title,text')->where('id = '.$data['id'])->find();
  if(is_array($content))
  {
    $type = 'updata';
  }

  然后就把这个变量放到模板中,加一个隐藏字段来存

  $this->assign('type', $type);

  <input type="hidden" name="type" value="{$type}">

  然后就拿这个字段来判断是否添加或修改,具体代码如下:

  php:

  public function content()
  {
    //获取从任何方式传输过来的id
    $data['id'] = I('request.id');

    //判断是不是post提交的数据,如果不是就显示页面
    if(!IS_POST)
    {
      //判断页面是添加还是修改
      $type = 'add';

      //id必须存在,我这边就简单验证下,以实际为准
      if($data['id'] == "" || preg_match('/\D/', $data['id']))
      {
        echo json_decode(['error', '非法操作!']);
        exit;
      }

      $content = M('demo')->fieid('title,text')->where('id = '.$data['id'])->find();
      if(is_array($content))
      {
        $type = 'updata';
      }

      $this->assign('content', $content);
      $this->assign('type', $type);
      $this->assign('id', $data['id']);
      $this->display();
      exit;//这里必须要停止运行,要不然就会有问题
     }

    $type = I('post.type');
    $data['title'] = I('post.title');
    $data['text'] = I('post.text');

    //判断是否是我们内设的内容
    if(!in_array($type, ['add','updata']))
    {
      echo json_decode(['error', '非法操作!']);
      exit;
    }

    //如果是添加操作
    if($type == 'add')
    {
      $data['addtime'] = time();

      if(M('demo')->add($data))
      {
        echo json_decode(['success', '添加成功!']);
        exit;
      }

      echo json_decode(['error', '添加失败!']);
      exit;
    }

    if(M('demo')->save($data))
    {
      echo json_decode(['success', '添加成功!']);
      exit;
    }

    echo json_decode(['error', '添加失败!']);
    exit;
  }

 

  html:

  

  <!DOCTYPE html>
  <html>
  <head>
    <title></title>
    <script type="text/javascript" src="__PUBLIC__/js/jquery-1.11.0.min.js"></script>
  </head>
  <body>
    <form>
      <input type="hidden" name="id" value="{$id}">
      <input type="hidden" name="type" value="{$type}">
      <input type="text" name="title" value="{$content['title']}">
      <textarea name="text">{$content['text']}</textarea>
      <input type="button" class="send" name="send" value="保存">
    </form>
    <script type="text/javascript">
      $('.send').on('click',function(){
        $.ajax({
          url:'/content/content',
          type:"post",
          dataType:"json",
          data:$("form").serialize(),
          timeout:30000,
          success:function(result){
            alert(result[1]);
          }
        });
      })
    </script>
</body>
</html>

转载于:https://www.cnblogs.com/zhangzhaowen/p/11527839.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值