微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – Grunt usemin filerev没有用rev’ed版本替换图像标签

我是咕噜咕噜咕噜咕噜咕噜咕噜咕噜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜呜

这是我的grunt构建的输出

我的一个观点中有这个html标记

< img src =“img / logo.png”alt =“logo”/>

但它在grunt构建之后不起作用,因为它没有被rev’ed版本取代.我是否需要在这周围添加那些usemin注释块我需要更新我的gruntfile来处理这个?

完整的Gruntfile.js

// Generated on 2014-10-29 using generator-angular 0.9.8
'use strict';

var pkg = require('./package.json');

// # Globbing
// for performance reasons we're only matching one level down:
// 'test/spec/{,*/}*.js'
// use this if you want to recursively match all subfolders:
// 'test/spec/**/*.js'

module.exports = function (grunt) {

  // Load grunt tasks automatically
  require('load-grunt-tasks')(grunt);

  // Time how long tasks take. Can help when optimizing build times
  require('time-grunt')(grunt);

  // Configurable paths for the application
  var appConfig = {
    //app: require('./bower.json').appPath || 'app',app: __dirname,dist: 'dist'
  };

  // Define the configuration for all the tasks
  grunt.initConfig({

    // Project settings
    yeoman: appConfig,// Watches files for changes and runs tasks based on the changed files
    watch: {
      bower: {
        files: ['bower.json'],tasks: ['wiredep']
      },js: {
        files: ['<%= yeoman.app %>/scripts/{,*/}*.js','<%= yeoman.app %>/controllers/{,'<%= yeoman.app %>/factories/{,'<%= yeoman.app %>/filters/{,'<%= yeoman.app %>/js/{,*/}*.js'],tasks: ['newer:jshint:all'],options: {
          livereload: '<%= connect.options.livereload %>'
        }
      },jsTest: {
        files: ['test/spec/{,tasks: ['newer:jshint:test','karma']
      },styles: {
        files: ['<%= yeoman.app %>/styles/{,*/}*.css'],tasks: ['newer:copy:styles','autoprefixer']
      },gruntfile: {
        files: ['Gruntfile.js']
      },livereload: {
        options: {
          livereload: '<%= connect.options.livereload %>'
        },files: [
          '<%= yeoman.app %>/{,*/}*.html','.tmp/styles/{,*/}*.css','<%= yeoman.app %>/img/{,*/}*.{png,jpg,jpeg,gif,webp,svg}'
        ]
      }
    },// The actual grunt server settings
    connect: {
      options: {
        port: 9000,// Change this to '0.0.0.0' to access the server from outside.
        hostname: 'localhost',livereload: 35729
      },livereload: {
        options: {
          open: true,middleware: function (connect) {
            return [
              connect.static('.tmp'),connect().use(
                '/bower_components',connect.static('./bower_components')
              ),connect.static(appConfig.app)
            ];
          }
        }
      },test: {
        options: {
          port: 9001,connect.static('test'),dist: {
        options: {
          open: true,base: '<%= yeoman.dist %>'
        }
      }
    },// Make sure code styles are up to par and there are no obvIoUs mistakes
    jshint: {
      options: {
        jshintrc: '.jshintrc',reporter: require('jshint-stylish')
      },all: {
        src: [
          'Gruntfile.js','<%= yeoman.app %>/scripts/{,*/}*.js'
        ]
      },test: {
        options: {
          jshintrc: 'test/.jshintrc'
        },src: ['test/spec/{,*/}*.js']
      }
    },// Empties folders to start fresh
    clean: {
      dist: {
        files: [{
          dot: true,src: [
            '.tmp','<%= yeoman.dist %>/{,*/}*','!<%= yeoman.dist %>/.git*'
          ]
        }]
      },server: '.tmp'
    },// Add vendor prefixed styles
    autoprefixer: {
      options: {
        browsers: ['last 1 version']
      },dist: {
        files: [{
          expand: true,cwd: '.tmp/styles/',src: '{,dest: '.tmp/styles/'
        }]
      }
    },// Automatically inject Bower components into the app
    wiredep: {
      app: {
        src: ['<%= yeoman.app %>/index.html'],ignorePath:  /\.\.\//
      }
    },// Renames files for browser caching purposes
    filerev: {
      dist: {
        src: [
          '<%= yeoman.dist %>/scripts/{,'<%= yeoman.dist %>/styles/{,'<%= yeoman.dist %>/img/{,svg}','<%= yeoman.dist %>/styles/fonts/*'
        ]
      }
    },// Reads HTML for usemin blocks to enable smart builds that automatically
    // concat,minify and revision files. Creates configurations in memory so
    // additional tasks can operate on them
    useminPrepare: {
      html: '<%= yeoman.app %>/index.html',options: {
        dest: '<%= yeoman.dist %>',flow: {
          html: {
            steps: {
              //js: ['concat','uglifyjs'],js: ['concat'],css: ['cssmin']
            },post: {}
          }
        }
      }
    },// Performs rewrites based on filerev and the useminPrepare configuration
    usemin: {
      html: ['<%= yeoman.dist %>/{,*/}*.html'],css: ['<%= yeoman.dist %>/styles/{,options: {
        assetsDirs: ['<%= yeoman.dist %>','<%= yeoman.dist %>/img']
      }
    },// The following *-min tasks will produce minified files in the dist folder
    // By default,your `index.html`'s <!-- Usemin block --> will take care of
    // minification. These next options are pre-configured if you do not wish
    // to use the Usemin blocks.
    // cssmin: {
    //   dist: {
    //     files: {
    //       '<%= yeoman.dist %>/styles/main.css': [
    //         '.tmp/styles/{,*/}*.css'
    //       ]
    //     }
    //   }
    // },// uglify: {
    //   dist: {
    //     files: {
    //       '<%= yeoman.dist %>/scripts/scripts.js': [
    //         '<%= yeoman.dist %>/scripts/scripts.js'
    //       ]
    //     }
    //   }
    // },// concat: {
    //   dist: {}
    // },imagemin: {
      dist: {
                options: { cache: false },files: [{
          expand: true,cwd: '<%= yeoman.app %>/img',*/}*.{jpg,png}',dest: '<%= yeoman.dist %>/img'
        }]
      }
    },svgmin: {
      dist: {
        files: [{
          expand: true,*/}*.svg',htmlmin: {
      dist: {
        options: {
          collapseWhitespace: true,conservativeCollapse: true,collapseBooleanAttributes: true,removeCommentsFromCDATA: true,removeOptionalTags: true
        },cwd: '<%= yeoman.dist %>',src: ['*.html','views/{,dest: '<%= yeoman.dist %>'
        }]
      }
    },// ng-annotate tries to make the code safe for minification automatically
    // by using the Angular long form for dependency injection.
    ngAnnotate: {
      dist: {
        files: [{
          expand: true,cwd: '.tmp/concat/scripts',src: ['*.js','!oldieshim.js'],dest: '.tmp/concat/scripts'
        }]
      }
    },// Replace Google CDN references
    cdnify: {
      dist: {
        html: ['<%= yeoman.dist %>/*.html']
      }
    },// copies remaining files to places other tasks can use
    copy: {
      dist: {
        files: [{
          expand: true,dot: true,cwd: '<%= yeoman.app %>',dest: '<%= yeoman.dist %>',src: [
            '*.{ico,png,txt}','.htaccess','*.html','img/{,*/}*.{webp}','font/*'
          ]
        },{
          expand: true,cwd: '.tmp/img',dest: '<%= yeoman.dist %>/img',src: ['generated/*']
        }]
      },styles: {
        expand: true,cwd: '<%= yeoman.app %>/styles',dest: '.tmp/styles/',*/}*.css'
       }
       //,// css: {
      //   expand: true,//   cwd: '<%= yeoman.app %>/css/compiled',//   dest: '.tmp/css/compiled/',//   src: '{,*/}*.css'
      // }
    },// Run some tasks in parallel to speed up the build process
    concurrent: {
      server: [
        'copy:styles'
      ],test: [
        'copy:styles'
      ],dist: [
        'copy:styles','imagemin','svgmin'
      ]
    },// Test settings
    karma: {
      unit: {
        configFile: 'test/karma.conf.js',singleRun: true
      }
    }
  });


  grunt.registerTask('serve','Compile then start a connect web server',function (target) {
    if (target === 'dist') {
      return grunt.task.run(['build','connect:dist:keepalive']);
    }

    grunt.task.run([
      'clean:server','wiredep','concurrent:server','autoprefixer','connect:livereload','watch'
    ]);
  });

  grunt.registerTask('test',[
    'clean:server','concurrent:test','connect:test','karma'
  ]);

  grunt.registerTask('build',[
    'clean:dist','useminPrepare',//'concurrent:dist','copy:styles',//'copy:css','svgmin','concat','ngAnnotate','copy:dist','cdnify','cssmin',//'uglify','filerev','usemin','htmlmin'
  ]);

  grunt.registerTask('default',[
    'newer:jshint','test','build'
  ]);
};

解决方法

我遇到了类似的问题,直到我意识到我的usemin配置有点错误.当前配置仅检查1级深度的html文件,这意味着如果您有views / folder / file.html,它将永远不会更新.相反,更改您的配置以使用0或更多glob,**.

html: ['<%= yeoman.dist %>/**/*.html']

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐