node结合swig渲染摸板的方法


Posted in Javascript onApril 11, 2018

在这里就nodejs如何应用swig摸板,总结一下一些基本的用法。

首先当然是利用express框架在node后台上面搭建服务

var express = require('express');
var server = express();

server.listen(8080,'localhost',(req,res)=>{
   console.log('服务器启动...');
})

启动成功之后,开始设置swig摸板的相关配置,具体代码如下:

npm install swig -s

安装成功之后,加上swig配置,代码如下:

//配置摸板引擎
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});

配置需要渲染的数据:

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']
  });
})

html文件的具体代码如下所示:

<!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>
  <div>摸板引擎</div>
  <!-- {{}} 插值表达式-->
  姓名:<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>

具体页面显示如下:

node结合swig渲染摸板的方法

上面讲的是使用swig摸板引擎如何传递参数到页面渲染,下面来看看如何使用swig提取html公共的部分:

html页面公共的部分,比如说header,公共的js css文件,导航栏等

设置一个公共的页面:

<header>
  <title>node</title>
  <!-- css占位符主要用来显示其他页面的个性化的css文件,例如home.css about.css -->
  {% block css%}
  {% endblock %}
  <link rel="stylesheet" href="/static/css/layout.css" rel="external nofollow" >
</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

<!-- 继承所有页面公共的页面模块layout.html -->
{% extends './layout.html'%}
{% block css %}
<link rel="stylesheet" href="/static/css/home.css" rel="external nofollow" >
{% endblock %}
{% block content %}
 <li><a href="">1</a></li>
 <li><a href="">2</a></li>
 <li><a href="">3</a></li>
 <li><a href="">4</a></li>
 <li><a href="">5</a></li>
 <li><a href="">6</a></li>
{% endblock %}

{% block js %}
<script src="/static/js/home.js"></script>
{% endblock %}

当启动node服务器,渲染home页面的时候,你会看到

server.get('/',(req,res)=>{
  res.render('www/home',{});
})

node结合swig渲染摸板的方法

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
通过隐藏option实现select的联动效果
Nov 10 Javascript
jquery lazyload延迟加载技术的实现原理分析
Jan 24 Javascript
IE与FireFox中的childNodes区别
Oct 20 Javascript
javascript实现label标签跳出循环操作
Mar 06 Javascript
require、backbone等重构手机图片查看器
Nov 17 Javascript
javascript动画系列之模拟滚动条
Dec 13 Javascript
Bootstrap组合上、下拉框简单实现代码
Mar 06 Javascript
js HTML5 canvas绘制图片的方法
Sep 08 Javascript
Vue.js 时间转换代码及时间戳转时间字符串
Oct 16 Javascript
LayUI数据接口返回实体封装的例子
Sep 12 Javascript
vue props对象validator自定义函数实例
Nov 13 Javascript
在Vue中使用antv的示例代码
Jun 29 Javascript
详解react、redux、react-redux之间的关系
Apr 11 #Javascript
Mac下安装vue
Apr 11 #Javascript
vue-cli 组件的导入与使用教程详解
Apr 11 #Javascript
手动用webpack搭建第一个ReactApp的示例
Apr 11 #Javascript
浅谈vue-cli 3.0.x 初体验
Apr 11 #Javascript
vue 组件高级用法实例详解
Apr 11 #Javascript
vue单个组件实现无限层级多选菜单功能
Apr 10 #Javascript
You might like
深入解析PHP中逗号与点号的区别
2013/08/05 PHP
PHP Curl模拟登录微信公众平台、新浪微博实例代码
2016/01/28 PHP
PHP后期静态绑定之self::限制实例分析
2018/12/21 PHP
javascript 函数使用说明
2010/04/07 Javascript
JavaScript词法作用域与调用对象深入理解
2012/11/29 Javascript
根据json字符串生成Html的一种方式
2013/01/09 Javascript
JQuery插件开发示例代码
2013/11/06 Javascript
js 实现菜单上下显示附效果图
2013/11/21 Javascript
深入理解jQuery之事件移除
2016/06/02 Javascript
AngularJS 单元测试(一)详解
2016/09/21 Javascript
JavaScript中关于for循环删除数组元素内容时出现的问题
2016/11/21 Javascript
jquery,js简单实现类似Angular.js双向绑定
2017/01/13 Javascript
关于axios如何全局注册浅析
2018/01/14 Javascript
Node.js之readline模块的使用详解
2019/03/25 Javascript
python实现应用程序在右键菜单中添加打开方式功能
2017/01/09 Python
Python实现的双色球生成功能示例
2017/12/18 Python
python 读取视频,处理后,实时计算帧数fps的方法
2018/07/10 Python
Python 获取windows桌面路径的5种方法小结
2019/07/15 Python
解决使用export_graphviz可视化树报错的问题
2019/08/09 Python
Python爬虫库BeautifulSoup获取对象(标签)名,属性,内容,注释
2020/01/25 Python
Anaconda3+tensorflow2.0.0+PyCharm安装与环境搭建(图文)
2020/02/18 Python
浅析python 定时拆分备份 nginx 日志的方法
2020/04/27 Python
Python 利用OpenCV给照片换底色的示例代码
2020/08/03 Python
手把手教你配置JupyterLab 环境的实现
2021/02/02 Python
ZINVO手表官网:男士和女士手表
2019/03/10 全球购物
简单说说tomcat的配置
2013/05/28 面试题
国贸专业个人求职信分享
2013/12/04 职场文书
《狐假虎威》教学反思
2014/02/07 职场文书
办公室主任岗位承诺书
2014/05/29 职场文书
校园安全广播稿范文
2014/09/25 职场文书
学习十八届四中全会精神思想汇报
2014/10/23 职场文书
2015年社区矫正工作总结
2015/04/21 职场文书
贷款收入证明格式
2015/06/24 职场文书
优秀团员主要事迹范文
2015/11/05 职场文书
详解nginx.conf 中 root 目录设置问题
2021/04/01 Servers
总结Python连接CS2000的详细步骤
2021/06/23 Python