渐进式迭代教学法--PHP

  目前常见的课程体系大致情况如下:

  阶段1:前端基础(html+css+js)

  阶段2:PHP&MySQL基础 + 框架 (PHP基本语法,面向对象,mvc,sql基础,TP项目)

  阶段3:前端高级(JS语法,JS语言特性,ajax,JQ,Node,Vue )

  阶段4:微信

  阶段5:服务器部分 (linux基础,Git,Nginx,NoSQL,优化及高可用集群,Laravel项目)

  阶段6:扩展 (React,Docker,Swoole,爬虫)

  这样的课程体系,最大的弊端就是课程关联性太弱,同时课程的切入点不合适,让人有一种盲人摸象的感觉;

  首先明确,我们的课程是专业的 web 应用编程课,以 PHP 这门编程语言为核心。

  PHP 开发的最大特点就是 入门容易开发快,这也是PHP流行和得到广泛应用最重要的原因之一;

  但是,入门容易和开发快是有前提的:

  网络通信是做web应用开发的基石,所以,TCP/IP 必须知道,HTTP必须精通,一切都是基于请求和响应的;

  PHP在整个web应用中最重要的就是逻辑处理,因此前台页面展示交由HTML,后台的数据持久化交由mysql;网路服务器交由Nginx或者Apache;

  所以,想要使用PHP完成一个完整且健壮的 web 应用,关键在于客户端发来了什么请求,服务器端如何处理并响应,这一点不明白,PHP语法学的在精通也是无济于事;

  而上面的课程就存在这样的问题,前端基础学完就会直接进入到语言学习部分,根本没有说明我学的PHP到底用在web应用的那个环节,起到怎样的作用,为什么要学PHP 等问题;

  而渐进式迭代教学法就是为了解决这个问题的,他是一个课程体系的设计逻辑;

  下面使用 渐进式迭代教学法 对上面的课程做修改,并进行说明:

  阶段1:前端基础 (html+css+js)

  说明:进入编程世界,使用HTML和CSS制作简单的静态页面,配合JS做出一定的动态效果,提升成就感;

  阶段2:编程语言入门及网络通信原理 (JS语言特性 + ajax + jq + Node + SQL基础 )

  说明:使学生入门编程的第一语言由原来的 PHP 改为 JS ,因为在Node中,我们可以进行相对原始的网络编程

  自己实现 HTTP 服务器的编写,实现HTTP客户端的编写,在这个过程中 深刻感受请求及响应的整个HTTP过程;

  利用这个节点,就能将网络通信的原理讲解清楚;

  同时,在编程中出现的名词也会更多的涉及,如:事件绑定及事件轮询的原理,异步与同步的原理,阻塞与非阻塞,回调等;

  还会涉及到基本的语言语法,解析引擎及编译原理等;

  这个阶段结束,学生就会有能力完成一个具备基本增删改查的web应用,且对整个web应用的环节无疑问;

  而更重要的就是在这个过程中会形成web应用编程的基本逻辑和编程思维的建立;

  后面课程中的几乎所有内容,都已客户端请求与响应为基本逻辑,也同时都有了讲解理由和依据;

  如:客户端提交到服务器的数据需要永久保存 --> MySQL基础讲解;

  掌握网络通信基本原理,建立基本的web编程世界观!!!

  至此,第2轮迭代结束;

  阶段3:WAMP 环境下的Web应用编程 (apache + PHP基本语法 + 面向对象 + mvc + TP5项目)

  说明:在上一阶段涉及到的网络通信中,需要自己写HTTP服务器端代码,需要自己接受并判断请求,需要自己写网络响应数据,而这些都可以交给现成的服务器来做,而且做得更好;

  因此我就不在需要考虑服务器的问题,重心就可以转移到具体的业务逻辑中,而PHP就是擅长业务逻辑处理的编程语言,学起来容易,开发起来也快,这就是它最大的优势;

  而如果面对普通中大型项目,我们则需要使用MVC进行分工协作,而成熟的MVC框架,就国内来说非TP莫属;

  最后使用TP加之前的html,CSS ,ajax与jq 完成一个完整的项目;

  这一段的重要性就是对第二阶段的迭代替换,使用 Apache 替换Node-http-server,使用PHP替换 JS 进行网络请求后的逻辑处理,使整个wamp环境的出现变得顺理成章;

  这个阶段开始,才真正进入到以PHP为核心的 web 应用编程,也在这一阶段凸显出PHP的优势和学习PHP的理由;

  至此,进入PHP世界,明白PHP在整个Web应用中的重要性和优势所在,带着目标和期许进入学习周期;

  同时,也能感受到编程语言仅仅是解决问题的工具,而PHP是哪个用起来最得心应手的……

  本阶段结束,能够通过对 js和PHP 两种编程语言的学习,更深的体会编译原理和解析引擎的工作原理,对编程工程化有初步了解,对面向对象、框架的使用、数据类型等都有立体感受;

  最后通过 TP 框架的项目串联整个第2和第3阶段的重要知识点;

  阶段4:LAMP 环境下的WEB应用编程 (linux基础,lamp环境的搭建,缓存及NoSQL工具,sql优化及高可用集群,Docker虚拟化,WEB安全攻防基础)

  说明:第三阶段中,仅学会PHP语法结构和框架,是不足以构建一个完整的web应用程序的,想要使PHP能够承受成千上万的大并发请求压力,并且能够抵御一般的黑客攻击,使用WAMP环境是很难以支撑和实现的;

  在此阶段则引入Linux及各种工具,以配合PHP完成整个web应用的架构;由 阶段2和阶段3 的单服务器架构引入linux下的多服务器集群架构;

  依然以整个HTTP请求与响应为基本逻辑,提出在请求及响应过程中的各种问题引出集群缓存等技术的必要性;

  此阶段结束,可以具备搭建大型WEB应用的能力,掌握web开发的各个环节,具备web开发的宏观意识;

  阶段5:项目工程化(Git , Vue ,Laravel, 前后端分离项目)

  说明:之前的阶段全部为单人开发,对于大型项目是不现实的,由此引入Git+Vue+Laravel技术,使用代码管理工具,前后端分离,前端及后端使用各自的工程化体系设计,由单人开发进入多人分工合作开发;

  将班级分为每3-5人组成的小组,合作开发项目并上线运行;

  配合前四个阶段的内容,做一个上线并运行的项目并不难;

  阶段6:应用技术 (微信 爬虫 swoole等)

  说明:以PHP为中心,进行相关技术扩展;不再过多解释;

  总结:

  我创造的这套 渐进式迭代教学法,其根本就是 由浅入深、由原理入实战的教学方法,使整个课程前后连贯且有因果,不再产生类似盲人摸象的无助感,每一个阶段的目的和目标都是明确的,上一阶段辅助下一阶段,下一阶段承接上一阶段;每个阶段都会用到上一阶段的关键知识点,而每个阶段都会将上一阶段的知识迭代升级,在这个迭代的过程中,不断复习同时又会不断深入;

  这也是起名为 渐进式迭代教学法 的原因;

  同时,这样的课程设计也在一定程度上缓解了大部分人 学完就忘 的现象,这是一个不断迭代的过程,会及时复习;

  而在这样的课程体系中,即使某些细节的知识点忘记了,也没关系,比如在第4阶段很可能就会忘记第2阶段中具体NodeJS中的语法,而此时具体语法已经不重要了,只要能在你脑海中留下关于使用NodeJS搭建HTTP服务器的原理知识就可以了;第二阶段出现的目的就是打通整个网络通信原理,不管以后是否还能使用NodeJS写一个HTTP服务器,这都已经不重要了,因为已经有了Nginx等技术做支撑;

  当然,这个教学法有个最大的 Bug , 就是对老师要求比较高,每个阶段的老师都必须明确自己所授课阶段的目的性,同时还必须要具备承前启后的技术能力,这一点尤为重要,所以备课压力会相当大,每个老师的备课底线就是两个阶段;

渐进式迭代教学法--PHP的更多相关文章

  1. <<google软件测试之道>>读书笔记

    以前一直从开发的角度来看待测试,看完这本书以后感觉错了,难怪之前公司的测试一直搭建不起来 1.开发人员,开发测试人员,测试人员 * 开发人员负责开发 * 开发测试人员近距离接触代码,负责编写测试用例, ...

  2. Twitter Lite以及大规模的高性能React渐进式网络应用

    Twitter Lite以及大规模的高性能React渐进式网络应用 原文:Twitter Lite and High Performance React Progressive Web Apps at ...

  3. 渐进式web应用开发-- 使用后台同步保证离线功能(六)

    _ 阅读目录 一:什么是后台同步保证离线功能呢? 二:后台同步是如何实现的呢? 三:如何给sync事件传递数据? 四:在我们的项目中添加后台同步功能 回到顶部 一:什么是后台同步保证离线功能呢? 在我 ...

  4. DevOps - 从渐进式交付说起(含实践 Demo)

    作者:CODING - 王炜 1. 开篇 如果让你主导一款千万.甚至亿级用户产品的功能迭代,你会怎么做?你需要面对的挑战可能来自于: 商业战略的变化带来新的产品诉求,而产品的任何改动哪怕仅是界面调整, ...

  5. 使用 Flux+Flagger+Istio+Kubernetes 实战 GitOps 云原生渐进式(金丝雀)交付

    在这篇指南中,你将获得使用 Kubernetes 和 Istio 使用 GitOps 进行渐进式交付(Progressive Delivery)的实际经验. 介绍 gitops-istio GitOp ...

  6. javascript中的Array对象 —— 数组的合并、转换、迭代、排序、堆栈

    Array 是javascript中经常用到的数据类型.javascript 的数组其他语言中数组的最大的区别是其每个数组项都可以保存任何类型的数据.本文主要讨论javascript中数组的声明.转换 ...

  7. IteratorPattern(迭代子模式)

    /** * 迭代子模式 * @author TMAC-J * 聚合:某一类对象的集合 * 迭代:行为方式,用来处理聚合 * 是一种行为模式,用于将聚合本身和操作聚合的行为分离 * Java中的COLL ...

  8. JavaScript高级程序设计--对象,数组(栈方法,队列方法,重排序方法,迭代方法)

    1.使用对象字面量定义对象 var person={}; 使用这种方式创建对象时,实际上不会调用Object构造函数. 开发人员更喜欢对象字面量的语法.   2.有时候需要传递大量可选参数的情形时,一 ...

  9. python征程3.1(列表,迭代,函数,dic,set,的简单应用)

    1.列表的切片. 1.对list进行切片.'''name=["wangshuai","wangchuan","wangjingliang", ...

随机推荐

  1. Linux-read 命令(20)

    Linux read 命令 参数说明: -a 后跟一个变量,该变量会被认为是个数组,然后给其赋值,默认是以空格为分割符. -d 后面跟一个标志符,其实只有其后的第一个字符有用,作为结束的标志. -p ...

  2. js 幻灯片

    基本思路 红色:为可见区域 黑色方框:元素,不可见. 通过绝对定位方式,把黑色方框,移动到红色可见区别,来实现图片切换.  实例 创建幻灯实例对象 <div class="slide& ...

  3. angular select 默认值

    <select ng-model="selected" ng-options="x.id as x.name for x in users">< ...

  4. js获取对象的长度

    var obj= { "name": "wuqian", "sex": "famale", "hello&qu ...

  5. BZOJ4407: 于神之怒加强版(莫比乌斯反演 线性筛)

    Description 给下N,M,K.求 感觉好迷茫啊,很多变换看的一脸懵逼却又不知道去哪里学.一道题做一上午也是没谁了,, 首先按照套路反演化到最后应该是这个式子 $$ans = \sum_{d ...

  6. Phaser.js之简单的跑酷游戏

    采用的物理引擎是Phaser.js 官网地址:http://phaser.io/ 在这里对此引擎不做过多介绍(因为我也是小白,嘿嘿) 效果展示: 源码(详细源码图片资源可点击文章下方或屏幕右上方的gi ...

  7. Activiti实现流程自由跳转

    import org.activiti.engine.ProcessEngine; import org.activiti.engine.TaskService; import org.activit ...

  8. 使用Nginx实现服务器反向代理和负载均衡

    前言 同事总问我Nginx做反向代理负载均衡的问题,因此特意留下一篇扫盲贴! 直接部署服务器的风险 假设,我开发了一个网站,然后买了一台Web服务器和一台数据库服务器,直接部署到公共网络上.如下图,网 ...

  9. leetcode-83.删除排序链表中的重复元素

    leetcode-83.删除排序链表中的重复元素 Points 链表 题意 给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次. 示例 1: 输入: 1->1->2 输出: 1- ...

  10. mysql 获取一张表中, 另一张表不存在的数据

    编写sql语句中,经常需要编写获取一张数据表中不存在与另一张表的数据,相关编写方法如下: 方法1: 使用not in ,效率低下,在数据较小的情况下可以采用如下编写 SELECT * FROM a A ...