2016-09-14 1 views
2

Я использую Grunt с php и использую пакет для версии my css с отметкой даты как style.min.20160913230349.css.Номера версий CSS с Grunt

Как найти пакет, который будет обновлять новую строку в заголовке на моей странице php. style.min.{grunt_this_string}.css.

Я ищу себе usemin, но не вижу, как я мог его реализовать.

<link rel="stylesheet" media="all" href="/css/style.min.20160913230349.css" type="text/css"/> 

Gruntfile.js

module.exports = function (grunt) { 


    grunt.initConfig({ 


    /*============================================= 
    =   Proxy server     = 
    =============================================*/ 
    php: { 
     dist: { 
     options: { 
      hostname: 'sau.dev', 
      base: 'website-v2', // Project root 
      keepalive: false, 
      open: false 
     } 
     } 
    }, 

    browserSync: { 
     dev: { 
     bsFiles: { 
      src: [ 
      'website-v2/*.php', 
      'website-v2/*/*.php', 
      'website-v2/css/*.css' 
      ] 
     }, 
     options: { 
      proxy: 'sau.dev',//<%= php.dist.options.hostname %>:<%= php.dist.options.port %> 
       ghostMode: { 
        clicks: false, 
        forms: false, 
        scroll: true 
       }, 
       logLevel: 'info',//client 
       logConnections: true, 
       watchTask: true, 
       open: 'ui', 
       xip: true, 
     } 
     } 
    }, 

    watch: { 
     html: { 
      files: ['src/*.html'], 
     } 
    }, 

    cssmin: { 
     dist: { 
      files: { 
      'website-v2/css/style.min.css': ['website-v2/css/all.css'] 
      } 
     } 
    }, 

    uglify: { 
     dist: { 
     files: { 
      'website-v2/js/main.min.js': ['website-v2/js/jquery-  1.9.1.min.js','jquery-ui.min.js','main.js','featherlight.js'] 
     } 
     } 
    }, 

    assets_versioning: { 
     options: { 
     tag: 'date', 
     dateFormat: 'YYYYMMDDHH', 
     timezoneOffset: 10 
     }, 
     dist: { 
     options: { 
      tasks: ['cssmin:dist'] 
     } 
     }, 
    }, 

    }); 

    //grunt.loadNpmTasks('grunt-contrib-sass'); 
    grunt.loadNpmTasks('grunt-contrib-watch'); 
    grunt.loadNpmTasks('grunt-browser-sync'); 
    grunt.loadNpmTasks('grunt-php'); 
    grunt.loadNpmTasks('grunt-assets-versioning'); 
    grunt.loadNpmTasks('grunt-contrib-cssmin'); 
    grunt.loadNpmTasks('grunt-string-replace'); 

    //grunt.loadNpmTasks('usemin'); 



    //Static Server 
    grunt.registerTask('dist', ['versioning']); 

    //Proxy Server 
    grunt.registerTask('server', ['php:dist','browserSync','watch']); 
}; 
+0

Не могли бы вы предоставить мне «gruntfile.js»? – slorenzo

+0

Вы пытались использовать файлы: {'website-v2/css/style.min.css': ['website-v2/css/all.css']} 'и' grunt.registerTask ('dist', [' cssmin: dist ',' assets_versioning ']); '? Как https://www.npmjs.com/package/grunt-assets-versioning#versioning-using-a-date – slorenzo

+0

Я могу использовать их правильно, но мне нужно обновить мою ссылку в тегах , чтобы динамически обновлять и ссылаться на новый файл и имя пути – ottz0

ответ

1

После понять вашу проблему, я думаю, что вам нужно, чтобы создать assets.map

Вы должны добавить это в gruntfile.js.

options: { 
    ... 
    versionsMapFile: 'assets.json', 
    ... 
} 

Я хотел бы верить, что grunt-assets-versioning создать версию взятой дату.

Вам необходимо заменить в html версией, которая предоставляет assest.json. Я рекомендую использовать для этого grunt-string-replace.

replace: { 
    dist: { 
    options: { 
     patterns: [ 
     { 
      match: 'style.min.css', 
      replacement: replacement() 
     } 
     ] 
    }, 
    files: [ 
     {src: ['src/assets/index.html'], dest: 'build/index.html'} 
    ] 
    } 
} 

... 

grunt.registerTask('versioning', ['assets_versioning']); 
grunt.registerTask('replace', ['string-replace'] 

... 

function replacements() { 
    var projectFile = "assets.json"; 

    if (!grunt.file.exists(projectFile)) { 
     grunt.log.error("file " + projectFile + " not found"); 
     return true;//return false to abort the execution 
    } 
    var project = grunt.file.readJSON(projectFile);//get file as json object 
    var version = project[0].version; 
    var replace = '' 

    // continue with the algorithm that you need 

    return replace; 
} 

Я надеюсь, что это поможет.

+0

Я думаю, что вы поставили меня в правильном направлении – ottz0