>백엔드 개발 >PHP 튜토리얼 >PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

黄舟
黄舟원래의
2017-03-24 09:19:081414검색

이 글에서는 간단한 프로세스 관리를 구체적으로 구현하기 위한 ajax와 PHP를 주로 소개하고 있으니 관심 있는 분들은 이 글에서

의 예시를 참고해 보세요. 참고로 ajax와 PHP로 간단한 프로세스 관리를 구현하는 방법을 공유해 드렸습니다. 구체적인 내용은 다음과 같습니다

우선 새로운 프로세스 페이지 xinjian.php가 있어야 합니다

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>新建</title>
<script src="../FENGZHUANG/jquery-3.1.1.min.js"></script>
</head>

<body>
<h1>新建流程</h1>

<p>
请选择节点人员:
<select id="user">
 <?php
 session_start();//需要将一些数据暂时存在session里
 include("../FENGZHUANG/DBDA.class.php");
 $db = new DBDA();
 
 $sql = "select * from users";
 $arr = $db->Query($sql);
 foreach($arr as $v)
 {
  echo "<option value=&#39;{$v[0]}&#39;>{$v[2]}</option>";
 }
 ?>
</select>
<input type="button" value="添加节点" id="add" />
</p>
<br />
<p>
 <?php
 if(!empty($_SESSION["user"]))
 {
  $attr = $_SESSION["user"];
  foreach($attr as $k=>$v) //索引为$k,取值为$v
  {
   $sname = "select name from users where uid=&#39;{$v}&#39;"; //取出名称
   $name = $db->StrQuery($sname);
   echo "<p>{$k}--{$name}--<input type=&#39;button&#39; value=&#39;删除&#39; key=&#39;{$k}&#39; class=&#39;del&#39; /></p>"; 
   //向处理页面传的是key的值
  }
 }
 ?>
</p>
<br />
<p>请输入流程名称:<input type="text" id="name" /></p>
<br />
<input type="button" value="保存" id="btn" />


</body>
<script type="text/javascript">
//添加节点按钮加点击
$("#add").click(function(){
  var uid = $("#user").val();
  $.ajax({
   url:"chuli.php",
   data:{uid:uid,type:0}, //传入一个type参数,以确保在同一页面处理时与其它的分开处理
   type:"POST",
   dataType:"TEXT",
   success: function(data){
     window.location.href="xinjian.php" rel="external nofollow" rel="external nofollow" ; //刷新页面
    }
   });
 })
 
//给删除按钮加点击
$(".del").click(function(){
  var key = $(this).attr("key"); //取删除的是哪条数据
  $.ajax({
   url:"chuli.php",
   data:{key:key,type:1},
   type:"POST",
   dataType:"TEXT",
   success:function(data){
    window.location.href="xinjian.php" rel="external nofollow" rel="external nofollow" ;
    }
   });
 })
//给保存按钮加点击
$("#btn").click(function(){
  var name = $("#name").val(); //取输入框中输入内容的值
  $.ajax({
   url:"chuli.php",
   data:{name:name,type:2},
   type:"POST",
   dataType:"TEXT",
   success:function(data){
     alert("保存成功!");
    }
   });
 })
</script>
</html>

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

데이터베이스 이미지:

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

처리 페이지 chuli.php

<?php
session_start();
include("../FENGZHUANG/DBDA.class.php");
$db = new DBDA();

$type = $_POST["type"];

switch($type)
{
 case 0://添加节点的加载数据,向session数组中添加数据
  $uid = $_POST["uid"];
  if(empty($_SESSION["user"]))
  {
   $arr = array($uid);
   $_SESSION["user"] = $arr;
  }
  else
  {
   $arr = $_SESSION["user"];
   array_push($arr,$uid);
   $_SESSION["user"] = $arr;
  }
  break;
  
 case 1://取节点的索引,然后删除,重新索引
  $key = $_POST["key"];
  $arr = $_SESSION["user"];
  unset($arr[$key]); //删除
  $arr = array_values($arr); //重新索引
  $_SESSION["user"] = $arr;
  break;
  
 case 2:
  $name = $_POST["name"];
  $code = time();
  //添加流程
  $sql = "insert into liucheng values(&#39;{$code}&#39;,&#39;{$name}&#39;)";
  $db->Query($sql,0);
  //添加流程节点
  $arr = $_SESSION["user"];
  foreach($arr as $k=>$v)
  {
   $sql = "insert into flowpath values(&#39;&#39;,&#39;{$code}&#39;,&#39;{$v}&#39;,&#39;{$k}&#39;)";
   $db->Query($sql,0);
  }
  break;
  
 case 3: //用户发起流程
  $code = $_POST["code"];
  $nr = $_POST["content"];
  $uid = $_SESSION["uid"];
  $time = date("Y-m-d H:i:s");
  $sql = "insert into userflow values(&#39;&#39;,&#39;{$code}&#39;,&#39;{$uid}&#39;,&#39;{$nr}&#39;,0,&#39;{$time}&#39;,0)";
  $db->Query($sql,0);
  break;
  
}

처리 시작 페이지 faqi.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>发起流程</title><br />
<script src="../FENGZHUANG/jquery-3.1.1.min.js"></script>

</head>

<body>

<h1>发起流程</h1>

<p>
请选择发起的流程:
 <select id="liucheng">
  <?php
  session_start();
  include("../FENGZHUANG/DBDA.class.php");
  $db = new DBDA();
  $sql = "select * from liucheng";
  $arr = $db->Query($sql);
  foreach($arr as $v)
  {
   echo "<option value=&#39;{$v[0]}&#39;>{$v[1]}</option>";
  }
  ?>
 </select>
</p>
<br />
<p>
请输入内容:
 <textarea id="nr"></textarea>
</p>
<br />
<input type="button" value="发起" id="btn" />


</body>
<script type="text/javascript">
$("#btn").click(function(){
  var code = $("#liucheng").val();
  var content = $("#nr").val();
  
  $.ajax({
   url:"chuli.php",
   data:{code:code,content:content,type:3},
   type:"POST",
   dataType:"TEXT",
   success: function(data){
    alert("发起成功!");
    }   
   });
 })
</script>
</html>

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

감사페이지 shenhe.php


아아앙

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)

tongguo.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>审核</title>
</head>

<body>
<h1>审核页面</h1>
<table width="100%" border="1" cellpadding="0" cellspacing="0">
 <tr>
  <td>流程代号</td>
  <td>发起者</td>
  <td>发起内容</td>
  <td>是否结束</td>
  <td>发起时间</td>
  <td>操作</td> 
 </tr>

 <?php
 session_start();
 include("../FENGZHUANG/DBDA.class.php");
 $db = new DBDA();
 $uid = $_SESSION["uid"];
 echo $uid;
 //查找登录者参与的所有流程
 $sql = "select * from userflow where code in(select code from flowpath where uids=&#39;{$uid}&#39;)";
 $arr = $db->Query($sql);
 
 //显示
 foreach($arr as $v)
 {
  //判断该流程走到登录者
  $lcdh = $v[1]; //流程代号
  $towhere = $v[6];//流程走到哪
  $sql = "select orders from flowpath where code=&#39;{$lcdh}&#39; and uids=&#39;{$uid}&#39;";
  $order = $db->StrQuery($sql);//该人员在流程中的次序
  
  if($towhere>=$order)
  {
   $caozuo = "";
   if($towhere==$order)
   {
    $caozuo="<a href=&#39;tongguo.php?code={$v[0]}&#39;>通过</a>";
   }
   else
   {
    $caozuo="<span style=&#39;background-color:green;color:white&#39;>已通过</span>";
   }
   echo "<tr>
  <td>{$v[1]}</td>
  <td>{$v[2]}</td>
  <td>{$v[3]}</td>
  <td>{$v[4]}</td>
  <td>{$v[5]}</td>
  <td>{$caozuo}</td> 
 </tr>";
  }
  
 }
 ?>
</table>
</body>
</html>

위 내용은 PHP와 Ajax를 활용한 간단한 프로세스 관리에 대한 자세한 설명(그림 및 텍스트)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.