Meteor 學(xué)習(xí)筆記

什么是Meteor?

Meteor是高性能Javascript全端開(kāi)發(fā)框架
優(yōu)勢(shì):

  • Javascript 全平臺(tái)單一語(yǔ)言開(kāi)發(fā)
  • 跨平臺(tái)開(kāi)發(fā) iOS Android Browser Mobile
  • 熱部署
  • 前后端可以同時(shí)操作數(shù)據(jù)庫(kù)
  • 實(shí)時(shí)系統(tǒng)
  • 代碼壓縮混淆部署都由Meteor透明完成
  • 可以使用npm擴(kuò)展

Meteor Collections(數(shù)據(jù)庫(kù) Mongodb)

每個(gè)Collections對(duì)應(yīng)MongoDB的一個(gè)表
Create

Languages=new Mongo.Collection('languages');

增刪改查

Languages.insert({})
Languages.find({})
Languages.remove({})
Languages.update()

html,css,js

Meteor規(guī)定,在一個(gè)模板文件里,只能出現(xiàn)三種頂層標(biāo)簽:head褒傅、bodytemplate。css樣式最終也會(huì)合并后呈現(xiàn)給用戶.
最終, Meteor會(huì)編譯合并后呈現(xiàn)給用戶.

模板語(yǔ)言
{{spacebars}} 基于流行的handlebars,{{> hello}}模板標(biāo)簽用來(lái)調(diào)用一個(gè)子模板

加載順序

  • 應(yīng)用程序根目錄下的 lib 目錄里的文件最先加載懦铺。
  • 然后是所有文件名匹配 main.* 的文件。
  • 子目錄里的文件在父目錄之前加載支鸡,所以先加載最深層的文件冬念,根目錄下的文件最后加載。
  • 在一個(gè)目錄中苍匆,文件按照文件名的字母順序加載刘急。

目錄結(jié)構(gòu)

  • client 參與打包的前端代碼文件夾, 相當(dāng)與使用if(Meter.isClient){...}進(jìn)行前端代碼隔離的效果
  • server 參與打包的后端代碼文件夾, 相當(dāng)與使用if(Meter.isServer){...}進(jìn)行后端代碼隔離的效果, 敏感代碼(如身份驗(yàn)證)放在此目錄
  • public 不參與打包的前端資源文件夾,相當(dāng)于http虛擬根目錄
  • client/compatibility 不參與打包的前端兼容庫(kù)目錄, 全局var變量,會(huì)在其他前端JavaScript文件之前執(zhí)行
  • test 僅用于測(cè)試,前后端都不會(huì)使用

Meteor 函數(shù)

helper

<template name="test">
  <h1>Hello,{{displayName "Jason" "Mr."}}!</h1>
</template>
//JS聲明如下
Template.test.helpers({
  'displayName' : function(name,title){
    return title + ' ' + name;
  }
});

// 渲染后

<h1>Hello,Mr. Jason!</h1>

Meteor.flush 使DOM立刻更新
Meteor.render 渲染HTML
preserve 指定模板重新渲染后保留的元素

Meteor 安全

封裝直接操作數(shù)據(jù)庫(kù)操作方法
meteor remove insecure

Meteor.methods({
    // 增刪改查
    // 權(quán)限驗(yàn)證
    method_name:function(...args){},...
});
Meteor.call('method_name',..args);

禁用自動(dòng)發(fā)布
meteor remove autopublish

if (Meteor.isServer) {
  Meteor.publish("tasks", function () {
    return Tasks.find();
  });
}
 
if (Meteor.isClient) {
  Meteor.subscribe("tasks");
}

Meteor 部署

meteor deploy
支持自定義域名, 可以操作服務(wù)器上的mongodb
自定義部署 meteor-up

$ meteor #1 先保證應(yīng)用是可以執(zhí)行運(yùn)行的
$ meteor build --directory ../rel # 構(gòu)建 Node.js 項(xiàng)目
$ cd  ../rel/bundle

# 該目錄下 README 有詳細(xì)的介紹
$ (cd programs/server && npm install)
$ export MONGO_URL='mongodb://user:password@host:port/databasename'
$ export ROOT_URL='http://example.com'
$ export MAIL_URL='smtp://user:password@mailhost:port/'
$ export PORT=3000 # 默認(rèn) 80
$ node main.js

F&Q

如何使用npm package?

請(qǐng)?jiān)?a target="_blank" rel="nofollow">AtmosphereJS上搜索有無(wú)相關(guān)的封裝包。盡量采用已有的封裝包浸踩,而不是自己封裝叔汁。

有兩種方法在項(xiàng)目中使用來(lái)自npm的模塊。

  1. 封裝為Meteor包并在項(xiàng)目中添加包检碗。使用meteor create 包名 --package來(lái)創(chuàng)建包据块,并通過(guò)將包目錄放置于項(xiàng)目的packages文件夾等方法向項(xiàng)目引入包。包中使用Npm.dependsNpm.require來(lái)引入npm模塊折剃。Meteor文檔-包中引入Npm模塊 http://cmeteor.org/t/meteor-npm/31
  2. 使用meteorhacks:npm另假。meteorhacks:npm @ AtmosphereJS

如何使用Cordova插件?

一般在 http://plugins.cordova.io 上搜索插件包時(shí)就會(huì)提供插件包的全名和版本號(hào)怕犁。

meteor add cordova:org.apache.cordova.media@0.2.16

注意包名前要加cordova: 包名后要加@版本號(hào)

如何在一個(gè)域名下使用多個(gè)的APP?

Meteor的localstorage package存儲(chǔ)代碼:

if (key === retrieved) {
  Meteor._localStorage = {
    getItem: function (key) {
      return window.localStorage.getItem(key);
    },
    setItem: function (key, value) {
      window.localStorage.setItem(key, value);
    },
    removeItem: function (key) {
      window.localStorage.removeItem(key);
    }
  };
}

這樣會(huì)導(dǎo)致app1和app2的value被覆蓋
改成:

if (key === retrieved) {
  var path = window.location.pathname.replace(/^\/([^\/]*).*$/, '$1') + '.';
  Meteor._localStorage = {
    getItem: function (key) {
      return window.localStorage.getItem(path + key);
    },
    setItem: function (key, value) {
      window.localStorage.setItem(path + key, value);
    },
    removeItem: function (key) {
      window.localStorage.removeItem(path + key);
    }
  };
}

則最終 www.example.com/app1 & www.example.com/app2value

app1.Meteor.userId
app1.Meteor.loginToken
app1.Meteor.loginTokenExpires
app2.Meteor.userId
app2.Meteor.loginToken
app2.Meteor.loginTokenExpires

觸發(fā)界面更新的reactive數(shù)據(jù)源有哪些?reactive上下文運(yùn)行的函數(shù)有哪些?

Meteor函數(shù)會(huì)在reactive上下文中運(yùn)行你的代碼:

  • Templates
  • Meteor.render 和 Meteor.renderList
  • Meteor.autosubscribe
  • Meteor.autorun

能夠觸發(fā)變化的reactive數(shù)據(jù)源:

  • Session variables
  • Database queries on Collections
  • Meteor.status
  • Meteor.user
  • Meteor.userId
  • Meteor.loggingIn
    可以用Meteor.deps模塊“勾入”到上下文中边篮,以增加新的reactive上下文和數(shù)據(jù)源己莺。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市戈轿,隨后出現(xiàn)的幾起案子凌受,更是在濱河造成了極大的恐慌,老刑警劉巖思杯,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件胜蛉,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡色乾,警方通過(guò)查閱死者的電腦和手機(jī)誊册,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)暖璧,“玉大人案怯,你說(shuō)我怎么就攤上這事∨彀欤” “怎么了殴泰?”我有些...
    開(kāi)封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)浮驳。 經(jīng)常有香客問(wèn)我,道長(zhǎng)捞魁,這世上最難降的妖魔是什么至会? 我笑而不...
    開(kāi)封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮谱俭,結(jié)果婚禮上奉件,老公的妹妹穿的比我還像新娘。我一直安慰自己昆著,他們只是感情好县貌,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著凑懂,像睡著了一般煤痕。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上接谨,一...
    開(kāi)封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天摆碉,我揣著相機(jī)與錄音,去河邊找鬼脓豪。 笑死巷帝,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的扫夜。 我是一名探鬼主播楞泼,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼驰徊,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了堕阔?” 一聲冷哼從身側(cè)響起棍厂,我...
    開(kāi)封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎印蔬,沒(méi)想到半個(gè)月后勋桶,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡侥猬,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年例驹,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片退唠。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡鹃锈,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出瞧预,到底是詐尸還是另有隱情屎债,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布垢油,位于F島的核電站盆驹,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏滩愁。R本人自食惡果不足惜躯喇,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望硝枉。 院中可真熱鬧廉丽,春花似錦、人聲如沸妻味。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)责球。三九已至焦履,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間棕诵,已是汗流浹背裁良。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留校套,地道東北人价脾。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像笛匙,于是被迫代替她去往敵國(guó)和親侨把。 傳聞我的和親對(duì)象是個(gè)殘疾皇子犀变,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

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

  • Meteor是一個(gè)基于Nodejs+Websocket+MongoDB的Web應(yīng)用程序開(kāi)發(fā)平臺(tái)。Metror的七個(gè)...
    IT小C閱讀 5,577評(píng)論 2 9
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,107評(píng)論 25 707
  • JavaScript 模塊化編程 網(wǎng)站越來(lái)越復(fù)雜秋柄,js代碼获枝、js文件也越來(lái)越多,會(huì)遇到什么問(wèn)題骇笔? 命名沖突省店; 文件...
    magic_pill閱讀 1,423評(píng)論 0 1
  • 為什么要調(diào)用系統(tǒng)相冊(cè) 現(xiàn)在很多項(xiàng)目都會(huì)用到調(diào)用系統(tǒng)相冊(cè),例如保存圖片到系統(tǒng)相冊(cè)懦傍、選取相冊(cè)中的圖片、給聯(lián)系人設(shè)置頭像...
    朱凱奇閱讀 9,589評(píng)論 5 41
  • 文/小木同學(xué) Z是我在校外補(bǔ)習(xí)班認(rèn)識(shí)的一個(gè)男生芦劣,一個(gè)來(lái)自中南湘雅醫(yī)學(xué)院的男生粗俱。 Z的身材高挑,長(zhǎng)得俊朗清秀虚吟,特別是...
    Henry_z閱讀 2,918評(píng)論 2 0