F3-fatfree小型php框架教程(五)

看到这里我想再写一个helloworld的程序,不过此次的程序须要调用htm来实现,首先咱们知道fatfree主要是以php为引擎的,咱们定义一个template.htm文件:php

<p>Hello, <?php echo $name; ?>!</p>
注意,这里的name是还没初始化的变量

而后在主函数里面:html

$f3=require('lib/base.php');$f3->route('GET /',
    function($f3) {
        $f3->set('name','world');
        $view=new View;
        echo $view->render('template.htm');
        // Previous two lines can be shortened to:        // echo View::instance()->render('template.htm');    });$f3->run();

这里面的view是内置对象,用于调用htm文件,而后这里给name初始化了而后调用template,输出helloworld,应该没什么问题。web


这里也有另一种fatfree自己的模板,格式是:数组

<p>Hello, {{ @name }}!</p>
$f3=require('lib/base.php');$f3->route('GET /',
    function($f3) {
        $f3->set('name','world');
        $template=new Template;
        echo $template->render('template.htm');
        // Above lines can be written as:        // echo Template::instance()->render('template.htm');    });$f3->run();
变更就是new的类不一样和文件中变量的引用不一样。

能够发现fatfree的变量都是以@符号开头的,并且框架会自动产生跟跟文件名同样的类,在这里是template,也就是文件的名字。app

再举个例子,若是你定义了:框架

$f3->set('buddy',array('Tom','Dick','Harry'));

而后再在template里面写下:函数

<p>{{ @buddy[0] }}, {{ @buddy[1] }}, and {{ @buddy[2] }}</p>
就能够输出buddy的数组元素了,可是若是你只在文件里写   {{ @buddy }} 的话,那么由于传输进来的是一个数组,因此输出的是‘Array’这个字符串。

文件里面的调用还支持一系列的操做:ui

{{ 2*(@page-1) }}
{{ (int)765.29+1.2e3 }}<option value="F" {{ @active?'selected="selected"':'' }}>Female</option>{{ var_dump(@xyz) }}<p>That is {{ preg_match('/Yes/i',@response)?'correct':'wrong' }}!</p>{{ @obj->property }}
只要你源文件里面给这些变量定义彻底了,这些操做都是有效的。

还有fatfree里面给函数定义是这样的:编码

$f3->set('func',
    function($a,$b) {
        return $a.', '.$b;
    });
定义完以后就能够调用了:

{{ @func('hello','world') }}

还有一招在文件里面调用另一个文件:spa

<include href="header.htm" />
若是你怕麻烦也能够用变量的形式调用,首先:

// switch content to your blog sub-template$f3->set('content','blog.htm');// in another route, switch content to the wiki sub-template$f3->set('content','wiki.htm');
而后:

<include href="{{ @content }}" />
并且这个include还能够设置为有条件限制的:

<include if="{{ count(@items) >= 2 }}" href="items.htm" />
这里的count是计算@items数组的元素,这里就不详细说了。



注释:

<exclude>
    <p>A chunk of HTML we don't want displayed at the moment</p></exclude>
还有

{* <p>A chunk of HTML we don't want displayed at the moment</p> *}
都是fatfree里面的注释。


条件语句:

<check if="{{ @page=='Home' }}">
    <false><span>Inserted if condition is false</span></false></check><check if="{{ @gender=='M' }}">
    <true>
        <div>Appears when condition is true</div>
    </true>
    <false>
        <div>Appears when condition is false</div>
    </false></check>
跟ifelse同样,这里就不说了,可是若是不写false那就所有默认为true:

<check if="{{ @loggedin }}">
    <p>HTML chunk to be included if condition is true</p></check>


而后说一个数组输出的方法:

首先定义:

$f3->set('fruits',array('apple','orange ',' banana'));
而后文件中

<repeat group="{{ @fruits }}" value="{{ @ifruit }}">
    <p>{{ trim(@ifruit) }}</p></repeat>
这样就能够出来效果:

<p>apple</p><p>orange</p><p>banana</p>

而后咱们来个复杂的例子:

定义:

$f3->set('div',
    array(
        'coffee'=>array('arabica','barako','liberica','kopiluwak'),
        'tea'=>array('darjeeling','pekoe','samovar')
    ));
而后文件中:

<repeat group="{{ @div }}" key="{{ @ikey }}" value="{{ @idiv }}">
    <div>
        <p><span><b>{{ @ikey }}</b></span></p>
        <p>
        <repeat group="{{ @idiv }}" value="{{ @ispan }}">
            <span>{{ @ispan }}</span>
        </repeat>
        </p>
    </div></repeat>
输出:

<div>
    <p><span><b>coffee</b></span></p>
    <p>
        <span>arabica</span>
        <span>barako</span>
        <span>liberica</span>
        <span>kopiluwak</span>
    <p></div><div>
    <p><span><b>tea</b></span></p>
    <p>
        <span>darjeeling</span>
        <span>pekoe</span>
        <span>samovar</span>
    </p></div>
如今发现挺好用了吧,而后要说明一下,key对应的值是数组当前指针(多维才适用),value对应的值是数组的值,会根据要求罗列出来。并且若是定义的数组是多维的,例如上面那个div -> coffee -> arabica这个二维数组,repeat也要调用两次,第一次的repeat是进入coffee的第一层,而后第二次调用进入arabica这一层,key对应的就是当时的指针。


固然也能够像以前那样判断类别:

<repeat group="{{ @fruits }}" value="{{ @fruit }}" counter="{{ @ctr }}">
    <p class="{{ @ctr%2?'odd':'even' }}">{{ trim(@fruit) }}</p></repeat>
若是ctr是奇数就进odd类,若是是偶数就是even类


字符编码:

UTF-8:

$f3->set('ENCODING','ISO-8859-1');

email模板:

首先下面先说一下email的逻辑定义:

welcome.txt文件里面是这样的

MIME-Version: 1.0
Content-type: text/html; charset={{ @ENCODING }}
From: {{ @from }}
To: {{ @to }}
Subject: {{ @subject }}<p>Welcome, and thanks for joining {{ @site }}!</p>
咱们的定义:

$f3->set('from','<no-reply@mysite.com>');$f3->set('to','<slasher@throats.com>');$f3->set('subject','Welcome');ini_set('sendmail_from',$f3->get('from'));mail(
    $f3->get('to'),
    $f3->get('subject'),
    Template::instance()->render('email.txt','text/html'));
这里有两个比较陌生的php函数,ini_php函数是用来修改php.ini基本配置文件的函数,可是会在脚本运行结束后恢复。而mail函数是php内置的核心函数,不须要额外安装,也就是发email的,这里是简单的使用模式,分别是接收者,主题,内容。可是要注意,发送成功不表示对方必定会接收到。


固然,上面这个代码只是给单一用户发送邮件的代码,可是咱们常常要给一系列的用户发送邮件。因此就不能用这种简单的代码了。

咱们能够用smtp的类来发送:教程

$mail=new SMTP('smtp.gmail.com',465,'SSL','account@gmail.com','secret');
$mail->set('from','<no-reply@mysite.com>');
$mail->set('to','"Slasher" <slasher@throats.com>');
$mail->set('subject','Welcome');
$mail->send(Template::instance()->render('email.txt'));
相关文章
相关标签/搜索