当前位置:天才代写 > 其他代写 > 代写PHP网页HTML:基于PHP的待办事项

代写PHP网页HTML:基于PHP的待办事项

2017-12-18 08:00 星期一 所属: 其他代写 浏览:1183

 

 

 

          基于PHP的待办事项软件   

 

 

 

 

 

 

1 背景与需求 1

1.1 系统背景 1

1.2 需求分析 1

2 开发环境概述 2

2.1 环境及工具软件 2

2.2 涉及的主要相关技术 2

3 系统设计 3

3.1 功能模块划分 3

3.2 模块界面设计 3

3.3 数据结构/数据库设计 3

4 程序开发与实现 4

4.1 文件结构 4

4.2 核心模块代码 4

5 评价与总结 5


1 背景与需求

1.1 系统背景

背景:每一个有条理的人,一天起来的第一件事并不是看手机,而是详细的规划今天要做什么,什么事情今天必须完成,什么时间做什么事。作为大学生,我也时常规划着自己的未来,比如端午回去要看书(结果还是没看),以上说的这种时间安排、规划只是保存在大脑中,并没有详细的记录并保存下来,身处于互联网时代的我们,无论做什么都会毫不犹豫的想到网络。鉴于此,就想到做一个待办事项的小应用。

有了这个小应用,每天起床就可以用手机记录下今天需要完成的事情,是不是有点像RPG游戏里面玩家控制主人公完成一个个任务,当然在这个待办事项小应用中,你完成了任务并不会得到奖励,但是当你每天晚上躺在床上看到任务列表中的任务一个个完成后,心中油然而生一种充实的感觉。

有了这个待办事项小应用,你就不用担心每天的任务会遗忘了,做了这件事忘记了那件事。今日事今日毕,不禁想起小学时的一篇文章:明日复明日,明日何其多,我生待明日,万事成蹉跎。

市场上现有的待办事项应用软件:印象笔记,有道笔记,滴答清单,奇妙清单,高效TodoAny.DOOmniFocus等。

1.2 需求分析

本软件具有的功能:

1) 注册

2) 登录

3) 查看待办事项

4) 删除待办事项

5) 添加待办事项


2 开发环境概述

2.1 环境及工具软件

开发环境:

1) Windows 10 专业版64

2) CPUIntel i5 2.5GHz

3) 8GB内存

4) phpStudy 2016

5) PHP/5.4.45

6) Apache/2.4.23

7) PHP 扩展: mysqli

8) MySQL 5.5.53

 

开发工具:

1) Sublime Text 3 64bit

2) PhpStorm 2017

3) Google Chrome 55

4) Postman

 

 

 

2.2 涉及的主要相关技术

1) PHP 版本:5.4.45

2) PHP 扩展:mysqli

3) 数据库:MySQL,版本:5.5.53

4) jQuery 2.1.1

5) Vue.js

6) Element-UI

 


3 系统设计

3.1 功能模块划分

首页展示页(Landing Page):用于展示本软件的简单介绍和说明,并链接到登陆页面。

登陆:注册过的用户需要用注册时的账号和密码登陆,对登陆账号做了一个简单的验证,主要是账号是否为空,账号至少四个字符;对密码的验证是,不能为空。还有一个跳转到注册的按钮,方便用户没有账号时注册。

清单页面:展示了该用户的所有待办事项清单。

添加事项:用户向清单中添加一条记录。

删除事项:用户删除清单中的一条记录。

 

3.2 模块界面设计

图片7.png 

 1. 登陆

图片8.png 

2. 我的待办事项

 

 

 

3.3 数据结构/数据库设计

 

Users

字段名

类型

主键

说明

id

int

name

Char(6)

用户账号

password

Char(32)

用户密码

created_at

Timestamp

用户注册时间

 

1. Users表结构

 

 

 

Lists

字段名

类型

主键

说明

Id

Int

Uid

Int

关联用户的外键

Content

varchar(100)

内容

Created_at

timestamp

创建时间

 

2.lists表结构


4 程序开发与实现

4.1 文件结构

对整个系统项目的文件结构做一介绍(图也行)。

 

  

4.2 核心模块代码

// index.html

 

            TODOList

            

            简单的待办事项, 去体验

        

 

// Login.html

图片9.png 

  

    

    

      

ODO

    

    

  

    

    

    

    

      

    

    

  

    

      

      

      

      

             

      

    

    

  

var Main = {

     data() {

        var validateName = (rule, value, callback) => {

          if (value === '') {

             callback(new Error('请输入账号'));

          } else {

             if (value.length < 4) {

                callback(new Error('至少四个字符'));

              } else {

                callback();

              }

          }

        };

        var validatePass2 = (rule, value, callback) => {

              if (value === '') {

                callback(new Error('请输入密码'));

              } else {

                callback();

              }

        };

        return {

          ruleForm2: {

            name: '',

            checkPass: '',

          },

          rules2: {

             name: [

               { validator: validateName, trigger: 'blur' }

             ],

             checkPass: [

               { validator: validatePass2, trigger: 'blur' }

             ]

          }

        };

     },

     methods: {

      submitForm(formName) {

        this.$refs[formName].validate((valid) => {

          if (valid) {

            console.log("validate OK");

            window.location.href = "./mylist.html";

         } else {

             console.log('error submit!!');

             return false;

           }

        });

        },

        register() {

          window.location.href = '/odo/register.html';

        }

     }

   }

var Ctor = Vue.extend(Main);

new Ctor().$mount('#app');

 

// DB.php 工具类

class DB{

    private $host     ='localhost'; //数据库主机

    private $user     = 'root';  //数据库用户名

    private $pwd      = 'root';  //数据库用户名密码

    private $database = 'odo';    //数据库名

    private $charset  = 'utf8';  //数据库编码,GBK,UTF8,gb2312

    private $link;                //数据库连接标识;

    private $rows;                //查询获取的多行数组

    static $_instance;     //存储对象

    /**

     * 构造函数

     * 私有

     */

    private function __construct() {

        $this->link = @ mysqli_connect($this->host, $this->user, $this->pwd, $this->database) or $this->err();

        

        // mysqli_select_db($this->database) or $this->err();

        $this->query("SET NAMES '{$this->charset}'", $this->link);

        return $this->link;

    }

    /**

     * 防止被克隆

     *

     */

    private function __clone(){}

 

    public static function getInstance($pconnect = false){

        if(FALSE == (self::$_instance instanceof self)){

            self::$_instance = new self($pconnect);

        }

        return self::$_instance;

    }

    /**

     * 查询

     */

    public function query($sql, $link = '') {

        $this->result = mysqli_query($this->link, $sql) or $this->err($sql);

        return $this->result;

    }

    /**

     * 单行记录

     */

    public function getRow($sql, $type = MYSQL_ASSOC) {

        $result = $this->query($sql);

        return @ mysqli_fetch_array($result, $type);

    }

    /**

     * 多行记录

     */

    public function getRows($sql, $type = MYSQL_ASSOC) {

        $result = $this->query($sql);

        while ($row = @ mysqli_fetch_array($result, $type)) {

            $this->rows[] = $row;

        }

        return $this->rows;

    }

    /**

     * 错误信息输出

     */

    protected function err($sql = null) {

        //这里输出错误信息

        echo 'error: ' . $sql;

        exit();

    }

}

 

// register.php 注册

图片10.png 

require_once 'db.php';

$db = DB::getInstance();

$name = $_POST['name'];

$password = $_POST['password'];

$checkPass = $_POST['checkPass'];

 

if (strlen($name) < 4 || strlen($password) == 0 || $password != $checkPass) {

echo json_encode(['code'=>20001, 'message'=>'注册失败,参数错误']);

exit(0);

}

 

$sql = "select * from users where name='$name';";

$hasReg = $db->query($sql);

if (!empty($hasReg)) {

// 已经注册

echo json_encode(['code'=>20002, 'message'=>'注册失败,已经注册']);

} else {

// 未注册

$sql = "insert into users(name, password, created_at) values('$name', md5($password), now());";

$q_ret = $db->query($sql);

if ($q_ret) {

echo json_encode(['code'=>20000, 'message'=>'注册成功']);

exit();

}

}


5 评价与总结

通过对本系统的开发,掌握了Vue.jsElementUI的一些简单用法,Vue.js是国人开发的一个JavaScript框架,因为它的轻量化,双向数据绑定,简单迅速的在前端界火起来,正好趁此机会学习一下这个框架。关于这个待办事项的应用,能改进的地方还有很多,比如加入社交账号的登陆与分享,给每条记录设置优先级,添加显示时间等,其实就类似于Google的日历。

最后做个简单的期末总结吧,这学期课很多,每天在不同的课之间跳转,时间在不经意间就流逝了,IT技术日新月异,AlphaGo打败了柯洁,人工智能火了,但在这些前沿技术的背后,一定是那些最普通、最基本的技术了,比如容器技术新秀Docker只不过是新瓶装旧酒,却改变了现有的developbuildshiprun的技术。很多时候所谓的创新只不过是从12的创新,本质却没有突破。对于我们学生来说,需要透过现象看本质,不要浮于表面,脚踏实地。只有掌握了本质,才有可能取得从01的突破,那才是创新。

 

    关键字:

天才代写-代写联系方式