-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
73 lines (67 loc) · 1.94 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
const path = require('path');
const express = require('express');
const expressVue = require('express-vue');
const app = express();
app.engine('vue', expressVue);
app.set('view engine', 'vue');
app.set('views', path.join(__dirname, '/views'));
app.set('vue', {
componentsDir: path.join(__dirname, '/views/components'),
defaultLayout: 'layout'
});
var users = [];
var pageTitle = 'Express Vue';
users.push({ name: 'tobi', age: 12 });
users.push({ name: 'loki', age: 14 });
users.push({ name: 'jane', age: 16 });
var exampleMixin = {
methods: {
hello: function () {
console.log('Hello');
}
}
}
app.get('/', function(req, res){
var scope = {
data: {
title: pageTitle,
message: 'Hello!',
users: users
},
vue: {
head: {
title: pageTitle,
meta: [
{ property:'og:title', content: pageTitle},
{ name:'twitter:title', content: pageTitle}
],
structuredData: {
"@context": "http://schema.org",
"@type": "Organization",
"url": "http://www.your-company-site.com",
"contactPoint": [{
"@type": "ContactPoint",
"telephone": "+1-401-555-1212",
"contactType": "customer service"
}]
}
},
components: ['users', 'messageComp'],
mixins: [exampleMixin]
}
};
res.render('index', scope);
});
app.get('/users/:userName', function(req, res){
var user = users.filter(function(item) {
return item.name === req.params.userName;
})[0];
res.render('user', {
data: {
title: 'Hello My Name is',
user: user
}
});
});
app.listen(3000);
console.log('Express server listening on port 3000');