JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 17
  • Score
    100M100P100Q45011F
  • License MIT

Replaces references to non-optimized scripts or stylesheets into a set of HTML files.

Package Exports

  • gulp-publish

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (gulp-publish) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

gulp-publish

Build Status Coverage Report Package Dependency Package DevDependency

Attention

gulp-publish make out from gulp-usemin branch for some entire different idea, and not ready for production environment.

Replace references to release scripts or stylesheets HTML tags, and provide API for resolve linked files identified by src or href.

Usage

First, install gulp-publish as a development dependency:

npm install --save-dev gulp-publish

Then, add it to your gulpfile.js:

var publish = require('gulp-publish');

gulp.task('publish', function () {
  return gulp.src('*.html')
      .pipe(publish()))
      .pipe(gulp.dest('build/'));
});

Block

Block are expressed as:

<!-- build:<type> <path> -->
Any link script markup
<!-- endbuild -->
  • type: declare the way to resolve internal markups and related files, e.g js, css, less, coffee, stylus, sass. (Linked files should match type)
  • path: the file output path relative to process.cwd().

Remember not miss the block split flag Between normal HTML and block, block and block, block and normal HTML, add split flag <!-- split -->.

Particularly, when type equal 'remove', the block will be destroyed.

<!-- build:remove /build/script/build.js -->
<script src="/script/origin.js"></script>
<!-- endbuild -->

Also, support add tags when build, below will insert <script src="/build/script/build.js"> , <link rel="stylesheet" href="/style/build.css"/> into html.

<!-- build:js /build/script/build.js -->
<!-- endbuild -->

<!-- build:css /style/build.css -->
<!-- endbuild -->

An completed example form acts below:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>gulp release</title>
    <!-- split -->
    <!-- build:css /style/build.css -->
    <link rel="stylesheet" href="/style/origin.css">
    <link rel="stylesheet" href="/style/complex.css">
    <!-- endbuild -->
    <!-- split -->
    <!-- build:js /script/build.js -->
    <script src="/script/origin.js"></script>
    <script src="/script/complex.js"></script>
    <!-- endbuild -->
    <!-- split -->
</head>
<body>

</body>
</html>

The example HTML file will output below:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>gulp release</title>

<link rel="stylesheet" href="/style/build.css"/>
<script src="/script/build.js"></script>

</head>
<body>

</body>
</html>

Options

Complete options act like below:

{
  enableResolve: true,
  postfix: '',
  directory: './build',
  css: [cssmin({})],
  js: [uglify({}],
  debug: true
}

enableResolve

Type: Boolean

whether resolve related files that script, link point. if false, will only output resolved HTML file. if true, will try resolve linked javascript, css files.

postfix

Type: md5 | String | Function

the postfix after source address. if md5, will calculate md5 value of all the linked files concat. if String, will use the string. if Function, the argument is all the linked files concat buffer, and use returned value as postfix.

css

Type: Array

Value consists of stream object that gulp-plugin generate. Declare how to resolve css files. if omitted or null, will only concat related files.

js

Type: Array

Value consists of stream object that gulp-plugin generate. Declare how to resolve javascript files. if omitted or null, will only concat related files.

less, stylus, sass, coffee

Almost the same thing as css, js above, to resolve correspond files. less, coffee pass the test, stylus, sass will dance as well.

debug

Type: boolean

whether used in debug environment, just for unit test.

For some scene, you did special structure, such as build simple server to render less, coffee files, and import like below:

<link rel="stylesheet" href="/style/index.less" />
<script src="/script/index.coffee"></script>

Making an assumption, put gulp-less, gulp-coffee into css or js config array will achieve the same thing, but I think provide less, coffee type is necessary.

Contact

hjj491229492@hotmail.com

LICENSE

MIT