grunt-inline
将html页面里的外链资源,比如js、css、img,变成内联资源。比如:
带有__inline
标记的link
标签,会变成内联样式
<link href="css/style.css?__inline=true" rel="stylesheet" />
带有__inline
标记的img
标签,会变成内联base64字符串
<img src="img/icon.png?__inline=true" />
带有__inline
标记的script
标签,会变成内联脚本
<script src="js/erport.js?__inline=true"></script>
Getting Started
This plugin requires Grunt ~0.4.1
If you haven't used Grunt before, be sure to check out the Getting Started guide, as it explains how to create a Gruntfile as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:
npm install grunt-inline --save-dev
Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:
grunt.loadNpmTasks('grunt-inline');
The "grunt-inline" task
Overview
In your project's Gruntfile, add a section named inline
to the data object passed into grunt.initConfig()
.
grunt.initConfig({
inline: {
dist: {
src: [ 'dist/index.html' ]
}
}
})
Options
dest
If dest is assigned, the the source file will be copied to the destination path. eg:
dist/index.html
will be processed and then copied to dest/index.html
grunt.initConfig({
inline: {
dist: {
src: ['dist/index.html'],
dest: ['dest/']
}
}
});
cssmin
If cssmin is assigned true, .css
will be minified before inlined.
grunt.initConfig({
inline: {
dist: {
options:{
cssmin: true
},
src: ['dist/index.html'],
dest: ['dest/']
}
}
});
uglify
If uglify is assigned true, .js
file will be minified before inlined.
grunt.initConfig({
inline: {
dist: {
options:{
uglify: true
},
src: ['dist/index.html'],
dest: ['dest/']
}
}
});
Usage Examples
config
grunt.initConfig({
inline: {
dist: {
src: [ 'dist/index.html' ],
dest: [ 'dev/' ]
}
}
})
src/index.html
<html>
<head>
<title>demo</title>
<link href="css/style.css?__inline=true" rel="stylesheet" />
</head>
<body>
<img src="img/icon.png?__inline=true" />
<script src="js/erport.js?__inline=true"></script>
</body>
</html>
after grunt inline
was run, it will be something like
<html>
<head>
<title>demo</title>
<style>
.container{
padding: 0;
}
</style>
</head>
<body>
<! -- base64, a terrible mass you know…so just show a little bit ...-->
<img src="idata:image/png;base64..." />
<script>
var Report = (function(){
return {
init: function(){
}
};
})();
</script>
</body>
</html>
inline tag
Suppose there is an <inline>
tag in index.html
like bellow
<!-- inline tag -->
<inline src="test.html" />
The content of test.html
is
<p>I'm inline html</p>
<span>hello world!</span>
Then, after the inline
task is run, the original content in index.html
will be replaced with
<p>I'm inline html</p>
<span>hello world!</span>
Contributing
In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using Grunt.
Release History
- 2013-10-31 v0.2.2 bug fix: img urls like 'background: url(http://www.example.com/img/bg.png)' will be transformed to 'background: url(url(http://www.example.com/img/bg.png))'
- 2013-10-30 v0.2.1 bug fix: when processing relative file path of img url in css stylesheet, forgot to transform "" to "/" for windows users
- 2013-10-30 v0.2.0 new feature: Support for minifing js、css when they ar inlined into html.
- 2013-08-30 v0.1.9 bug fix: stylesheets ended with ">" cannot be inlined
- 2013-09-02 v0.1.9 add feature: add options.dest to assign a destination path where the source file will be copied
- 2013-09-02 v0.1.8 add feature: support for
<inline>
tag