Change Link Or Script Filename In Html After Gruntjs Minify/uglify
Solution 1:
You can do this with grunt-string-replace. Here's an example on how you could use it.
In my index.html you find the following import tags:
<!--start PROD imports
<script src="assets/dist/traffic.min.js"></script>
end PROD imports--><!--start DEV imports--><scriptsrc="assets/js/app.js"></script><scriptsrc="assets/js/services.js"></script><scriptsrc="assets/js/directives.js"></script><scriptsrc="assets/js/filters.js"></script><scriptsrc="assets/js/resources.js"></script><scriptsrc="assets/js/controller/homeControllers.js"></script><scriptsrc="assets/js/controller/adminControllers.js"></script><scriptsrc="assets/js/controller/reportsControllers.js"></script><!--end DEV imports-->
Notice the 'start imports' and 'end imports' comments. By default (in DEV) we comment out the PROD import.
In my grunt file I then add the following task:
'string-replace': {
inline: {
files: {
'index.html': 'index.html'
},
options: {
replacements: [
{
pattern: '<!--start PROD imports',
replacement: '<!--start PROD imports-->'
},
{
pattern: 'end PROD imports-->',
replacement: '<!--end PROD imports-->'
},
{
pattern: '<!--start DEV imports-->',
replacement: '<!--start DEV imports'
},
{
pattern: '<!--end DEV imports-->',
replacement: 'end DEV imports-->'
}
]
}
}
}
Running the task (grunt string-replace) gives me:
<!--start PROD imports--><scriptsrc="assets/dist/traffic.min.js"></script><!--end PROD imports--><!--start DEV imports
<script src="assets/js/app.js"></script>
<script src="assets/js/services.js"></script>
<script src="assets/js/directives.js"></script>
<script src="assets/js/filters.js"></script>
<script src="assets/js/resources.js"></script>
<script src="assets/js/controller/homeControllers.js"></script>
<script src="assets/js/controller/adminControllers.js"></script>
<script src="assets/js/controller/reportsControllers.js"></script>
end DEV imports-->
Now the DEV imports have been commented out, while the PROD import is no longer commented out.
Solution 2:
This is easily automated with grunt-processhtml. Here's an example from the docs:
<!-- build:js app.min.js --><scriptsrc="my/lib/path/lib.js"></script><scriptsrc="my/deep/development/path/script.js"></script><!-- /build --><!-- changed to --><scriptsrc="app.min.js"></script>
Read more at https://www.npmjs.org/package/grunt-processhtml
Solution 3:
A very suitable grunt task for this is grunt-html-build
It can substitute some some parts of the HTML from dev to a production version. See examples there, it is easy to setup.
Now, using the standard configuration presented for grunt-html-build, if minified files are dynamically named during build process like:
some-file.js
-> another-name.min.js
One can configure grunt-html-build with:
[...]
scripts: {
bundle: [
'<%= fixturesPath %>/scripts/*.min.js'
]
},
[...]
A HTML section like:
<!-- build:script bundle --><scripttype="text/javascript"src="/path/to/js/libs/jquery.js"></script><scripttype="text/javascript"src="/path/to/js/libs/knockout.js"></script><scripttype="text/javascript"src="/path/to/js/libs/underscore.js"></script><scripttype="text/javascript"src="/path/to/js/app/module1.js"></script><scripttype="text/javascript"src="/path/to/js/app/module2.js"></script><!-- /build -->
Would yield to something like:
<scripttype="text/javascript"src="scripts/other-name.min.js"></script><scripttype="text/javascript"src="scripts/another-other-name.min.js"></script>
That is what @hyprstack is asking for in comments.
Solution 4:
You could use grunt preprocess to do this: https://github.com/jsoverson/grunt-preprocess
Basically, you need to set up a template and have preprocess replace the relevant parts.
The Gruntfile part will look something like this:
preprocess: {
dev: {
options: {
context: {
DEBUG:true,
HOST:'<%= env.dev.HOST %>'
}
},
files: {
'index.html':'tpl/index.tpl'
}
},
production: {
options: {
context: {
DEBUG:false,
HOST:'<%= env.production.HOST %>
}
},
files: {
'index.html':'tpl/index.tpl'
}
}
},
Solution 5:
I am using Middleman App do distinguish between dev vs build in my html or haml file:
- if development?
and
- if build?
Post a Comment for "Change Link Or Script Filename In Html After Gruntjs Minify/uglify"