web-dev-qa-db-fra.com

npm avec node-sass et autoprefixer

J'utilise node-sass pour compiler tous mes fichiers Sass en master.css . Cela fonctionne bien, mais je souhaite maintenant ajouter des préfixes. Je voudrais utiliser uniquement le npm, pas Gulp ou Grunt.

Voici mon fichier package.json:

{
  "name": "xxxxxx.com",
  "version": "1.0.0",
  "description": "",
  "watches": {
    "sass": "src/scss/**"
  },
  "scripts": {
    "sass": "node-sass src/scss/master.scss -o dist/css/ --style compressed",
    "prefix": "postcss --use autoprefixer dist/css/master.css -d dist/css/master.css",
    "dev": "rerun-script"
  },
  "author": "Jan",
  "license": "ISC",
  "devDependencies": {
    "autoprefixer": "^6.3.1",
    "browserify": "^13.0.0",
    "clean-css": "^3.4.9",
    "node-sass": "^3.4.2",
    "postcss-cli": "^2.5.0",
    "rerun-script": "^0.6.0",
    "uglifyjs": "^2.4.10"
  }
}

Je ne le fais pas courir. J'utilise autoprefixer et postcss-cli. Les modules ont été installés localement dans le répertoire du projet. Je pense que ma partie "script" est fausse .

12
user3852555
 {
    "name": "npm-node-sass",
    "version": "0.0.1",
    "devDependencies": {
        "autoprefixer": "^6.3.3",
        "browserify": "^13.0.0",
        "cssnano": "^3.5.2",
        "jshint": "^2.9.1",
        "node-sass": "^3.4.2",
        "postcss": "^5.0.16",
        "postcss-cli": "^2.5.1",
        "watch": "^0.17.1"
    },
    "scripts": {
        "prebuild:css": "node-sass --include-path scss src/sass/styles.scss    public/css/styles.css",
        "build:css": "postcss --use autoprefixer -b 'last 2 versions' < public/css/styles.css | postcss --use cssnano > public/css/styles.min.css",
        "lint": "jshint src/js/*.js",
        "build:js": "browserify src/js/main.js > public/js/bundle.js",
        "build": "npm run build:css && npm run build:js",
        "prebuild:js": "npm run lint",
        "build:watch": "watch 'npm run build' src/*"
    }
}

Vous avez besoin de postcss et postcss-cli en tant que développeur.

23
Maurice van Cooten

Disons que nous avons styles.sass fichier dans sass répertoire. J'ai utilisé quelque chose comme ceci (mon package.json):

{
 "scripts": {
    "c":"node-sass sass/styles.sass -o .|postcss styles.css -u autoprefixer -r",
    "w":"watch 'npm run c' sass"
 }
}   

commande du terminal: npm run w. À ce stade, chaque enregistrement de styles.sass fichier produira automatiquement le fichier styles.css compilé et préfixé. J'ai des paquets postcss-cli, node-sass et watch installés globalement.

1
daGo