npm-npmscript-gulp-webpack

如何全局安裝一個 node 應用?

npm install -g xxx 會安裝在系統(tǒng)目錄下,安裝的package能夠在所有目錄下使用多律。

package.json 有什么作用伐庭?

  • 定義了這個項目所需要的各種模塊,以及項目的配置信息(比如名-
    稱漏策、版本、許可證等元數(shù)據(jù))
  • 允許你指定你項目中所使用的node包的版本臼氨。
  • 構(gòu)建你的項目更加容易掺喻,便于給其他人共享。

package.json包括以下基本配置

{
  "name": "demo", //package的名稱
  "version": "1.0.0",// 版本號
  "description": "",//項目描述
  "main": "index.js",//指定別人使用這個包的入口文件
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },  //
  "author": "",  //作者
  "license": "ISC"   //版權(quán)相關(guān)
}

可以使用npm init -y快速創(chuàng)建基本配置

npm install --save app 與 npm install --save-dev app有什么區(qū)別?

npm install --save app會把依賴包名稱添加到 package.json 文件 的dependencies 屬性下,記錄此包所依賴的其他包.

  1. 如果我們下載別人的包只要輸入--save,就會把別人包所依賴的包一起下載
  2. 如果我們自己在開發(fā)一個包供別人使用時只要輸入npm install --save app會把我們開發(fā)包所依賴的app添加到 package.json 文件 的dependencies 屬性下,
    記錄自己開發(fā)的包會依賴于app.我們上傳自己此包時就不需要上傳自己所依賴的包以節(jié)省空間加快速度.
    下次再需要用自己此包時只要輸入npm install自然就會把所依賴的包下載

npm install --save-dev app會把下載的包放在devDependencies(開發(fā)依賴) 的屬性下,是我們開發(fā)測試時用的.
別人要下載引用我們的包是不會把devDependencies所列出的包下載來的(有需要才手動下載).而會把dependencies下所列出的包下載來

node_modules的查找路徑是怎樣的?

從當前文件目錄開始查找node_modules目錄感耙;然后依次進入父目錄褂乍,查找父目錄下的node_modules目錄;依次迭代即硼,直到根目錄下的node_modules目錄逃片。

webpack是什么?和其他同類型工具比有什么優(yōu)勢只酥?

webpack 是一個現(xiàn)代 JavaScript 應用程序的模塊打包器(module bundler)褥实。當 webpack 處理應用程序時,它會遞歸地構(gòu)建一個依賴關(guān)系圖(dependency graph)裂允,其中包含應用程序需要的每個模塊损离,然后將所有這些模塊打包成少量的 bundle - 通常只有一個,由瀏覽器加載绝编。

優(yōu)勢:

  • webpack是以commonJS的形式來書寫腳本僻澎,但對AMD/CMD的支持也很全面
  • webpack可以將代碼拆分為多個區(qū)塊,每個區(qū)塊包含一個或多個模塊瓮增,它們可以按需異步加載怎棱,極大地減少了頁面初次加載時間
  • webpack本身只能處理原生JS模塊,但是loader轉(zhuǎn)換器可以將各種類型的資源轉(zhuǎn)換成JS模塊绷跑。這樣拳恋,任何資源都可以成為webpack可以處理的模塊
  • webpack有一個智能解析器,幾乎可以處理任何第三方庫砸捏,無論它們的模塊形式是commonJS,AMD還是普通的JS文件谬运。
  • webpack還有一個功能豐富的插件系統(tǒng)。大多數(shù)內(nèi)容功能都是基于這個插件系統(tǒng)運行的垦藏,還可以開發(fā)和使用開源的webpack插件梆暖,來滿足各種各樣的需求。
  • webpack使用異步I/O和多級緩存提高運行效率掂骏,使得它能夠快速增量編譯

npm script是什么轰驳?如何使用?

每個項目文件下一般都會有一個package.json文件,這個文件中會包含一個名為scripts的對象,由key-value形式組成
每個value都是一條可以直接在命令行中的命令,而key則對應其相應的value,只要在命令行中輸入key則會自動執(zhí)行所對應value的命令,以此實現(xiàn)對每個value命令的簡化,
只要記住其key值即可.(注意這里的key不是可以隨意書寫,有其自身規(guī)定的一系列名字,除了test和start之外其他的key需在前加上run)

e.g.
{
  // ...
  "scripts": {
    "build": "node build.js"
    "start":  "mkdir abc"
  }
}

上面代碼是package.json文件的一個片段弟灼,里面的scripts字段是一個對象级解。它的每一個屬性,對應一段腳本田绑。比如勤哗,build命令對應的腳本是node build.js。

命令行下使用npm run命令掩驱,就可以執(zhí)行這段腳本芒划。
$ npm run build
  等同于執(zhí)行
$ node build.js

$ npm start即執(zhí)行mkdir abc的命令,注意這里的start不需要寫run

使用 webpack 替換 入門-任務15中模塊化使用的 requriejs

code
demo

gulp是什么冬竟?使用 gulp 實現(xiàn)圖片壓縮、CSS 壓縮合并民逼、JS 壓縮合并

簡介

  • gulp是一款node.js的應用
  • 主要用于打造前端工作流,可用于打包,壓縮,合并等
  • 他有簡單易用,無快不破等特性
  • 他擁有很多高質(zhì)量的插件

gulp常用組件

  • gulp-minify-css //css壓縮
  • gulp-uglify //js壓縮
  • gulp-concat //合并文件
  • gulp-rename // 重命名
  • gulp-clean //清空文件夾
  • gulp-htmlmin //html壓縮
  • gulp-jshint //js代碼規(guī)范性檢查
  • gulp-imagemin //圖片壓縮

用 gulp 實現(xiàn)圖片壓縮泵殴、CSS 壓縮合并、JS 壓縮合并

具體demo詳見gulp-test
var gulp = require('gulp');            //依賴gulp
var minhtml = require("gulp-htmlmin"),
    cssnano =require('gulp-cssnano'),
    concat = require('gulp-concat'),
    uglify = require('gulp-uglify'),
    imagemin = require('gulp-imagemin');
                                       //gulp組件
gulp.task('html',function(){
  return gulp.src('./src/*.html')
  .pipe(minhtml({collapseWhitespace: true}))
  .pipe(gulp.dest('./disc'))
})                                        //html壓縮
gulp.task('css',function(){
  return gulp.src('./src/css/style.css')
  .pipe(concat('merge.min.css'))
  .pipe(cssnano())
  .pipe(gulp.dest('./disc/css'));
})                                        //css壓縮合并
gulp.task('compress', function (cb) {
     return gulp.src('./src/js/*.js')
      .pipe(concat('merge.min.js'))
      .pipe(uglify())
      .pipe(gulp.dest('./disc/js'));
 });                                       //js壓縮合并
gulp.task('img', function(){
gulp.src('./src/img/*')
    .pipe(imagemin())
    .pipe(gulp.dest('./disc/img'))
});                                         //圖片壓縮
gulp.task('build',['html','css','compress','img']);

開發(fā)一個 node 命令行天氣應用用于查詢用戶當前所在城市的天氣缴挖,發(fā)布到 npm 上去袋狞》俑ǎ可以通過如下方式安裝使用(可使用api.jirengu.com里提供的查詢天氣接口) (選做題目)

node天氣應用

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末映屋,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子同蜻,更是在濱河造成了極大的恐慌棚点,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,376評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件湾蔓,死亡現(xiàn)場離奇詭異瘫析,居然都是意外死亡,警方通過查閱死者的電腦和手機默责,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評論 2 385
  • 文/潘曉璐 我一進店門贬循,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人桃序,你說我怎么就攤上這事杖虾。” “怎么了媒熊?”我有些...
    開封第一講書人閱讀 156,966評論 0 347
  • 文/不壞的土叔 我叫張陵奇适,是天一觀的道長。 經(jīng)常有香客問我芦鳍,道長嚷往,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,432評論 1 283
  • 正文 為了忘掉前任柠衅,我火速辦了婚禮皮仁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘菲宴。我一直安慰自己贷祈,他們只是感情好,可當我...
    茶點故事閱讀 65,519評論 6 385
  • 文/花漫 我一把揭開白布裙顽。 她就那樣靜靜地躺著付燥,像睡著了一般。 火紅的嫁衣襯著肌膚如雪愈犹。 梳的紋絲不亂的頭發(fā)上键科,一...
    開封第一講書人閱讀 49,792評論 1 290
  • 那天闻丑,我揣著相機與錄音,去河邊找鬼勋颖。 笑死嗦嗡,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的饭玲。 我是一名探鬼主播侥祭,決...
    沈念sama閱讀 38,933評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼茄厘!你這毒婦竟也來了矮冬?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,701評論 0 266
  • 序言:老撾萬榮一對情侶失蹤次哈,失蹤者是張志新(化名)和其女友劉穎胎署,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體窑滞,經(jīng)...
    沈念sama閱讀 44,143評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡琼牧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,488評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了哀卫。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片巨坊。...
    茶點故事閱讀 38,626評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖此改,靈堂內(nèi)的尸體忽然破棺而出趾撵,到底是詐尸還是另有隱情,我是刑警寧澤带斑,帶...
    沈念sama閱讀 34,292評論 4 329
  • 正文 年R本政府宣布鼓寺,位于F島的核電站,受9級特大地震影響勋磕,放射性物質(zhì)發(fā)生泄漏妈候。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,896評論 3 313
  • 文/蒙蒙 一挂滓、第九天 我趴在偏房一處隱蔽的房頂上張望苦银。 院中可真熱鬧,春花似錦赶站、人聲如沸幔虏。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽想括。三九已至,卻和暖如春烙博,著一層夾襖步出監(jiān)牢的瞬間瑟蜈,已是汗流浹背烟逊。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留铺根,地道東北人宪躯。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像位迂,于是被迫代替她去往敵國和親访雪。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,494評論 2 348

推薦閱讀更多精彩內(nèi)容