仅对文件进行 Gulp 重命名,而不重命名目录


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

我只想重命名文件而不是目录(并且没有重复文件夹),但我无法弄清楚如何过滤目录。任何帮助不胜感激!

已编辑:为法比奥添加了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"

问题出在您的 .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 文件而不是文件夹。

相关内容

  • 没有找到相关文章

最新更新