node+ejs模板引擎的应用
前言:
最近在开发一个关于后台管理系统的基础开发平台,解释一下就是不管什么管理系统都有一些相同的功能,但是又有一些细节不一样,这个基础平台就是实现对于基础功能可以进行快速开发,主要有自定义的生成功能代码块,只需要选择一些配置项就能够生成我们需要的页面,主要就是通过nodejs和ejs模板引擎完成这个功能。
正文:
其实实现起来也很简单:
首先就是我们先要搭建需要生成的页面模板,然后通过传递参数来实现生成不同的需求页面,下面贴一些主要的代码:(这里是生成的vue文件,其实不管是html vue文件都一样)
这里是ejs模板
<!-- 查看 -->
<Modal v-model="modal.flag" :title="modal.title" :footer-hide="modal.footer" :width="modal.width" :class="modal.size" :mask="modal.mask">
<Form ref="formItem" :model="formItem" :label-width="120" label-position="right" class="formStyle"><% for (let i=0; i<config.length; i++) { %>
<Row>
<Col span="8">
<FormItem label="<%= config[i].itemName %>:" prop="<%= config[i].itemCode %>"><% if (config[i].inputElement === 'input') { %>
<Input v-model="formItem.<%= config[i].itemCode %>" :readonly="readonly"></Input><% } else if (config[i].inputElement === 'text') { %>
<Input v-model="formItem.<%= config[i].itemCode %>" :readonly="readonly" type="textarea" :rows="4"></Input><% } else if (config[i].inputElement === 'password') { %>
<Input v-model="formItem.<%= config[i].itemCode %>" :readonly="readonly" type="password" :rows="4"></Input><% } else if (config[i].inputElement === 'radio') { %>
<RadioGroup v-model="formItem.<%= config[i].itemCode %>">
<Radio v-for="(item, index) in formItem.<%= config[i].itemCode %>_list" :label="item.value" disabled>{{ item.label }}</Radio>
</RadioGroup><% } else if (config[i].inputElement === 'checkbox') { %>
<CheckboxGroup v-model="formItem.<%= config[i].itemCode %>">
<Checkbox v-for="(item, index) in formItem.<%= config[i].itemCode %>_list" :label="item.value" disabled>{{ item.label }}</Checkbox>
</CheckboxGroup><% } else if (config[i].inputElement === 'switch') { %>
<i-switch v-model="formItem.<%= config[i].itemCode %>" :true-value="open" :false-value="close" size="large" disabled>
<span v-for="(item, index) in formItem.<%= config[i].itemCode %>_list" :slot="item.value" :key="index">{{ item.label }}</span>
</i-switch><% } else if (config[i].inputElement === 'date') { %>
<DatePicker type="date" v-model="formItem.<%= config[i].itemCode %>" :readonly="readonly"></DatePicker><% } else if (config[i].inputElement === 'time') { %>
<TimePicker type="time" v-model="formItem.<%= config[i].itemCode %>" :readonly="readonly"></TimePicker><% } else if (config[i].inputElement === 'tree') { %>
<Input v-model="formItem.<%= config[i].itemCode %>_list" :readonly="readonly"/>
<Input v-model="formItem.<%= config[i].itemCode %>" style="display:none" :readonly="readonly"/><% } else if (config[i].inputElement === 'select') { %>
<Select v-model="formItem.<%= config[i].itemCode %>" disabled>
<Option v-for="(item, index) in formItem.<%= config[i].itemCode %>_list" :value="item.value" :key="index">{{ item.label }}</Option>
</Select><% } %>
</FormItem>
</Col>
</Row><% } %>
</Form>
</Modal>
//这里是生成模板时,通过node服务将后台请求到的数据简单处理一下然后添加到模板中,然后生成vue文件
http.createServer(function(req, res) {
res.writeHead(200, {
'Content-Type': 'text/plain'
});
// 解析 url 参数
let params = url.parse(req.url, true).query
res.end()
console.log("读取模板!"); fs.readFile('./src/views/system-management/FYI/vue.ejs', function(err, data) {
if (err) {
return console.error(err)
}
console.log("异步读取文件数据: " + data.toString()); let template = data.toString()
console.log("columns: " + params.telegram.columns);
console.log(params);
let liquid = {
columns: JSON.parse(params.telegram).columns,
columnsButton: JSON.parse(params.telegram).columnsButton,
modelUrl: JSON.parse(params.telegram).modelUrl,
config: JSON.parse(params.telegram).config,
operationButton: JSON.parse(params.telegram).operationButton,
addCardButton: JSON.parse(params.telegram).addCardButton,
editCardButton: JSON.parse(params.telegram).editCardButton,
columnsField: JSON.parse(params.telegram).columnsField,
formId: JSON.parse(params.telegram).formId,
functionId: JSON.parse(params.telegram).functionId,
sumWidth: JSON.parse(params.telegram).sumWidth,
id: JSON.parse(params.telegram).id
}
let vue = ejs.render(template, liquid)
let vuePath = `./src/views/system-management/FYI/${liquid.formId}.vue`
console.log("数据已成功注入模板中!")
console.log("准备写入文件")
fs.writeFile(vuePath, vue, function(err) {
if (err) {
return console.error(err)
}
console.log("数据写入成功!")
})
console.log("vue 文件已生成!") })
}).listen(3000);
//这里就是将以上两个部分连接起来就实现了整个过程,先从后请求数据然后再通过本地的node服务将数据添加到模板中最后生成vue文件
birthCode() {
let sessionId = Cookies.get('status');
let this1 = this;
this1.$http({
headers: {
"Authorization": sessionId,
},
method: 'post',
url: this1.GLOBAL.BASE_URL + '/common/function/loadingPage',
params: {
'id': this1.funId
},
})
.then(function(res) {
// axios请求
this1.$http({
method: 'get',
url: 'http://localhost:3000',
params: {
telegram: res.data[0]
}
})
.then(function(response) {
debugger
})
.catch(function(error) {
})
})
.catch(function(error) {
//
})
}
这些只是自己在项目中的一些运用,也是第一次接触使用ejs模板引擎,如果有不对的地方欢迎大家指正,最后希望能够帮助到大家!
node+ejs模板引擎的应用的更多相关文章
- Node - EJS模板应用(node+express+ejs)
准备工作: 工具:Webstorm 1. 新建一个文件夹为blogs(随意). 一个js文件app.js. 一个文件夹views,文件夹内一个index.ejs文件,文件夹asstes内style.c ...
- nodejs-5.1 ejs模板引擎
ejs官方文档:https://ejs.bootcss.com/ 1.什么是 EJS? "E" 代表 "effective",即[高效]. EJS 是一套简单的 ...
- 前端笔记之NodeJS(三)Express&ejs模板引擎&请求识别
一.Express框架 1.1基本使用 创建http服务器特别麻烦,express框架解决了这个的问题. Express在node界的地位,就相当于jQuery在DOM界的地位.jQuery的核心就是 ...
- express搭建web服务器、路由、get、post请求、multer上传文件、EJS模板引擎的使用
express官网 postman工具下载地址 multer的npm文档地址 express模板引擎怎么使用 地址:http://www.expressjs.com.cn/guide/using- ...
- 在express站点中使用ejs模板引擎
在express站点中使用ejs模板引擎 文/玄魂 目录 在express站点中使用ejs模板引擎 前言 1.1 安装 1.2修改app.js 1.3创建测试页面 前言 使用 vs创建 ...
- 理解node的模板引擎
1.1.3:分析模板引擎 1.什么是模板引擎 模板引擎是一个将页面模板和要显示的数据结合生成HTML页面的工具 可以这么理解,如果说Express中的路由控制方法是MVC中的控制器的话,那么模板 ...
- 使用ejs模板引擎
let express = require('express'); let fs = require('fs'); let ejs = require('ejs'); let app = expres ...
- Express框架中如何引用ejs模板引擎
1.如何在项目中安装ejs模板引擎 在NodeJS指南中利用利用以下命令建立网站的基本结构: express -t ejs microblog 运行这个命令后继续运行 cd microblog &am ...
- Swiper+ ejs模板引擎+ iScroll插件知识总结
一. Swiper swiper是一个应用于移动端的动画插件,原理类似于轮播图 官网 http://www.swiper.com.cn/# html结构 <div class="swi ...
随机推荐
- 如何解决loss NAN的问题
问题 如上图所示,第二次迭代时出现NAN值,nan表示无穷大或者非数值,一般是在一个数除以0或者log(0)时会出现无穷大.可能的原因有:1)学习率过大:2)batch过大:3)不当的损失函数等. 试 ...
- spark的运行模式
1.local(本地模式) 单机模式,通常用来测试 将spark应用以多线程方式,直接运行在本地 本地模式可以启动多个executor不过上限不能超过cpu数 2.standalone(独立模式) 独 ...
- C++——简单数据类型及布尔类型
一. 简单数据类型 数据类型描述了对象在内存存储区中占据的空间大小,描述了对象能够表示的数据范围 和类型.C++语言中常用的数据类型有整型.实型.字符型(这3种类型也被称之为简单数 据类型).数组类型 ...
- vue2.x入坑总结—回顾对比angularJS/React的一统
从感性的角度讲,我是不屑于用VUE,觉得react套件用起来更顺手,但是vue现在越来火,所以也不得入vue(杂烩汤)的坑.vue/anguarJS/React,三者对关系现在就是: https:// ...
- 2015年上海现场赛重现 (A几何, K暴力搜索)
A: 题目链接 :https://vjudge.net/contest/250823#problem/A 参考 : https://www.cnblogs.com/helenawang/p/54654 ...
- JavaScript中的转译符
转译字符 含义 \o NUL字符(\u0000) \b 退格符(\u0008) \t 水平制表符(\u0009) \n 换行符(\u000A) \v 垂直制表符(\u000B) \f 换页符( ...
- zigbee 中ZDO的理解
---恢复内容开始--- ZigBee 物理层:主要进行无线数据的收发,同时定义了无线传输的信道以及频率. MAC层:使用CSMA-CA机制接入到无线信道,负责传输信标帧,保持同步和 ...
- 前端如何生成条形码---JsBarcode
React 生成条形码代码 注:需引入 jsbarcode 插件 import React from 'react'; import JsBarcode from 'jsbarcode'; class ...
- 安卓加载网络图片OOM问题解决
前言:次片是上篇后续出现的问题,在网上找了很多博客,越解决越乱,好在最后看了郭霖的博客给了我一点思路 借鉴:http://blog.csdn.net/guolin_blog/article/detai ...
- 论使用HashMap优化双层For循环的实际性能
当需要对两个集合进行相互操作的时候,一般需要进行双层For循环,但我们知道双层For在数量越大的时候性能影响越大 这时候我们会想到的其中一种解决方法就是利用Hashmap在查找数据的高效上来优化双层F ...