设为首页 收藏本站
查看: 860|回复: 0

[经验分享] PHP之Smarty模版简单应用

[复制链接]

尚未签到

发表于 2015-8-23 14:56:17 | 显示全部楼层 |阅读模式
  什么是模版,我的理解是将界面和实现代码分离开来,
  这样做的目的将美工和程序员的工作分离开来,提高工作效率,方便后期维护。
  PHP也有比较多的模版,例如PHPLIB Template、FastTemplate、Smarty等
  今天我研究的是Smarty
  到Smarty的官方网站下载最新的Smarty套件: http://smarty.php.net/
解开 Smarty 2.6.0 后,会看到很多档案,其中有个 libs 资料夹。在 libs 中应该会有 3 个 class.php 檔 + 1 个 debug.tpl + 1 个 plugin 资料夹 + 1 个 core 资料夹。然后直接将 libs 复制到您的程序主资料夹下

  如上项目结构         那个libs就是Smart的内库
  common.php        增强可重复性创建此  因为很多页面都会用到如下设置,所以把他提取出来,每次只要引用即可!
  <?php
require('smarty/mysql.class.php');
$dbcharset = 'utf8';
$query = new dbQuery('localhost', 'root', 'sa','demo');
  require 'smarty/libs/Smarty.class.php';
  // 初始化smarty
$smarty = new Smarty;
  $smarty->compile_check = true; // 打开编译检查
$smarty->debugging = false;
  $smarty->template_dir   = 'templates/'; //模板目录  可自定义 只要可在项目中确实存在此目录
$smarty->compile_dir    = 'templates_c/';//编译文件目录  同上
  $smarty->left_delimiter  = '<!--{';//左标记  解析模版页中的特定代码块   可自定义   
$smarty->right_delimiter  = '}-->';//右标记
  ?>
   mysql.class.php
  <?php
/**
* mysql查询类
*
*/
class dbQuery {
/**
  * 查询总次数
  *
  * @var int
  */
var $querynum = 0;
/**
  * 连接句柄
  *
  * @var object
  */
var $link;

/**
  * 构造函数
  *
  * @param string $dbhost 主机名
  * @param string $dbuser 用户
  * @param string $dbpw   密码
  * @param string $dbname 数据库名
  * @param int $pconnect 是否持续连接
  */
function dbQuery($dbhost, $dbuser, $dbpw, $dbname = '', $pconnect = 0) {
  if($pconnect) {
   if(!$this->link = @mysql_pconnect($dbhost, $dbuser, $dbpw)) {
    $this->halt('Can not connect to MySQL server');
   }
  } else {
   if(!$this->link = @mysql_connect($dbhost, $dbuser, $dbpw)) {
    $this->halt('Can not connect to MySQL server');
   }
  }
  if($this->version() > '4.1') {
   global $dbcharset;
   if($dbcharset) {
    mysql_query("SET character_set_connection=$dbcharset, character_set_results=$dbcharset, character_set_client=binary", $this->link);
   }
  if($this->version() > '5.0.1') {
    mysql_query("SET sql_mode=''", $this->link);
   }
  }
  if($dbname) {
   mysql_select_db($dbname, $this->link);
  }
  }
/**
  * 选择数据库
  *
  * @param string $dbname
  * @return
  */
function select_db($dbname) {
  return mysql_select_db($dbname, $this->link);
}
/**
  * 取出结果集中一条记录
  *
  * @param object $query
  * @param int $result_type
  * @return array
  */
function fetch_array($query, $result_type = MYSQL_ASSOC) {
  return mysql_fetch_array($query, $result_type);
}

/**
  * 查询SQL
  *
  * @param string $sql
  * @param string $type
  * @return object
  */
function query($sql, $type = '') {
  
  $func = $type == 'UNBUFFERED' && @function_exists('mysql_unbuffered_query') ?
   'mysql_unbuffered_query' : 'mysql_query';
  if(!($query = $func($sql, $this->link)) && $type != 'SILENT') {
   $this->halt('MySQL Query Error', $sql);
  }
  $this->querynum++;
  return $query;
}
/**
  * 取影响条数
  *
  * @return int
  */
function affected_rows() {
  return mysql_affected_rows($this->link);
}
/**
  * 返回错误信息
  *
  * @return array
  */
function error() {
  return (($this->link) ? mysql_error($this->link) : mysql_error());
}
/**
  * 返回错误代码
  *
  * @return int
  */
function errno() {
  return intval(($this->link) ? mysql_errno($this->link) : mysql_errno());
}
/**
  * 返回查询结果
  *
  * @param object $query
  * @param string $row
  * @return mixed
  */
function result($query, $row) {
  $query = @mysql_result($query, $row);
  return $query;
}
/**
  * 结果条数
  *
  * @param object $query
  * @return int
  */
function num_rows($query) {
  $query = mysql_num_rows($query);
  return $query;
}
/**
  * 取字段总数
  *
  * @param object $query
  * @return int
  */
function num_fields($query) {
  return mysql_num_fields($query);
}
/**
  * 释放结果集
  *
  * @param object $query
  * @return bool
  */
function free_result($query) {
  return mysql_free_result($query);
}
/**
  * 返回自增ID
  *
  * @return int
  */
function insert_id() {
  return ($id = mysql_insert_id($this->link)) >= 0 ? $id : $this->result($this->query("SELECT last_insert_id()"), 0);
}
/**
  * 从结果集中取得一行作为枚举数组
  *
  * @param object $query
  * @return array
  */
function fetch_row($query) {
  $query = mysql_fetch_row($query);
  return $query;
}
/**
  * 从结果集中取得列信息并作为对象返回
  *
  * @param object $query
  * @return object
  */
function fetch_fields($query) {
  return mysql_fetch_field($query);
}
/**
  * 返回mysql版本
  *
  * @return string
  */
function version() {
  return mysql_get_server_info($this->link);
}
/**
  * 关闭连接
  *
  * @return bool
  */
function close() {
  return mysql_close($this->link);
}
/**
  * 输出错误信息
  *
  * @param string $message
  * @param string $sql
  */
function halt($message = '', $sql = '') {
  echo $message . ' ' . $sql;
  exit;
  }
}
  ?>
  
  userList.php
  <?php
include_once 'common.php';
$result=$query->query("select * from userinfo");
$userList=array();
while ($row=$query->fetch_array($result))
{
array_push($userList,$row);
}
$query->free_result($result);
$query->close();
$smarty->assign('userList',$userList);//给模板赋值
$smarty->display('userList.html');//显示模板内容
?>
  
  userList.html
  <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>用户列表</title>
</head>
<body>
<center>
<table>
  <tr><th>用户名</th><th>密码</th><th>年龄</th><th>备注</th></tr>
<!--{foreach  from=$userList item=user}-->
<tr>
<td><!--{$user.userName}--></td>
<td><!--{$user.pwd}--></td>
<td><!--{$user.age}--></td>
<td><!--{$user.remark}--></td>
</tr>
<!--{/foreach}-->
</table>
</center>
</body>
</html>
  
  
  运行userList.php
用户名密码年龄备注zhangsan1234520aaliudehuagggggg40aa  
  
  测试成功! 个人小结  那模版页面就好比是含有多个Smart标记的一个占位符,然后进行动态的操作,我只是一个小小DEMO,但感觉这样的方式是挺不错的 一定程度上解耦合了,呵呵  还要继续学习啊 !

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-103053-1-1.html 上篇帖子: php 汉字转拼音 [包含20902个基本汉字+5059生僻字] 下篇帖子: PHP Socket 编程
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表