私はこの基本的なkoa v2
アプリを持っています。このアプリでは、テンプレートリテラルを表示エンジンとして実装しようとしています。 ./views/index.js
でstate
の値をapp.js
からどのように設定できますか?CommonJSモジュール内のオブジェクトの値を変更できないのはなぜですか?
私の問題は、私はのは、私は<title></title>
タグの間title
オブジェクト値を含めたいとしましょう.views/partials/mainTop.js
ファイルにダウンctx.body = index.render({})
からすべての方法をオブジェクト値をプッシュするということです。これを達成する方法はありますか.views/partials/mainTop.js
app.js
に?ハンドルバーやnunjucksテンプレートの場合、テンプレートリテラルと同様のことを達成したい。
./app.js
const index = require('./views/index');
const app = new Koa();
app.use(ctx => {
index.state = {
foo: 'bar',
};
ctx.body = index.render({
title: 'Template Literals',
description: 'Vanilla JS rendering',
});
});
app.listen(3000);
./views/index.js
const main = require('./layouts/main');
let state = {};
module.exports.state = state;
console.log(state); // returning an {} empty object, expected => { foo: "bar" }
module.exports.render = (obj) => {
return main.render(`
<p>Hello world! This is HTML5 Boilerplate.</p>
${JSON.stringify(obj, null, 4)}}
${obj.title}
`);
};
./views/layouts/main.js
const mainTop = require('../partials/mainTop');
const mainBottom = require('../partials/mainBottom');
module.exports.render = (content) => {
return `
${mainTop.render}
${content}
${mainBottom()}
`;
}
./views/partials/mainTop.js
./views/partials/mainBottom.js
module.exports =() => {
return `
...
</body>
</html>
`;
}
不明です。どこでも到達可能なメソッドを定義して値を返すか、最後の手段としてグローバルを使用することができます。 – dandavis
'mainTop'が文字列プロパティを持つオブジェクトとして定義されているのに対して、' mainBottom'が文字列を返す関数として定義されているのはなぜですか? – Bergi