mirror of
https://github.com/S2-/ejs-render-remote
synced 2025-08-04 05:20:04 +02:00
Compare commits
1 Commits
v1.0.12
...
37a2512f4b
Author | SHA1 | Date | |
---|---|---|---|
37a2512f4b |
@@ -28,7 +28,6 @@
|
|||||||
"dot-notation": 0,
|
"dot-notation": 0,
|
||||||
"no-multi-str": 2,
|
"no-multi-str": 2,
|
||||||
"key-spacing": [2, {"afterColon": true}],
|
"key-spacing": [2, {"afterColon": true}],
|
||||||
"func-call-spacing": [2, "never"],
|
"func-call-spacing": [2, "never"]
|
||||||
"no-console": "warn"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
//this uses jQuery for now because ie11 support is needed (promises, fetch, Object.assign)
|
//this uses jQuery for now because ie11 support is needed (promises and fetch)
|
||||||
|
|
||||||
(function($) {
|
(function($) {
|
||||||
var uuidv4 = function() {
|
var uuidv4 = function() {
|
||||||
@@ -9,28 +9,19 @@
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
var overwriteWithCacheOptions = function(options, cacheName) {
|
ejs.rr = function(templateUrl, data) {
|
||||||
var cacheOptions = {
|
|
||||||
cache: true,
|
|
||||||
filename: cacheName
|
|
||||||
};
|
|
||||||
|
|
||||||
var templateOptions = options || {};
|
|
||||||
|
|
||||||
return $.extend(templateOptions, cacheOptions);
|
|
||||||
};
|
|
||||||
|
|
||||||
ejs.rr = function(templateUrl, data, options) {
|
|
||||||
var templateFn = ejs.cache.get(templateUrl);
|
var templateFn = ejs.cache.get(templateUrl);
|
||||||
|
|
||||||
//if the template is already cached, return it and we are done
|
//if the template is already cached, return it and we are done
|
||||||
if (templateFn) {
|
if (templateFn) {
|
||||||
try {
|
//but first check if there is still a getter function for this template in the cache
|
||||||
return templateFn(data);
|
//if yes, remove it so we clean up a bit
|
||||||
} catch(ex) {
|
if (ejs.cache.remove && ejs.cache.get('getFnFor' + templateUrl)) {
|
||||||
$.readyException(ex);
|
ejs.cache.remove('getFnFor' + templateUrl);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return templateFn(data);
|
||||||
|
|
||||||
} else { //if the template is not cached, we need to get it and render it later once we have it. remember: this happens only if the template is not already cached
|
} else { //if the template is not cached, we need to get it and render it later once we have it. remember: this happens only if the template is not already cached
|
||||||
|
|
||||||
//is there a getFn for this template?
|
//is there a getFn for this template?
|
||||||
@@ -41,47 +32,39 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
var r = uuidv4();
|
var r = uuidv4();
|
||||||
getTemplateFn.done(function(template) {
|
getTemplateFn.then(function(template) {
|
||||||
var templateOptions = overwriteWithCacheOptions(options, templateUrl);
|
|
||||||
|
|
||||||
try {
|
|
||||||
$('#' + r).replaceWith(ejs.render(
|
$('#' + r).replaceWith(ejs.render(
|
||||||
template,
|
template,
|
||||||
data,
|
data,
|
||||||
templateOptions
|
{
|
||||||
|
cache: true,
|
||||||
|
filename: templateUrl
|
||||||
|
}
|
||||||
));
|
));
|
||||||
} catch(ex) {
|
|
||||||
$.readyException(ex);
|
|
||||||
}
|
|
||||||
|
|
||||||
//clean up the getFnFor
|
|
||||||
if (ejs.cache.remove && ejs.cache.get('getFnFor' + templateUrl)) {
|
|
||||||
ejs.cache.remove('getFnFor' + templateUrl);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return '<span class="ejs-templateplaceholder" style="display: none;" id="' + r + '"></span>';
|
return '<span class="ejs-templateplaceholder" style="display: none;" id="' + r + '"></span>';
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
ejs.preloadTemplate = function(templateUrl, options) {
|
ejs.preloadTemplate = function(templateUrl) {
|
||||||
var d = $.Deferred();
|
var d = $.Deferred();
|
||||||
|
|
||||||
//if the template is already cached, just return.
|
//if the template is already cached, just return.
|
||||||
if (ejs.cache.get(templateUrl)) {
|
if (ejs.cache.get(templateUrl)) {
|
||||||
d.resolve(templateUrl);
|
d.resolve();
|
||||||
} else {
|
} else {
|
||||||
$.get(templateUrl)
|
$.get(templateUrl)
|
||||||
.done(function(template) {
|
.then(function(template) {
|
||||||
try {
|
var templateFn = ejs.compile(template,
|
||||||
var templateOptions = overwriteWithCacheOptions(options, templateUrl);
|
{
|
||||||
var templateFn = ejs.compile(template, templateOptions);
|
cache: true,
|
||||||
|
filename: templateUrl
|
||||||
|
});
|
||||||
|
|
||||||
ejs.cache.set(templateUrl, templateFn);
|
ejs.cache.set(templateUrl, templateFn);
|
||||||
|
|
||||||
d.resolve(templateUrl);
|
d.resolve(templateUrl);
|
||||||
} catch(ex) {
|
|
||||||
$.readyException(ex);
|
|
||||||
d.reject(ex);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
2
examples/ejs.min.js
vendored
2
examples/ejs.min.js
vendored
File diff suppressed because one or more lines are too long
@@ -9,7 +9,6 @@
|
|||||||
<body>
|
<body>
|
||||||
<h1>ejs-render-remote example</h1>
|
<h1>ejs-render-remote example</h1>
|
||||||
<p class="hello"></p>
|
<p class="hello"></p>
|
||||||
<div class="sometext"></div>
|
|
||||||
|
|
||||||
<script src="jquery.min.js"></script>
|
<script src="jquery.min.js"></script>
|
||||||
<script src="ejs.min.js"></script>
|
<script src="ejs.min.js"></script>
|
||||||
@@ -19,14 +18,6 @@
|
|||||||
<script>
|
<script>
|
||||||
//render the template
|
//render the template
|
||||||
$('.hello').html(ejs.rr('templates/hello.ejs', {name: 'Simon'}));
|
$('.hello').html(ejs.rr('templates/hello.ejs', {name: 'Simon'}));
|
||||||
|
|
||||||
//a more elaborate example: preload the template to be sure the dom is
|
|
||||||
//ready when manipulated
|
|
||||||
ejs.preloadTemplate('templates/somestuff.ejs')
|
|
||||||
.then(function(t) {
|
|
||||||
$('.sometext').html(ejs.rr(t)); //this is sync now
|
|
||||||
$('.stuff').html('hi!');
|
|
||||||
});
|
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
@@ -1 +1 @@
|
|||||||
Hello <%= name %>!
|
Hello <%= name%>!
|
||||||
|
@@ -1 +0,0 @@
|
|||||||
<p class="stuff"></p>
|
|
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "ejs-render-remote",
|
"name": "ejs-render-remote",
|
||||||
"version": "1.0.12",
|
"version": "1.0.3",
|
||||||
"description": "",
|
"description": "",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"homepage": "https://github.com/S2-/ejs-render-remote",
|
"homepage": "https://github.com/S2-/ejs-render-remote",
|
||||||
@@ -9,9 +9,5 @@
|
|||||||
},
|
},
|
||||||
"author": "s2 <s2@31337.it>",
|
"author": "s2 <s2@31337.it>",
|
||||||
"license": "ISC",
|
"license": "ISC",
|
||||||
"keywords": [
|
"keywords": ["ejs", "templating", "client-side"]
|
||||||
"ejs",
|
|
||||||
"templating",
|
|
||||||
"client-side"
|
|
||||||
]
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user