黄永成-thinkphp讲解-个人博客讲解25集

时间:2023-12-24 13:11:43

整个网站的根目录用blog你要跟别人说起,自己好识别的文件夹名字.

下面的项目名称 就不再重复的写了, 直接用App就好了.

网站访问: ...../index.php(入口文件)/Admin(模块名称)/[[Index控制器名称]/index(方法名称)]

一般在后台中, 除了Index控制器显示首页(登陆进去后的页面管理和显示)外, 还有有一个LoginAction的控制器.

!! 一个控制器就是一个class.php文件, 里面有很多相关的方法

!! 导入外部的 模板: 只要在模块下,先创建Tpl目录, 然后将模板(包括css样式表, js脚本, index.html, login.html等等页面)全部放到 Tpl中就好了!

为了方便管理/清晰, 可以将除了 html页面的其他内容都放在Public文件夹中.

而html文件则要 按控制器的名称, 分别创建文件夹, 把对应控制器的模板html文件放在对应的文件夹中.

如: 控制器Login.class.php对应的html模板文件就放在 Login的文件夹下.

系统默认的PUBLIC 常量是指向: 网站根目录下的Public文件夹.

黄永成 习惯的是: 系统默认的PUBLIC用来存放 前台的Public模板文件夹内容(主要是指css,js)

后台的Public文件夹就放后台的模板的 css js等内容.

-------------------------- ==

在开发的时候, 要习惯于查看浏览器 给出的 页面的源代码, 因为, 通过浏览器 的源代码, 可以查看 / 排错!

可以查看: tp翻译/转换 后的 js, css的源地址和代码执行情况等等. 如: 通过查看源代码, 可以看到 从服务器端返回给浏览器的 "变量替换后的路径/内容"等等, 从而可以排错!

同时浏览器查看 源代码比很多 编辑器更好看.

有的页面布局, 完全用div.

其实有时候, 也不要完全抛弃 table! 在页面布局中, 要结合table和div!!! 有时要轻松得多!

因为在 td中, 你完全可以任意的使用 div! 一个td中可以包含 很多内容的 div1, div2....

-------------------------- ==

不能只是重视style css的应用, 也要重视/ 注意 html标签元素的 属性的应用, 有时 使用标签元素的 属性 比使用style来控制 更简单 更直接 有效!

注释:

不只是脚本文件中需要注释, 同样要习惯于: 在写html的时候, 也要适当的使用注释: 常用的格式是:

---------------------------==

定义全局或 模块下的__PUBLIC__, _ JS _等常量

在ThinkPHP中config文件中进行一下配置即可。

//重定义网站的一些URL地址
/* 模板相关配置 */
'TMPL_PARSE_STRING' => array(
'__PUBLIC__' => __ROOT__ . '/Public',
'__JS__' => __ROOT__ . '/Public/Js',
'__CSS__' => __ROOT__ . '/Public/Css',
'__IMAGE__' => __ROOT__ . '/Public/Image',
'__DATA__' => __ROOT__ . '/Data/'
), 在ThinkPHP3.2中其中__ROOT__ 默认找到项目的根路径,利用这种方式即可定义网站后台各级文件夹的路径,便于更好的查找相关文件 在ThinkPHP的模板中使用已定义的路径,可以使用C方法 C('TMPL_PARSE_STRING.PUBLIC') // 注意调用配置文件中的TMPL_PARSE_STRING的时候, 就不用下划线__PUBLIC__, 直接是PUBLIC了

在thinkphp的Conf中的convention.php中没有TMPL_PARSE_STRING, 要靠自己在模块的Conf中设置: 如: Modules/Admin/Conf/config.php 文件中设置... TMPL_PARSE_STRING是包含多个常量字符串设置的 数组!

设置中的 分组名, 最好用GROUP_NAME 表示. 这样在修改分组名称的时候, 就只是修改入口文件index.php, 而不用修改其他配置了, 如这里的 TMPL_PARSE_STRING.

在项目配置文件中, 设置分组时:

对APP的配置都是以APP_开头的;

只有DEFAULT_GROUP不是以APP开头的.

------------------------- ==

就像linux下, 只用vim编辑文档一样, windows下只用editplus编辑文档, 熟悉并记住这些键盘bind keys有意义的事!

记住, 从text editor跟侧边栏之间的转换: alt+F5, shift+F5是转到输出窗口. 然后再记住alt+F6是打开硬盘上的文件/文件夹列表

------------------------ ==

有两个xx+alt+up/down:

ctrl+alt+up/down: 复制当前行;

shift+alt+up/down : 上/下移动当前行

------------------------ ==

使用外部css表的方式: (外部链接的方式) 和img src的区别?

  1. 标签是link, 不是style
  2. 指定源地址是: href, 不是src
  3. 总之, 你理解为: css是外部" 链接", "链接" 那么就是: link, 如同超链接a一样, 地址是用 href属性来指明的.

    即: link type="text/css" rel="stylesheet" href="xxx" />

使用外部链接样式表的好处是:

  1. 减少html文件的大小, 搜索引擎搜录得更快
  2. 可以使用多线程来下载html和css文件, 这样显示渲染速度更快
  3. 便于html和css人员的分别修改处理: 内容和样式的分离

------------------------- ==

注意在定义类class的时候, 继承 的单词是 extends, 不是extended!

黄永成-thinkphp讲解-个人博客讲解25集

独立分组好后, 可以把App下的一些不要的文件夹如tpl等可以删除.

??好像: editplus(epp)的配置文件, 只认一个, 即使你安装了多个版本的epp, 那么最后你使用的配置 , 总是最后一次安装时的, 这是通常为空白的默认的安装配置

在epp中, 匹配有两种: 一是匹配括号(,[ {, 一是匹配 标签

匹配括号的bind key is: Ctrl+], select bracket is: ctrl+shift+]

匹配标签的,html标签,如 body> , 则是: ctrl+[, 选择标签内容是: ctrl+shift+[

epp的匹配,不像 zend, 是自动显示/高亮括号, 它是要匹配操作后才显示的.

可以配置一次性删除: 所有的空白行: ctrl+shift+B(bind key)...

--------------------------- ==

查看页面的源代码:

在页面的地址前面加上: view-source: + http://.....

**而且可以刷新!

view-source:http://localhost/blog/index.php/Admin/Login/index

--------------------------==

写TMPL_PARSE_STRIGN时:

  1. 位置 : 是写在App/Modules/分组名称如Admin/ Conf/ config.php中, 不是写在Admin下...
  2. 解析__PUBLIC__的时候, 最好用全局常量, 不要写死, 因为如果后面要修改的话, 就不好修改: 不要写MODULE_NAME, 它会把所有的东西都看成是模块, 不管

    是App, Modules, 还是Admin, 还是Action, 所以要写具体的: 应用程序的名称用APP_Name, 分组的名称用 Group_NAME...

.

---------------------- -------- ==

导入库:

查看thinkphp的官方文档

  1. import是一个方法, 格式是:import('类库文件名', '起始路径', '类库后缀');

    '类库文件名'中的点号表示的是路径"", 所以类库名本身不能带有点号

  2. 可以基于框架导入, 这时候, 就不用写第二个和第三个参数, 即不写起始路径, 和类库后缀, 因为框架会自动判断/认为类库的起始路径, 也会自动认为类库的后缀为

    class.php

  3. 基于框架的导入有三种:

    导入基类库(基础类库): 是指导入 Thinkphp/Lib 目录下的类库: import('Think.Util.Array'): Note that: 是导入lib目录下的, 不是lib/core下的; and: 是

    以Think开头的...

    导入扩展类库: 是指导入Thinkphp/Extend/Library目录下的类库: import('ORG.Util.Image'): 导入的是: THinkphp/Extend/Library/ ORG/Util/Image.class.php 类库文件

    导入项目应用程序库: import('MyApp.Action.UserAction')...

如果没有指定起始导入路径的话,类库包Think、ORG、Com之外的都会被认为是导入项目应用类库,例如:

    import("MyApp.Action.UserAction");
import("MyApp.Model.InfoModel"); 表示导入MyApp项目的UserAction和InfoModel类库文件,由于通常,我们都是导入当前项目下面的类库,所以可以简写成: import("@.Action.UserAction");
import("@.Model.InfoModel");
  1. 导入非标准类库文件

    这时, import的第二个参数和第三个参数就不能省略了:

    这里所说的非标准类库文件,主要是指位于特殊位置(不是上面三种位置)或者非.class.php后缀(如是.php后缀)的类库文件。

    像导入基类库、扩展类库和项目类库都是基于框架规范的目录下面,如果我们需要导入项目的Common目录下面的MyClass.php文件,则可以采用:

    import('Common.MyClass',APP_PATH,'.php');

    或者

    import('MyClass',APP_PATH.'Common','.php');

  2. 导入第三方库:

    可以用import方法, 但是用Vendor()方法更方便, 把自己写的第三方类库放在Thinkphp/Extend/Vendor下,就可以直接用 Vendor方法导入:

    Vendor('Zend.....');

  3. 支持别名导入:

    除了命名空间的导入方式外,import方法还可以支持别名导入,要使用别名导入,首先要定义别名,

    我们可以在项目配置目录下面增加alias.php 用以定义项目中需要用到的类库别名,例如:

    return array(

    'rbac' =>LIB_PATH.'Common/Rbac.class.php',

    'page' =>LIB_PATH.'Common/Page.class.php',

    );

--------------------------------- ==

生成验证码的时候, 提示, Image::buildImageVerify()方法无法call ImageCreate()方法?

要开启 php.ini中的 extension=php_gd2.dll

好像还不能用APP_PATh来代替配置文件中的__ROOT__.'/'.APP_NAME! 因为APP_PATh输出的是./App/, 结果替换后, 就成了当前目录下的... MODULE_NAME是指控制器的名字!

thinkphp中的方法函数import(), 就是由tp框架定义的 thinkphp/Common/目录中的 common.php文件中定义的!

我们甚至可以 在这个系统文件中 common.php中来echo 等等debug, 或显示某些变量!