Heim >Backend-Entwicklung >PHP-Tutorial >php命名空间 和 独立的模板引擎 的必要性 在哪里?

php命名空间 和 独立的模板引擎 的必要性 在哪里?

WBOY
WBOYOriginal
2016-06-06 20:49:311139Durchsuche

php引入命名空间用"\"分割的语法,算是独创,初用非常不习惯;且,用设计良好的目录结果来管理类,也能实现命名空间管理,个人认为新引入的namespace,used等都是画蛇添足,望指教交流。

再说模板引擎,个人认为模板引擎唯一用处在于:把写界面(模板)和写业务逻辑分离开,使的美工可以独立开发模板,以减少程序员的工作量。但对于美工来说,学习 类似{var}的模板标签,不亚于写php代码直接填充模板的难度;且非php语法的模板需要模板编译的过程,消耗性能。除此之外,想请问各种模板引擎的好处在哪里?

请不要简单的回答:“你的项目规模不够大,并行开发人员不够多”

回复内容:

php引入命名空间用"\"分割的语法,算是独创,初用非常不习惯;且,用设计良好的目录结果来管理类,也能实现命名空间管理,个人认为新引入的namespace,used等都是画蛇添足,望指教交流。

再说模板引擎,个人认为模板引擎唯一用处在于:把写界面(模板)和写业务逻辑分离开,使的美工可以独立开发模板,以减少程序员的工作量。但对于美工来说,学习 类似{var}的模板标签,不亚于写php代码直接填充模板的难度;且非php语法的模板需要模板编译的过程,消耗性能。除此之外,想请问各种模板引擎的好处在哪里?

请不要简单的回答:“你的项目规模不够大,并行开发人员不够多”

命名空间用得不多,跳过,就说说模板引擎吧。

关于模板引擎的使用,其实是回到最原始的需求:无非就是希望尽可能方便地输出html。

虽然php与其他很多语言不一样,它最初被设计出来的时候就是为了方便在一堆html里头实现一些动态特性(所以其实也有很多项目的确是用php来实现模板的,比如wordpress就是一堆php);但是和smarty(之类的模板引擎)比起来,在直接写html的时候,的确大多数时候还是smarty更方便,因为smarty引擎是针对编写html专门优化的。比如说在smarty里头需要将一个变量进行html转义:

<code>{$xxx|escape:'html'}
</code>

php呢?

<code><?php echo htmlspecialchars($xxx); ?>
</code>

如果改改成引号转义,smarty只需要把 html 改成 quotes 就行了,形式上保持了一致,在编写和阅读上都比较舒服。至于php,当然把 htmlspecialchars 改成 addslashes 也可以,但是php的函数,真的很难用(又难记又难写,很多类似的一组函数,变量的顺序也没有统一的约定,谁用谁恶心)……关于这一点我深有体会,10年的时候自己写的一个项目,觉得不是很有必要用smarty,于是自己用php来实现,写得非常痛苦,如果当时对smarty了解多一点(只是听说过,感觉好像比较重量级就没用),就绝对不可能出现这种情况。

最近webpy用的比较多,webpy的模板引擎我觉得比smarty用起来更爽的一点也在html转义:它默认就是转义的,需要在页面引用变量的时候,直接 $xxx 就行了。如果不需要转义也很简单: $:xxx

这些专门为了html开发而优化的特性,对于php这种一开始就很随意、以后也是很随意地乱堆起来的语言来说,的确是要好很多。

而关于编译、效率的问题:其实大多数模板引擎都是有编译缓存的,只是在第一次访问的时候需要编译,此后带来的开销几乎可以忽略不计。关于效率的问题,其实还可以顺便吐槽一下php——本来效率就不怎么样,这一点开销真的没什么。(p.s. 我快成php黑了)

use等等是命名空间的核心功能啊,显然,这是从C++等语言参考过来的。

命名空间的目的是为了加强标识符的管理,并非所有情况下都要使用非常长的完整限定名,所以要有use等机制来对标识符的命名空间部分进行简写。

当然,PHP的命名空间确实设计的不怎么样,比如奇葩的反斜杠,对函数和变量功能有限等等。

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn