PHP做Web开发的MVC框架(Smarty使用说明 )
<span style="font-size: 15px;"><span style="font-size: 18pt;"> PHP做Web开发的MVC框架(Smarty使用说明 )</span><br>一、Smarty简明教程 </span>
<span style="font-size: 15px;">1.安装演示 </span>
<span style="font-size: 15px;"> 下载最新版本的Smarty-3.1.12,然后解压下载的文件。接下来演示Smarty自带的demo例子。 </span>
<span style="font-size: 15px;">(1)下载地址:http://www.smarty.net/download </span>
<span style="font-size: 15px;">(2)在你的WEB服务器根目录下建立新目录,这里我在/var/www下创建yqting/目录,然后将解压之后的目录中的demo/和libs/目录复制到/var/www/yqting/目录下。 <br>(3)这里要特别注意demo/目录下cache/和template_c/两个目录,<strong><span style="color: #ff0000;">一定要设置它们 为可读写权限</span></strong>。 </span>
<span style="font-size: 15px;"> chmod 777 cache/ </span>
<span style="font-size: 15px;"> chmod 777 template_c/ </span>
<span style="font-size: 15px;">(4)启动apache。在浏览器中输入http://localhost/yqting/demo/index.php ,这样一个简单的Smarty demo就实现了。 </span>
<span style="font-size: 15px;">2.Smarty目录结构 </span>
<span style="font-size: 15px;">(1)以/var/www/yqting目录开始分析: </span>
<span style="font-size: 15px;"> yqting/ </span>
<span style="font-size: 15px;"> ├── demo </span>
<span style="font-size: 15px;"> │ ├── cache 缓冲文件存放目录 </span>
<span style="font-size: 15px;"> │ ├── configs 配置文件目录 </span>
<span style="font-size: 15px;"> │ ├── index.php </span>
<span style="font-size: 15px;"> │ ├── plugins 自定义的一些实用插件 </span>
<span style="font-size: 15px;"> │ ├── templates 模板目录 </span>
<span style="font-size: 15px;"> │ └── templates_c 编译后的文件存放目录 </span>
<span style="font-size: 15px;"> └── libs</span>
<span style="font-size: 15px;"> ├── debug.tpl debug模板 </span>
<span style="font-size: 15px;"> ├── plugins 自定义的一些实用插件</span>
<span style="font-size: 15px;"> ├── SmartyBC.class.php 支持Smarty 2兼容 </span>
<span style="font-size: 15px;"> ├── Smarty.class.php Smarty类定义文件 </span>
<span style="font-size: 15px;"> └── sysplugins Smarty核心功能插件,不需要进行修改 </span>
<span style="font-size: 15px;">(2)添加自己定义的插件 </span>
<span style="font-size: 15px;"> 上述目录结构中,其实最核心的部分是libs/目录,同时这部分也是不允许修改的。</span>
<span style="font-size: 15px;"> 而要添加自己的插件,一种方法是将自己定义的插件放在libs/plugins/目录下,另一种方式是 单独创建一个自己plugins/目录,同时还要创建cache/、configs/、templates/和templates _c/目录,而且要保证cache/和templates_c/目录的可读写权限。 </span>
<span style="font-size: 15px;"> 不难发现,其实上述例子中,demo/目录就是一个包含了自己定义的插件的完整目录。 我们可以参照demo/目录来实现自己的程序。 </span>
<span style="font-size: 15px;">3.实现一个简单的例子 </span>
<span style="font-size: 15px;">(1)在/var/www/yqting/下创建目录weibo/,然后在weibo/目录下创建cache/、 configs/、templates/和templates_c/目录,修改cache/和templates_c/目录的权限为可读写。 </span>
<span style="font-size: 15px;">(2)新建一个模板文件:index.tpl,将此文件放在/var/www/yqting/weibo/templates目录下,代码如下: </span>
<span style="font-size: 15px;"> </span>
<span style="font-size: 15px;"> </span>
<span style="font-size: 15px;"> <metahttp-equiv content="text/html;charset=gb2312"></metahttp-equiv></span>
<span style="font-size: 15px;"> <title>Smarty</title> </span>
<span style="font-size: 15px;"> </span>
<span style="font-size: 15px;"> </span>
<span style="font-size: 15px;"> username:{$Name}</span>
<span style="font-size: 15px;"> </span>
<span style="font-size: 15px;"> <br> 这段代码很简单,有什么不明白的继续往下看,不要着急!每一个做显示的.tpl文件都会对应一个处理业务逻辑的.php文件,下面介绍这个.php文件。</span>
<span style="font-size: 15px;">(3)新建index.php,将此文件放在/var/www/yqting/weibo/下,代码如下: </span>
<span style="font-size: 15px;"> <?php <br> </span><span style="font-size: 15px;">/*sample example */<br> </span><span style="font-size: 15px;">require '../libs/Smarty.class.php'; <br> </span><span style="font-size: 15px;">$smarty = new Smarty(); <br> </span><span style="font-size: 15px;">$username = "Smarty"; <br> $smarty->assign("Name",$username); <br> </span><span style="font-size: 15px;">$smarty->display('index.tpl'); <br> </span><span style="font-size: 15px;">?> <br> 其中require使用的路径一定要正确,可以参照上面的目录结构看一下!</span>
<span style="font-size: 15px;">(4)在Smarty3中,Smarty类的构造函数中已经指定了template_dir、compile_dir 、config_dir和cache_dir,不需要再次指定。 </span>
<span style="font-size: 15px;">(5) 在浏览器中输入http://localhost/yqting/weibo/index.php,就可以看到输出的信息username:Smarty 了。 </span>
<span style="font-size: 15px;">二、解释smarty的程序 </span>
<span style="font-size: 15px;"> 我们可以看到,smarty的程序部分实际就是符合php语言规范的一组代码,我们依次来解释一下: </span>
<span style="font-size: 15px;">(1)/**/语句:</span>
<span style="font-size: 15px;"> 包含的部分为程序篇头注释。主要的内容应该为对程序的作用,版权与作者及编写时间 做一个简单的介绍,这在smarty中不是必需的,但从程序的风格来讲,这是一个好的风格。 </span>
<span style="font-size: 15px;">(2)include_once语句:</span>
<span style="font-size: 15px;"> 它将安装到网站的smarty文件包含到当前文件中,注意包含的路径一定要写正确。 </span>
<span style="font-size: 15px;">(3)$smarty = new Smarty(): </span>
<span style="font-size: 15px;"> 这一句新建一个Smarty对象$smarty,简单的一个对象的实例化。 </span>
<span style="font-size: 15px;">(4)$smarty->templates="": </span>
<span style="font-size: 15px;"> 这一句指明$smarty对象使用tpl模板时的路径,它是一个目录,在没有这一句时, Smarty默认的模板路径为当前目录的templates目录,实际在写程序时,我们要将这一 句写明,这也是一种好的程序风格。 </span>
<span style="font-size: 15px;">(5)$smarty->templates_c="": </span>
<span style="font-size: 15px;"> 这一句指明$smarty对象进行编译时的目录。在模板设计篇我们已经知道Smarty是 一种编译型模板语言,而这个目录,就是它编译模板的目录,要注意,如果站点位于linux 服务器上,请确保 teamplates_c里定义的这个目录具有可写可读权限,默认情况下它的 编译目录是当前目录下的templates_c,出于同样的理由我们将其明确的写出来。 </span>
<span style="font-size: 15px;">(6)<strong><span style="color: #ff0000; font-size: 16px;">分隔符 $smarty->left_delimiter与$smarty->right_delimiter: </span></strong></span>
<span style="font-size: 15px;"> 指明在查找模板变量时的左右分割符。默认情况下为"{"与"}",但在实际中因为我们要 在模板中使用<script>,Script中的函数定义难免会使用{},虽然它有自己的解决办法,但习惯上我们将它重新定义为"{#"与"#}"或是"<!--{"与"}-->"或其它标志符,注意,如果在这里定义了左右分割符后,在模板文件中相应的要使每一个变量使用与定义相同的符号, 例如在这里指定为"<{"与"}>",html模板中也要相应的将{$name}变成<{$name}>, 这样程序才可以正确的找到模板变量。 </script></span>
<span style="font-size: 15px;">(7)$smarty->cache="./cache": </span>
<span style="font-size: 15px;"> 告诉Smarty输出的模板文件缓存的位置。上一篇我们知道Smarty最大的优点在于它 可以缓存,这里就是设置缓存的目录。默认情况下为当前目录下的cache目录,与 templates_c目录相当,在linux系统中,我们要确保它的可读可写性。 </span>
<span style="font-size: 15px;">(8)$smarty->cache_lifetime = 60 * 60 * 24: </span>
<span style="font-size: 15px;"> 这里将以秒为单位进行计算缓存有效的时间。第一次缓存时间到期时当Smarty的 caching变量设置为true时缓存将被重建。当它的取值为-1时表示建立起的缓存从不过期, 为0时表示在程序每次执行时缓 存总是被重新建立。上面的设置表示将cache_lifetime设置为一天。 </span>
<span style="font-size: 15px;">(9)$smarty->caching = 1: </span>
<span style="font-size: 15px;"> 这个属性告诉Smarty是否要进行缓存以及缓存的方式。</span>
<span style="font-size: 15px;"> 它可以取3个值,0: Smarty默认值,表示不对模板进行缓存;1:表示Smarty将使用当前定义的 cache_lifetime来决定是否结束cache;2:表示 Smarty将使用在cache被建立时使用 cache_lifetime这个值。习惯上使用true与false来表示是否进行缓存。 </span>
<span style="font-size: 15px;">(10)$smarty->assign("name", $username): </span>
<span style="font-size: 15px;"> 该数的原型为assign(string varname, mixed var),varname为模板中使用的模板变量,var指出要将模板变量替换的变量名;其第二种原形为assign(mixed var),我们要在后面的例子详细的讲解这个成员函数的使用方法,assign是Smarty的核心函数之一, 所有对模板变量的替换都要使用它。 </span>
<span style="font-size: 15px;">(11)$smarty->display("index.tpl"): </span>
<span style="font-size: 15px;"> 该函数原形为display(string varname),作用为显示一个模板。简单的讲,它将分析 处理过的模板显示出来,这里的模板文件不用加路径,只要使用一个文件名就可以了,它路 径我们已 经在$smarty->templates(string path)中定义过了。 </span>
<span style="font-size: 15px;"><br>程序执行完后我们可以打开当前目录下的templates_c与cache目录,就会发现在下 边多出一些%%的目录,这些目录就是Smarty的编译与缓存目录,它由程序自动生成,不 要直接对这些生成的文件进行修改。 </span>
<span style="font-size: 15px;">以上我简单的把Smarty程序中的一些常用的基本元素介绍了一下,在后边的例子中你可以看到将它们将被多次的使用。</span>
<span style="font-size: 15px;"> </span>

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

PHP主要是过程式编程,但也支持面向对象编程(OOP);Python支持多种范式,包括OOP、函数式和过程式编程。PHP适合web开发,Python适用于多种应用,如数据分析和机器学习。

PHP适合网页开发和快速原型开发,Python适用于数据科学和机器学习。1.PHP用于动态网页开发,语法简单,适合快速开发。2.Python语法简洁,适用于多领域,库生态系统强大。

PHP起源于1994年,由RasmusLerdorf开发,最初用于跟踪网站访问者,逐渐演变为服务器端脚本语言,广泛应用于网页开发。Python由GuidovanRossum于1980年代末开发,1991年首次发布,强调代码可读性和简洁性,适用于科学计算、数据分析等领域。

HTML的未来趋势是语义化和Web组件,CSS的未来趋势是CSS-in-JS和CSSHoudini,JavaScript的未来趋势是WebAssembly和Serverless。1.HTML的语义化提高可访问性和SEO效果,Web组件提升开发效率但需注意浏览器兼容性。2.CSS-in-JS增强样式管理灵活性但可能增大文件体积,CSSHoudini允许直接操作CSS渲染。3.WebAssembly优化浏览器应用性能但学习曲线陡,Serverless简化开发但需优化冷启动问题。

JavaScript在Web开发中的主要用途包括客户端交互、表单验证和异步通信。1)通过DOM操作实现动态内容更新和用户交互;2)在用户提交数据前进行客户端验证,提高用户体验;3)通过AJAX技术实现与服务器的无刷新通信。

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。 MySQL以其高性能、可扩展性和跨平台支持着称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

React在HTML中的应用通过组件化和虚拟DOM提升了web开发的效率和灵活性。1)React组件化思想将UI分解为可重用单元,简化管理。2)虚拟DOM优化性能,通过diffing算法最小化DOM操作。3)JSX语法允许在JavaScript中编写HTML,提升开发效率。4)使用useState钩子管理状态,实现动态内容更新。5)优化策略包括使用React.memo和useCallback减少不必要的渲染。

PHP仍然流行的原因是其易用性、灵活性和强大的生态系统。1)易用性和简单语法使其成为初学者的首选。2)与web开发紧密结合,处理HTTP请求和数据库交互出色。3)庞大的生态系统提供了丰富的工具和库。4)活跃的社区和开源性质使其适应新需求和技术趋势。
