javascript - 如何在 grunt build 中跳过 concat

标签 javascript angularjs gruntjs uglifyjs grunt-contrib-concat

我需要跳过 grunt 构建中的 concat,因为它会给我带来很多错误,并在我的 Angular 项目中产生冲突。

我在我的 Gruntfile.js 上试过这个:

copy: {
      dist: {
        files: [{
          expand: true,
          dot: true,
          cwd: '<%= yeoman.app %>',
          dest: '<%= yeoman.dist %>',
          src: [
            '*.{ico,png,txt}',
            '*.html',
            'images/{,*/}*.{webp}',
            'styles/fonts/{,*/}*.*'
          ]
        }, {
          expand: true,
          cwd: '.tmp/images',
          dest: '<%= yeoman.dist %>/images',
          src: ['generated/*']
        },{
          expand: true,
          cwd: '.tmp/scripts',
          dest: '<%= yeoman.dist %>/scripts',
          src: ['<%= yeoman.app %>/scripts/{,*/}*.js']
        }, {
          expand: true,
          cwd: 'bower_components/bootstrap/dist',
          src: 'fonts/*',
          dest: '<%= yeoman.dist %>'
        }]
      },
      styles: {
        expand: true,
        cwd: '<%= yeoman.app %>/styles',
        dest: '.tmp/styles/',
        src: '{,*/}*.css'
      }
    },

useminPrepare: {
      html: '<%= yeoman.app %>/index.html',
      options: {
        dest: '<%= yeoman.dist %>',
        flow: {
          html: {
            steps: {
              js: ['uglifyjs'],
              css: ['cssmin']
            },
            post: {}
          }
        }
      }
    },

  grunt.registerTask('build', [
    'clean:dist',
    'wiredep',
    'useminPrepare',
    'postcss',
    'ngtemplates',
    'ngAnnotate',
    'copy:dist',
    'cdnify',
    'cssmin',
    'uglify',
    'filerev',
    'usemin',
    'htmlmin'
  ]);

但仍然给我 concat scripts uglify 的输出。

最佳答案

创建您自己的任务,女巫将运行 ngAnnotate,然后运行 ​​uglify 和 cssmin 以缩小 css。

您还可以指定要在 grunt.initConfig 上进行丑化和注释的 js 文件:

ngAnnotate : {
    dist: {
        files: {
            '.tmp/scripts/MYFILE.min.js' : ['app/scripts/MYFILE.js'],
             /*...*/

它是一个较低版本,更加静态的 grunt 构建,但它会对您的项目进行缩小和注释。

关于javascript - 如何在 grunt build 中跳过 concat,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42622858/

相关文章:

javascript - 无法读取未定义的 Three.js 的属性 'material'

javascript - Angular 2 RC1 - 找不到默认 socket

angularjs - Karma,测试没有运行

javascript - 如何将数据从隔离作用域传递到父作用域?

coffeescript - 使用 grunt 编译 coffeescript 文件

javascript - 获取所有刻度值 (NVD3)

javascript - SharePoint 2013 客户端上下文 : How to DELETE specific list items by MULTIPLE CONDITION filter?

node.js - 如何解决安装 grunt-contrib-uglify 的错误

javascript - 如何更新 React 状态中的单个属性(函数组件)

gruntjs - 如何在动态更改配置中的数据时在 for 循环中运行 grunt 任务?