Heim >Web-Frontend >js-Tutorial >Knoten kombiniert mit Swig-Rendering-Vorlage
Der in diesem Artikel mit Ihnen geteilte Inhalt bezieht sich auf Node in Kombination mit der Swig-Rendering-Vorlage. Freunde in Not können sich darauf beziehen.
Hier finden Sie eine Zusammenfassung, wie NodeJS die Swig-Vorlage anwendet Schauen wir uns einige grundlegende Verwendungsmöglichkeiten an.
Verwenden Sie zunächst natürlich das Express-Framework, um Dienste im Knoten-Backend zu erstellen.
var express = require('express'); var server = express(); server.listen(8080,'localhost',(req,res)=>{ console.log('服务器启动...'); })
Nachdem der Start erfolgreich war, beginnen Sie mit der Einrichtung der relevanten Konfiguration der Swig-Vorlage. Der spezifische Code lautet wie folgt:
npm install swig -s
Fügen Sie nach erfolgreicher Installation die Swig-Konfiguration hinzu. Der Code lautet wie folgt:
//配置摸板引擎 var swig = require('swig'); //参数1,摸板引擎的名称,固定字段 //参数2,摸板引擎的方法 server.engine('html',swig.renderFile); //摸板引擎存放目录的关键字,固定字段 //实际存在的目录,html文件就在html文件夹下面 server.set('views',__dirname+'/html'); //注册摸板引擎,固定字段 server.set('view engine','html'); //关闭swig缓存,缓存的目的也是提高node服务器的响应速度 swig.setDefaults({cache:false});
Konfigurieren Sie die zu rendernden Daten:
server.get('/',(req,res)=>{ //render方法只有在使用摸板引擎之后才会生效,其中 参数1是需要渲染的摸板名称,参数2就是需要渲染到页面的一些参数 res.render('temp',{ name:'张三', user:{ name:'栗子', age:18 }, lists:['item1','item2','item3','item4','item5', 'item6','item7','item8','item9','item10','item11','item12', 'item13','item14','item15','item16','item17','item18','item19', 'item20','item21','item22','item23','item24','item25','item26'] }); })
Der spezifische Code der HTML-Datei lautet wie folgt:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <p>摸板引擎</p> <!-- {{}} 插值表达式--> 姓名:<p>{{name}}</p> {% if user.name == '栗子' && user.age == '18'%} 姓名:<p>栗子</p> {% elseif user.name == '张三'%} <p>张三</p> {% endif %} <p>遍历数组</p> {% for items in lists%} <li>items</li> {% endfor %} <!-- 页面上面设置数据 --> {% set arr = [1,2,3,4,5]%} <p>{{arr.length}}</p> <!-- 如何引入页面--> {% include './common.html' %} </body> </html>
Die spezifische Seite wird wie folgt angezeigt:
Oben wird beschrieben, wie Sie mit der Swig-Vorlagen-Engine Parameter an das Seitenrendering übergeben. Schauen wir uns an, wie Sie mit Swig die öffentlichen Teile von HTML extrahieren:
Öffentliche Teile von HTML-Seiten, z. B. Header und öffentliche JS-CSS-Dateien , Navigationsleisten usw.
Legen Sie eine öffentliche Seite fest:
<header> <title>node</title> <!-- css占位符主要用来显示其他页面的个性化的css文件,例如home.css about.css --> {% block css%} {% endblock %} <link rel="stylesheet" href="/static/css/layout.css"> </header> <!-- 所以页面公共的导航栏 --> <nav> <li><a href="">首页</a></li> <li><a href="">关于我们</a></li> <li><a href="">商品列表</a></li> <li><a href="">登录</a></li> <li><a href="">注册</a></li> </nav> <!-- content占位符主要用来显示其他页面的个性化的内容显示,不同的页面有不同的显示方式 --> {% block content%} {% endblock %} <!-- js占位符主要用来显示其他页面的个性化的js文件,例如home.js about.js --> {% block js%} {% endblock %} <script src="/static/js/layout.js"></script>
Home html
d4cca6311f99f023c034557d9c699285 {% extends './layout.html'%} {% block css %} 93df20d6087b99c1f2fce1dfd065778e {% endblock %} {% block content %} 25edfb22a4f469ecb59f1190150159c66170e8999ab19ec641e0422470b16d5c15db79b134e9f6b82c0b36e0489ee08edbed06894275b65c1ab86501b08a632eb 25edfb22a4f469ecb59f1190150159c66170e8999ab19ec641e0422470b16d5c25db79b134e9f6b82c0b36e0489ee08edbed06894275b65c1ab86501b08a632eb 25edfb22a4f469ecb59f1190150159c66170e8999ab19ec641e0422470b16d5c35db79b134e9f6b82c0b36e0489ee08edbed06894275b65c1ab86501b08a632eb 25edfb22a4f469ecb59f1190150159c66170e8999ab19ec641e0422470b16d5c45db79b134e9f6b82c0b36e0489ee08edbed06894275b65c1ab86501b08a632eb 25edfb22a4f469ecb59f1190150159c66170e8999ab19ec641e0422470b16d5c55db79b134e9f6b82c0b36e0489ee08edbed06894275b65c1ab86501b08a632eb 25edfb22a4f469ecb59f1190150159c66170e8999ab19ec641e0422470b16d5c65db79b134e9f6b82c0b36e0489ee08edbed06894275b65c1ab86501b08a632eb {% endblock %} {% block js %} 4598c8b9c010e04b865fd3e7954034832cacc6d41bbb37262a98f745aa00fbf0 {% endblock %}
Wenn Sie den Knotenserver starten und die Homepage rendern, wird
server.get('/',(req,res)=>{ res.render('www/home',{}); })
verwandt Empfohlen:
Knoten implementiert tokenbasierte Authentifizierung
Ein detailliertes Beispiel dafür, wie node.js die SQL Server-Datenbank erhält
Das obige ist der detaillierte Inhalt vonKnoten kombiniert mit Swig-Rendering-Vorlage. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!