采用php+smary来模拟dedecms后台—>"更新所有文档”的功能。特别说明,因为是在本机测试,只是为了能看到实现的功能,所以写得很简单。
第一步:下载和安装smarty
(1)我的网址根目录:localhost/php/
(2)php根目录下有:
libs目录——smarty库文件;
tpls目录——用于放置smarty的cache目录、configs目录、templates目录、templates_c目录;
article目录—— 呆会生成的静态文件,都放在这里
index.php文件——php程序代码,呆会访问该页面时,即自动批量生成静态文件
第二步:index.php代码
一切从简,这里从数据库 dede_archives表中,只读取是 id 和 title 两个字段的内容。
header("content-type:text/html;charset=utf-8");
/**
* smarty 配置
**/
include("./libs/Smarty.class.php");
$smarty = new Smarty();
$smarty->setTemplateDir('./tpls/templates/');
$smarty->setCompileDir('./tpls/templates_c/');
$smarty->setConfigDir('./tpls/configs/');
$smarty->setCacheDir('./tpls/cache');
/**
* 从数据库中读取内容
**/
$art = array();
$mysqli = new mysqli("localhost","root","123456","dedecmsv57gbksp1");
if($mysqli->error){
die("数据库连接失败:". $mysqli->error);
}
$mysqli->query('set names utf8');
$query = "select id,title from dede_archives limit 0,3";//简单测试,所以只读取了3篇文章
$res = $mysqli->query($query);
while($row = $res->fetch_assoc()){
$art[] = $row;
}
$mysqli->close();
/**
*循环生成静态文件
**/
for($i=0,$len=count($art);$i<$len;$i++){
$smarty->assign("id",$art[$i]['id']);
$smarty->assign("title",$art[$i]['title']);
$str = $smarty->fetch("view.html");//获得模板中smarty标签被替换后的内容
//生成静态文件
$fp = fopen("./article/views-".$art[$i]['id'].".html","w");
fwrite($fp, $str);
fclose($fp);
}
echo "生成静态文件成功";
?>
第三步:模板文件 ./tpls/templates/view.html
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<title>{$title}</title>
</head>
<body>
<p>文章id为:{$id}</p>
<h4>文章标题:{$title}</h4>
</body>
</html>
ok,完成,访问 index.php页面,即在 ./article/ 目录下自动生成静态文件。
本文链接
在这将近一年的开发里,发现自己每次都会重复做很多事,如CURD,如各种控件的调用,每次都要复制代码,很麻烦而且容易搞错,后台一个同事把一些基本的代码写成模版进行自动生成,这时才如梦初醒。
作为一个程序员,应该思考用神马方法去解放自己的双手和眼睛。如果永远只会敲代码,那永远不能体会code的真谛,让程序完成我们要做的是,我们也包括我们程序员。个人观点~嘿嘿,闲话就说这些。希望有兴趣的大哥能给点意见。(是在Thinkphp框架的基础上)
第一步:生成后台
1.生成thinkphp所需的文件夹。
2.生成登入页面及权限控制(1.直接修改核心的Action。2建立一个SuperAction类来继承Action然后别的类都继承自SuperAction)
3.导入数据库文件到数据库
4.列出所有表(根据目录区别出已经生成了多少个表)
5.生成表配置(a.需要显示的字段,b.字段调用什么样的控件(例如:上传文件,编辑器等))
6.然后生成后台
暂时想到的就这些了 希望大侠们能给我这个菜鸟意见 ,各种求=。=
本文链接
单例模式
所谓单例模式,也就是在任何时候,应用程序中只会有这个类的一个实例存在。常见的,我们用到单例模式只让一个对象去访问数据库,从而防止打开多个数据库连接。要实现一个单例类应包括以下几点:
- 和普通类不同,单例类不能被直接实例化,只能是由自身实例化。因此,要获得这样的限制效果,构造函数必须标记为private。
- 要让单例类不被直接实例化而能起到作用,就必须为其提供这样的一个实例。因此,就必须要让单例类拥有一个能保存类的实例的私有静态成员变量和对应的一个能访问到实例的公共静态方法。
- 在PHP中,为防止对单例类对象的克隆来打破单例类的上述实现形式,通常还为基提供一个空的私有__clone()方法。
下面是一个基本的单例模式:
private static $instance;
// other vars..
private function __construct() {
// do construct..
}
private function __clone() {}
public static function getInstance() {
if (!(self::$instance instanceof self)) {
self::$instance = new self();
}
return self::$instance;
}
// other functions..
}
$a = SingetonBasic::getInstance();
$b = SingetonBasic::getInstance();
var_dump($a === $b);
工厂模式
工厂模式在于可以根据输入参数或者应用程序配置的不同来创建一种专门用来实现化并返回其它类的实例的类。下面是一个最基本的工厂模式:
public static function create($config) {
}
}
比如这里是一个描述形状对象的工厂,它希望根据传入的参数个数不同来创建不同的形状。
interface IShape {
function getCircum();
function getArea();
}
// 定义矩形类
class Rectangle implements IShape {
private $width, $height;
public function __construct($width, $height) {
$this->width = $width;
$this->height = $height;
}
public function getCircum() {
return 2 * ($this->width + $this->height);
}
public function getArea() {
return $this->width * $this->height;
}
}
// 定义圆类
class Circle implements IShape {
private $radii;
public function __construct($radii) {
$this->radii = $radii;
}
public function getCircum() {
return 2 * M_PI * $this->radii;
}
public function getArea() {
return M_PI * pow($this->radii, 2);
}
}
// 根据传入的参数个数不同来创建不同的形状。
class FactoryShape {
public static function create() {
switch (func_num_args()) {
case 1:
return new Circle(func_get_arg(0));
break;
case 2:
return new Rectangle(func_get_arg(0), func_get_arg(0));
break;
}
}
}
// 矩形对象
$c = FactoryShape::create(4, 2);
var_dump($c->getArea());
// 圆对象
$o = FactoryShape::create(2);
var_dump($o->getArea());
使用工厂模式使得在调用方法时变得更容易,因为它只有一个类和一个方法,若没有使用工厂模式,则要在调用时决定应该调用哪个类和哪个方法;使用工厂模式