zoukankan      html  css  js  c++  java
  • 我设计的工作流

    参考了网上的一些东西,以前做的一些东西,然后加上了自己的一些想法,便有了下面的东西。

    第一步:

    流程配置表:这里用xml表示,有人会用if ... else ...,switch... case,表示,但是状态少了还可以,要是一堆的状态,可读性会大大降低,所以我用xml表示,直观,

    可读性强。

    xml如下:

    <state name="领料审核" value="LLSH">

           <first_step name="组长审核' value="ZZSH">

              <pass name="审核通过" value="PASS"/>

               <pass name="审核不通过" value="NOPASS"/>

                <is_end name="是否结束" value="NOEND"/>

            </first_step>

     <second_step name="主任审核' value="ZRSH">

               <pass name="审核通过" value="PASS"/>

               <pass name="审核不通过" value="NOPASS"/>

               <is_end name="是否结束" value="END"/>

            </second_step>

    </state>

    第二步:

    数据库设计:

    column          filed

    state_name    char(10)

    step_name      char(10)

    pass_result      char(10)

    next_step       char(10)

    user_id          tinyint

    第三步:

    程序实现

    首先读取数据审核表,如果记录数为0,则从xml文件开始读取第一步的审核种类,然后用户开始审批,最后记录。如果记录数不为0,则取相应审核种类的最大记录。

    不管是审核通过,还是不通过,都必须增加一条新的记录,不能更新原先的记录,以保证出现问题时,有剧可查。当开始第二步审核时,如果xml利用数据库中记录的

    next_step先去获取上一步状态,如果没有上一步,则获取第一步的状态,看是否,以被结束,如没有则允许审核。

    xml读取的数据应该用链表做记录:

     current 当前状态,next 下一步的状态 back 上一步的状态

     这只是一个最简单的实现,没有涉及到权限判断

  • 相关阅读:
    部分页面开启宽屏模式
    门户diy实现翻页功能的方法
    git命令详解,从入门到装逼
    array方法常用记载
    vue 生命周期的理解(created && mouted的区别)
    微信小程序传值的几种方式
    data-*
    本地存储和会话存储以及cookie的处理
    vue的安装和项目构建
    进击的UI----------动画
  • 原文地址:https://www.cnblogs.com/chenleinet/p/1686631.html
Copyright © 2011-2022 走看看