發(fā)布 ReactNative 組件到 NPM

原文地址:http://liu-hang.cn/2019/06/25/189-publish-react-native-component-to-npm/

截屏捕捉組件

npm i react-native-screenshotcatch

背景

前一段時間寫的 react-native 截屏監(jiān)聽功能是直接寫進項目中的缘回,現(xiàn)在打算將其單獨封裝發(fā)布到 NPM 上去瑟曲,之前也發(fā)過一個命令行工具但是沒有寫文記錄一下過程与境,這次補上

實現(xiàn)

使用 react-native-create-library

react-native-create-library 是一個自定義組件模板工具琼了,比自己去創(chuàng)建省很多麻煩

npm i -g react-native-create-library # 安裝
react-native-create-library --package-identifier com.dreamser.screenshotcatch --platforms android,ios screenshotcatch
mv screenshotcatch react-native-screenshotcatch

更新 build.gradle

react-native-create-library 中的依賴版本太低,需要更新一下

編寫代碼

請見 React Native 實現(xiàn)截圖添加二維碼分享功能

完善 readme

react-native-create-library 已經(jīng)為你準備了基礎的模板,具體內容需要自己來添加

上傳 github

初始化本地repo授艰,在github創(chuàng)建遠程repo,連接世落,上傳代碼...在這里不做贅述

完善 package.json

package.json文件定義了發(fā)布的所有信息淮腾,包括:組件名、版本屉佳、作者谷朝、描述、依賴等等關鍵信息武花。具體可以參照 Creating a package.json file


{
  "name": "react-native-screenshotcatch",
  "version": "0.0.1",
  "description": "A ReactNative Tool for catch Screen Shot Event",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [
    "react-native",
    "screen-shot",
    "screen-capture",
    "ios",
    "android"
  ],
  "author": {
    "name": "callcter",
    "email": "sharpliuzigu@gmail.com"
  },
  "license": "MIT",
  "repository": {
    "type": "git",
    "url": "git@github.com:callcter/react-native-screenshotcatch.git"
  },
  "peerDependencies": {
    "react-native": "^0.41.2"
  }
}

發(fā)布到 NPM

npm adduser # 創(chuàng)建 NPM 賬號
npm login # 如果已經(jīng)在官網(wǎng)有賬號圆凰,可以直接登錄
npm whoami # 查看登錄狀態(tài)
npm publish # 發(fā)布

發(fā)布時可能遇到 publish Failed PUT 403 錯誤,原因是更改了鏡像源

npm config get registry # 查看當前鏡像源
npm config set registry=http://registry.npmjs.org # 更改回官方鏡像源
npm publish # 重新發(fā)布

NPM 更新

npm 提供官方提供了npm version來進行版本控制体箕,其效果跟手動修改package.json里面的version字段是一樣的专钉,好處在于,可以在構建過程中用npm version命令自動修改累铅,而且具有語義化即Semantic versioning

npm version [<newversion> | major | minor | patch | premajor | preminor | 
prepatch | prerelease | from-git]

語義為:

major:主版本號(大版本)
minor:次版本號(小更新)
patch:補丁號(補对拘搿)
premajor:預備主版本
preminor: 預備次版本
prepatch:預備補丁版本
prerelease:預發(fā)布版本

參考文章

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末菇民,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子投储,更是在濱河造成了極大的恐慌第练,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件轻要,死亡現(xiàn)場離奇詭異,居然都是意外死亡垦缅,警方通過查閱死者的電腦和手機冲泥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來壁涎,“玉大人凡恍,你說我怎么就攤上這事≌颍” “怎么了嚼酝?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長竟坛。 經(jīng)常有香客問我闽巩,道長钧舌,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任涎跨,我火速辦了婚禮洼冻,結果婚禮上,老公的妹妹穿的比我還像新娘隅很。我一直安慰自己撞牢,他們只是感情好,可當我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布叔营。 她就那樣靜靜地躺著屋彪,像睡著了一般。 火紅的嫁衣襯著肌膚如雪绒尊。 梳的紋絲不亂的頭發(fā)上畜挥,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機與錄音垒酬,去河邊找鬼砰嘁。 笑死,一個胖子當著我的面吹牛勘究,可吹牛的內容都是我干的矮湘。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼口糕,長吁一口氣:“原來是場噩夢啊……” “哼缅阳!你這毒婦竟也來了?” 一聲冷哼從身側響起景描,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤十办,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后超棺,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體向族,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年棠绘,在試婚紗的時候發(fā)現(xiàn)自己被綠了件相。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡氧苍,死狀恐怖夜矗,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情让虐,我是刑警寧澤紊撕,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站赡突,受9級特大地震影響对扶,放射性物質發(fā)生泄漏区赵。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一辩稽、第九天 我趴在偏房一處隱蔽的房頂上張望惧笛。 院中可真熱鬧,春花似錦逞泄、人聲如沸患整。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽各谚。三九已至,卻和暖如春到千,著一層夾襖步出監(jiān)牢的瞬間昌渤,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工憔四, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留膀息,地道東北人。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓了赵,卻偏偏與公主長得像潜支,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子柿汛,可洞房花燭夜當晚...
    茶點故事閱讀 45,044評論 2 355

推薦閱讀更多精彩內容