zoukankan      html  css  js  c++  java
  • 自定义类似smarty模板

    • 自定义类封装模板解析功能
    原理其实比较简单,就是把html文件解析为一个超级字符串,然后把类似{{$mytitle}}这种结构的变量进行替换(str_replace)当然,实际中这样做可能导致频繁的磁盘I/O
    类实现体
    class analazytpl
    {
        private $mydata = array();
        private $leftdelimeter = "<{";
        private $rightdelimeter = "}>";
        public function assign($key,$value)
        {
            $this->mydata[$key] = $value;
        }
        public function __set($key,$value)
        {
            $this->$key = $value;
        }
        public function __get($key)
        {
            echo $this->$key.PHP_EOL;
            //return $this->$key;
        }
        public function display($tplname)
        {
            $tplcontents = file_get_contents($tplname);
            foreach($this->mydata as $key=>$value)
            {
                //echo $this->leftdelimeter.$key.$this->rightdelimeter.PHP_EOL;
                //echo $value.PHP_EOL;
                $tplcontents=str_replace($this->leftdelimeter.$key.$this->rightdelimeter,$value,$tplcontents);
            }
            echo $tplcontents;//这一步超级关键,一定要输出模板替换的最终结果
        }
    }
    调用自定义的类
    $mytpl = new analazytpl();
    $mytpl->leftdelimeter = '{{';
    $mytpl->rightdelimeter ='}}';
    $mytpl->assign('$mytitle','我的自定义smarty页');
    $mytpl->assign('$mywords','我的自定义smarty页');
    $mytpl->assign('$mypic','../static/pic/130406050015a5c63fe5f44412.jpg');
    $mytpl->display('../templates/selfdefine.html');
    模板文件
    
    <!DOCTYPE html>
    <html lang="en">
    <!doctype html>
    <html lang="en">
    <head>
        <meta charset="utf-8">
        <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
        <meta name="description" content="">
        <meta name="author" content="">
        <link rel="icon" href="../../../../favicon.ico">
    
        <title>{{$mytitle}}</title>    #第一个模板变量
    
        <!-- Bootstrap core CSS -->
        <link href="../static/booststrap4/css/bootstrap.min.css" rel="stylesheet">
    
        <!-- Custom styles for this template -->
        <link href="../static/mycss/navbar-top.css" rel="stylesheet">
    </head>
    
    <body>
    
    <nav class="navbar navbar-expand-md navbar-dark bg-dark mb-4">
        <a class="navbar-brand" href="#">Top navbar</a>
        <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarCollapse" aria-controls="navbarCollapse" aria-expanded="false"
    aria-label="Toggle navigation"> <span class="navbar-toggler-icon"></span> </button> <div class="collapse navbar-collapse" id="navbarCollapse"> <ul class="navbar-nav mr-auto"> <li class="nav-item active"> <a class="nav-link" href="#">Home <span class="sr-only">(current)</span></a> </li> <li class="nav-item"> <a class="nav-link" href="#">Link</a> </li> <li class="nav-item"> <a class="nav-link disabled" href="#">Disabled</a> </li> </ul> <form class="form-inline mt-2 mt-md-0"> <input class="form-control mr-sm-2" type="text" placeholder="Search" aria-label="Search"> <button class="btn btn-outline-success my-2 my-sm-0" type="submit">Search</button> </form> </div> </nav> <main role="main" class="container"> <div class="jumbotron"> <h1>Navbar example</h1> <p class="lead">{{$mywords}}</p> #第二个模板变量 <a class="btn btn-lg btn-primary" href="../../components/navbar/" role="button">View navbar docs &raquo;</a> <p> <br> <img src="{{$mypic}}" height="200"> #第三个模板变量 </p> </div> </main> <!-- Bootstrap core JavaScript ================================================== --> <!-- Placed at the end of the document so the pages load faster --> <script src="../static/booststrap4/js/jquery-3.3.1.min.js"></script> </body> </html>

    结果:

    可以在Apache,nginx乃至IIS部署自己的网站直接访问替换模板文件

     

  • 相关阅读:
    Git的安装与配置
    JDBCTemplate
    消费金融大数据风控架构
    架构设计之道
    面向服务架构SOA
    java集合List解析
    web应用安全
    微服务的交互模式
    服务化管理和治理框架的技术选型
    分库分表就能无限扩容么?
  • 原文地址:https://www.cnblogs.com/saintdingspage/p/11063891.html
Copyright © 2011-2022 走看看