代码拉取完成,页面将自动刷新
'use strict'
const through = require('through2')
const PluginError = require('plugin-error')
const ejs = require('ejs')
const PLUGIN_NAME = 'gulp-ejs'
function render(data, options = {}) {
return through.obj(function(file, encoding, callback) {
if (file.isNull()) {
return callback(null, file)
}
if (file.isStream()) {
callback(new PluginError(PLUGIN_NAME, 'Streaming not supported'))
}
const ejsData = Object.assign({}, data, file.data)
try {
const rendered = ejs.render(file.contents.toString(), ejsData, options)
if (options.async && typeof rendered.then === 'function') {
rendered.then(rendered => {
file.contents = Buffer.from(rendered)
this.push(file)
}).catch(err => {
this.emit(
'error',
new PluginError(PLUGIN_NAME, err, { fileName: file.path })
)
}).then(callback)
return
}
file.contents = Buffer.from(rendered);
this.push(file);
} catch (err) {
this.emit(
'error',
new PluginError(PLUGIN_NAME, err, { fileName: file.path })
)
}
callback()
})
}
// expose ejs object for configuration
render.__EJS__ = ejs
module.exports = render
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。