zoukankan      html  css  js  c++  java
  • php模板字符串替换----PHP 替换模板变量实现步骤----PHP的(<<<EOT)在PHP中添加html

    方法1

    写这篇文章是由于最近一个项目中的满减活动,要实现根据模板生成广告,

    话不多说,直接上代码

    /*
         * 实现字符串模板解析
         * @value string
         * @data  array
         *@output string 解析模板后的字符串
         * */
    function getMbzStringAttr($value,$data){
            foreach ($data as $key=>$v){
                $$key =$v;
            }
            return eval('return "' . $value . '";');
    }
    $mbz_string = '满{$amount}减{$pay_account}';
    echo getMbzStringAttr($mbz_string,['amount'=>'20元','pay_account'=>'10元']);
    

    方法2---使用eval方法,因为这种方法,太不安全,所以不建议使用

    这是一个简易的字符串模板引擎、数据库模板引擎。区别于一般基于文件模板的引擎,这里的模板是一个字符串,因此可以将模板存于数据库或其他地方,而且不是编译型引擎,没有缓存文件,因而就不涉及到目录权限问题。模板的基本原理是将模板处理成全php脚本的字符串,然后用eval执行符串。至于安全问题,因为用到eval执行模板里面的语句,因此模板代码必须是受信任的,大多数其他模板引擎也是这样吧。

    // 字符串模板,懒得构造字符串,这里直接读取文件来模拟
    $str = file_get_contents( 'tpl.php' );
    // 首尾添加php脚本标签,使所有原样输出的html文本处于php脚本标签的中间
    $str = "<?php if(1){?>{$str}<?php }?>";
    // 用echo语句替换原样输出的html文本
    $str = preg_replace_callback( '/?>([sS]+?)<?/', function ($m)
    {
        return '?><?php echo "' . addcslashes( $m[1], "
    \"" ) . '";?><?';
    }, $str );
    // 去掉php脚本标签并执行标签里面的代码
    eval( str_replace( array (
            '<?php',
            '?>'
    ), '', $str ) );
    

    php模板替换的基本原理

    $title="测试标题"; 
    $file="测试内容"; 
    //打开这个模板 
    $tempdata=fopen("test.html","r"); 
    //读取模板中的内容 
    $str=fread($tempdata,filesize("test.html")); 
    //替换模板中的内容 
    $str=str_replace('{$title}',$title,$str); 
    $str=str_replace('{$center}',$file,$str); 
    //输出 
    echo $str; 
    

    好像是最终的方法

    在W3school上学PHP,看到第一句就是“PHP 文件可包含文本、HTML 标签以及脚本”

    在后来的学习别人的代码,发现在需要HTML代码的PHP脚本中,多用这么几种方法

    第一种是在HTML中加PHP。大段大段的html代码中,在各个需要执行php的地方。这种方法在ASP的程序中比较常见。

    例子:

        <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
      <meta http-equiv="Content-Language" content="zh-CN" />
        <title>Hello World</title><style>body{font-size:15px;color:#000;font-family:Arial,Helvetica,sans-serif;}a{color:#039;text-decoration:none;}</style>
        </head><body></b>
    <?php
    echo "Hello world!这是正文";
    ?>
    </b></body></html>
    

    第二种用echo输出HTML。但是HTML中有双引号,所用echo输出的内容用单引号括起来,避免出错,也省了转义这一步。比如这样的代码:

    <?php
    if(!$_POST)
    {
    echo '<form action="" method="post">
    服务器地址:<input type="text" name="host" value="localhost" /><br />
    数据库账号:<input type="text" name="user" value="" /><br />
    数据库密码:<input type="password" name="pwd" value="" /><br />
    指定数据库:<input type="text" name="db" value="test" /><br />
    <input type="submit" value="确定"/>
    </form><hr/>说明:<b><br /></b>';
    }
    ?>
    

    不过比较多见的还是加了转义符号的,个人觉得阅读起来不爽

    echo "<input type="submit" value="确定"/>" 
    
    第三种就是用(<<<)标记符了,这是在PHP168的模板代码中首次见到的。
    <<<EOT
    EOT;
    

    中间的文档直接输出,一个比较好理解的说法是“一个多行的echo ”。
    优点是输出大段HTML方便,不需要转义,而且可以引用变量。一个例子:

    <?php
    print <<<EOT
          <div class="slidecont">{$label[deepblue_mainslide]}</div>
            <div class="newcontainter">
              <div class="head">{$label[deepblue_mainh1]}</div>
                <div class="cont" id="Tab1">
                  {$label[deepblue_maint1]}
                </div>
                <div class="cont" id="Tab2">
                  {$label[deepblue_maint2]}
                </div>
            </div>
    <a href="$rs[url]" title="$rs[descrip]" target="_blank">$rs[name]</a>
    EOT;
    ?>
    

    在上面的例子干净利索的输出了大段HTML+变量的值,非常棒。

    使用(<<<eot)的注意事项

    标记符还有一点需要注意:标识符结束字符串既EOT;要独占一行,前后都不许再有内容。

    尤其容易犯的失误就是在标识符前加空格和缩进符,下面的例子什么都不会输出

    东方天宇的博客 EOT; echo "喂~人家在等你呢!"; ?>

    我们会发现,最后的echo也没有执行。这是因为(<<<eot)
    没有找到标识符结束字符,将echo语句也包含到需要输入的内容了。
    同时,因为没有找到标识符结束字符所有的内容都不会输出。
    当然,这只是我的理解,因为即使将echo语句放在print <<前面,脚本也不会有内容内容。
    具体什么原因,就留给大家去讨论了。

  • 相关阅读:
    stm32的hal之串口库函数总结复习
    关闭win10 任务栏窗口预览的步骤:
    sizeof的注意点
    goto语句——慎用,但是可以用
    #define的一个小技巧
    Chapter 1 First Sight——36
    Chapter 1 First Sight——35
    Chapter 1 First Sight——34
    leetcode409
    Chapter 1 First Sight——34
  • 原文地址:https://www.cnblogs.com/cn-oldboy/p/13837871.html
Copyright © 2011-2022 走看看