0
function javascriptSites() {
  return gulp.src(PATHS.javascriptSites)
  .pipe($.sourcemaps.init())
  .pipe($.babel())
  .pipe($.if(PRODUCTION, $.uglify()
    .on('error', e => { console.log(e); })
  ))
  .pipe($.if(PRODUCTION, $.rename({
    suffix: '.min'  
  })))
  .pipe(gulp.dest('dist/assets/js'))
}

这将输出以下树:

dir/assets/js/

folder1
    site.min.js

folder1.min
    empty

folder2
    site.min.js

folder2.min
    empty

folder3
    site.min.js

folder3.min
    empty

我只想重命名文件而不是目录(并且没有重复的文件夹),但我不知道如何过滤掉目录。任何帮助表示赞赏!

已编辑:为Fabio添加了 config.yml 文件

  # Your project's server will run on localhost:xxxx at this port
  PORT: 8000

  # Autoprefixer will make sure your CSS works with these browsers
  COMPATIBILITY:
    - "last 2 versions"
    - "ie >= 9"

  # UnCSS will use these settings
  UNCSS_OPTIONS:
    html:
      - "src/**/*.html"
    ignore:
      - !!js/regexp .foundation-mq
      - !!js/regexp ^\.is-.*

  # Gulp will reference these paths when it copies files
  PATHS:
    # Paths to static assets that aren't images, CSS, or JavaScript
    assets:
      - "src/assets/**/*"
      - "!src/assets/{img,js,scss}/**/*"
    fonts:
      - "bower_components/font-awesome/fonts/**/*"

    # Paths to Sass libraries, which can then be loaded with @import
    sass:
      - "bower_components/foundation-sites/scss"
      - "bower_components/motion-ui/src"
      - "src/assets/scss"

    # Paths to JavaScript libraries, which are compined into one file
    javascript:
     # Libraries requried by Foundation
      - "bower_components/jquery/dist/jquery.js"
      - "bower_components/what-input/what-input.js"
     # Core Foundation files
      - "bower_components/foundation-sites/js/foundation.core.js"
      - "bower_components/foundation-sites/js/foundation.util.*.js"
     # Individual Foundation components
     # If you aren't using a component, just remove it from the list
      - "bower_components/foundation-sites/js/foundation.abide.js"
      - "bower_components/foundation-sites/js/foundation.accordion.js"
      - "bower_components/foundation-sites/js/foundation.accordionMenu.js"
      - "bower_components/foundation-sites/js/foundation.drilldown.js"
      - "bower_components/foundation-sites/js/foundation.dropdown.js"
      - "bower_components/foundation-sites/js/foundation.dropdownMenu.js"
      - "bower_components/foundation-sites/js/foundation.equalizer.js"
      - "bower_components/foundation-sites/js/foundation.interchange.js"
      - "bower_components/foundation-sites/js/foundation.magellan.js"
      - "bower_components/foundation-sites/js/foundation.offcanvas.js"
      - "bower_components/foundation-sites/js/foundation.orbit.js"
      - "bower_components/foundation-sites/js/foundation.responsiveMenu.js"
      - "bower_components/foundation-sites/js/foundation.responsiveToggle.js"
      - "bower_components/foundation-sites/js/foundation.reveal.js"
      - "bower_components/foundation-sites/js/foundation.slider.js"
      - "bower_components/foundation-sites/js/foundation.sticky.js"
      - "bower_components/foundation-sites/js/foundation.tabs.js"
      - "bower_components/foundation-sites/js/foundation.toggler.js"
      - "bower_components/foundation-sites/js/foundation.tooltip.js"
     # Paths to your own project code are here
      - "src/assets/js/!(app).js"
      - "src/assets/js/app.js"
      - "bower_components/owl.carousel/dist/owl.carousel.js"

     javascriptSites:
      - "src/assets/js/**/*"
      - "!src/assets/js/app.js"
4

1 回答 1

1

问题出在您的 .yml 文件中。您将其指定为来源:

javascriptSites:
      - "src/assets/js/**/*"
      - "!src/assets/js/app.js"

现在,您的文件夹被重命名和更改的原因是因为您将您内部的所有内容传递src/assets/js/给您的 gulp 管道,而显然您想要的只是传递所有javascript 文件。

为此,您需要将.yml文件更改为:

javascriptSites:
      - "src/assets/js/**/*.js"
      - "!src/assets/js/app.js"

请注意,我们将.js添加到您的第一行,因此 gulp 只获取 javascript 文件而不是文件夹。

于 2016-03-21T16:24:06.267 回答