Meteor

来自开放百科 - 灰狐
(版本间的差异)
跳转到: 导航, 搜索
(DDP)
(简介)
 
(未显示1个用户的49个中间版本)
第4行: 第4行:
  
 
[[node.js ecosystem|Node.js, Meteor, React.js, AngularJS, JavaScript 和 HTML5 生态系统]]
 
[[node.js ecosystem|Node.js, Meteor, React.js, AngularJS, JavaScript 和 HTML5 生态系统]]
 +
 +
==简介==
 +
Meteor 基于 [[Node.js]] 构建,Node.js 是所有 Meteor 应用的服务器引擎,Meteor 深度整合 [[MongoDB]],通过 [[Apache_Cordova]] 支持移动端应用,MIT 许可协议。
 +
 +
[https://forge.huihoo.com/news/1545 Meteor JavaScript 全栈框架]
  
 
==版本==
 
==版本==
 +
*[https://blog.meteor.com/announcing-meteor-1-6-abf30f29e2c6 Announcing Meteor 1.6]
 +
*[https://blog.meteor.com/announcing-meteor-1-5-b82be66571bb Announcing Meteor 1.5]
 
*1.4, Meteor 1.4 will come with Node 4.4.x and Mongo 3.2
 
*1.4, Meteor 1.4 will come with Node 4.4.x and Mongo 3.2
*1.3  
+
*1.3, Meteor 1.3 support for ES2015 modules
 
*1.2
 
*1.2
  
第20行: 第27行:
 
  http://localhost:3000/
 
  http://localhost:3000/
 
  meteor deploy try-meteor.meteor.com
 
  meteor deploy try-meteor.meteor.com
 +
 +
服务端Shell
 +
$ meteor shell
 +
 +
Mongo Shell
 +
$ meteor mongo
 +
升级
 +
$ meteor update
 +
$ meteor update --all-packages
  
 
==术语表==
 
==术语表==
第64行: 第80行:
  
 
==Package==
 
==Package==
 +
[https://atmospherejs.com/ Atmosphere] is the catalog for Meteor packages, resources and tools.
 +
 
[http://zh.discovermeteor.com/chapters/getting-started/ Meteor 中的代码包有点特殊],分为五种:
 
[http://zh.discovermeteor.com/chapters/getting-started/ Meteor 中的代码包有点特殊],分为五种:
 
*Meteor 核心代码本身分成多个核心代码包(core package),每个 Meteor 应用中都包含,你基本上不需要花费精力来维护它们
 
*Meteor 核心代码本身分成多个核心代码包(core package),每个 Meteor 应用中都包含,你基本上不需要花费精力来维护它们
第84行: 第102行:
  
 
更多细节:[https://atmospherejs.com/ian/accounts-ui-bootstrap-3 meteor-accounts-ui-bootstrap-3]
 
更多细节:[https://atmospherejs.com/ian/accounts-ui-bootstrap-3 meteor-accounts-ui-bootstrap-3]
 +
 +
==模版==
 +
*[http://zh.discovermeteor.com/chapters/templates/ 了解 Meteor 模版系统]
 +
*[https://github.com/meteor/meteor/tree/devel/packages/spacebars Spacebars 模版语言]
 +
*[https://github.com/meteor/meteor/tree/devel/packages/spacebars-compiler Spacebars 编译器]
 +
*[https://guide.meteor.com/blaze.html Blaze 前端渲染系统]
 +
*[https://github.com/meteor/meteor/tree/master/packages/blaze Blaze 包] [https://github.com/meteor/meteor/tree/devel/packages/templating Templating  包] [https://github.com/meteor/meteor/tree/devel/packages/templating-tools templating-tools 包]
  
 
==例子==
 
==例子==
第96行: 第121行:
 
[[image:angular-meteor-ionic-whatsapp.png]] [http://www.angular-meteor.com/tutorials/whatsapp/ 更多细节>>>]
 
[[image:angular-meteor-ionic-whatsapp.png]] [http://www.angular-meteor.com/tutorials/whatsapp/ 更多细节>>>]
  
==用户系统==
+
==账户系统==
 
用户体系、身份认证、允许拒绝、第三方登录
 
用户体系、身份认证、允许拒绝、第三方登录
 +
 +
[https://github.com/meteor/meteor/tree/master/packages/accounts-base accounts-base]  Meteor用户账户系统包含以下包:
 +
*accounts-password [https://github.com/meteor/meteor/tree/devel/packages/accounts-password accounts-password 包]
 +
*accounts-facebook [https://github.com/meteor/meteor/tree/devel/packages/accounts-facebook accounts-facebook 包]
 +
*accounts-google [https://github.com/meteor/meteor/tree/devel/packages/accounts-google accounts-google 包]
 +
*accounts-github [https://github.com/meteor/meteor/tree/devel/packages/accounts-github accounts-github 包]
 +
*accounts-twitter [https://github.com/meteor/meteor/tree/devel/packages/accounts-twitter accounts-twitter 包]
 +
*accounts-meetup [https://github.com/meteor/meteor/tree/devel/packages/accounts-meetup accounts-meetup 包]
 +
*accounts-weibo [https://github.com/meteor/meteor/tree/devel/packages/weibo weibo 包]
 +
[https://meteorhacks.com/extending-meteor-accounts/ Extending Meteor Accounts (login system)]
  
 
==DDP==
 
==DDP==
了解DDP
+
了解DDP (Distributed Data Protocol)
 
*[https://github.com/meteor/meteor/blob/devel/packages/ddp/DDP.md DDP Specification]
 
*[https://github.com/meteor/meteor/blob/devel/packages/ddp/DDP.md DDP Specification]
 
*[https://meteorhacks.com/discover-meteor-ddp-in-realtime/ Discover Meteor DDP in Realtime]
 
*[https://meteorhacks.com/discover-meteor-ddp-in-realtime/ Discover Meteor DDP in Realtime]
[https://meteorhacks.com/introduction-to-ddp/ DDP] 主要做两件事:
+
*[https://github.com/arunoda/meteor-ddp-analyzer Meteor DDP Analyzer]
 +
[https://meteorhacks.com/introduction-to-ddp/ DDP主要做两件事]
 
* 处理 Remote Procedure Calls ([[RPC]])
 
* 处理 Remote Procedure Calls ([[RPC]])
 
* 管理数据
 
* 管理数据
第116行: 第152行:
  
 
==MongoDB==
 
==MongoDB==
[https://github.com/mWater/minimongo Minimongo]
+
[https://github.com/meteor/meteor/tree/master/packages/minimongo Minimongo包] [https://github.com/mWater/minimongo Minimongo]
 
*Polling MongoDB every ~10 secs
 
*Polling MongoDB every ~10 secs
 
*Using MongoDB oplog
 
*Using MongoDB oplog
第123行: 第159行:
 
  > db.posts.find();
 
  > db.posts.find();
  
==项目==
+
==[[RethinkDB]]==
 +
[https://github.com/Slava/meteor-rethinkdb RethinkDB integration for Meteor]
 +
 
 +
==Cassandra==
 +
 
 +
==Mobile==
 +
整合[[ionic]]
 
*[https://github.com/meteoric/meteor-ionic meteor-ionic]
 
*[https://github.com/meteoric/meteor-ionic meteor-ionic]
 +
整合 [[Apache Cordova]]
 +
*[https://guide.meteor.com/mobile.html#introduction Meteor Cordova integration]
 +
 +
==Scaffolding==
 +
通过脚手架快速启动Meteor项目:
 +
*[https://github.com/Differential/meteor-boilerplate meteor-boilerplate]
 +
*[https://github.com/iron-meteor/iron-cli iron]
 +
*[https://github.com/themeteorchef/base The Meteor Chef - Base]
 +
 +
==项目==
 +
*[https://atmospherejs.com/ Atmosphere] is the catalog for Meteor packages, resources and tools.
 +
*[[Meteor Admin]]
 +
*[https://github.com/wekan/wekan Wekan]
 +
*[https://github.com/RocketChat/Rocket.Chat Rocket.Chat]团队通讯
 +
*[https://github.com/meteoric/meteor-ionic meteor-ionic] [[Ionic]]
 
*[https://github.com/martijnwalraven/meteor-ios Meteor iOS]
 
*[https://github.com/martijnwalraven/meteor-ios Meteor iOS]
 
*[https://github.com/delight-im/Android-DDP Android-DDP]
 
*[https://github.com/delight-im/Android-DDP Android-DDP]
第134行: 第191行:
 
*[https://github.com/arunoda/meteor-up Meteor Up] 通过 Meteor Up 来部署 App
 
*[https://github.com/arunoda/meteor-up Meteor Up] 通过 Meteor Up 来部署 App
 
*[https://github.com/sockjs/sockjs-node SockJS]
 
*[https://github.com/sockjs/sockjs-node SockJS]
 +
*[https://arunoda.github.io/meteor-streams/ Meteor Streams]  [https://meteorhacks.com/introducing-meteor-streams/ Introducing Meteor Streams]
 +
*[https://github.com/kadirahq/react-storybook React Storybook] develop and design [[React.js]] UI components [https://medium.com/@arunoda/ec27f28de1e2 Introducing React Storybook]
 +
*[https://github.com/arunoda/meteor-up meteor-up] Production Quality Meteor Deployments
 +
*[https://github.com/ethereum/mist Mist Browser] [[Ethereum]]项目
  
 
==应用==
 
==应用==
第160行: 第221行:
 
*[https://meteorhacks.com/introducing-multi-core-support-for-meteor/ Introducing Multi-Core Support for Meteor]
 
*[https://meteorhacks.com/introducing-multi-core-support-for-meteor/ Introducing Multi-Core Support for Meteor]
 
*[https://meteorhacks.com/making-meteor-500-faster-with-smart-collections/ Making Meteor 500% Faster with Smart Collections]
 
*[https://meteorhacks.com/making-meteor-500-faster-with-smart-collections/ Making Meteor 500% Faster with Smart Collections]
 +
*[https://galaxy.meteor.com/ Galaxy] [https://galaxy-guide.meteor.com/ The guide for deploying, scaling, and managing Meteor apps on Galaxy]
 +
*[https://bulletproofmeteor.com/ Bullet Proof Meteor Build Fast and Efficient Meteor Apps]
 +
你也可基于 Meteor Up, Flow Router, Fast Render, SubsManager, and Meteor NPM integration 构建 Meteor 性能运营平台。
 +
*[https://github.com/zodern/meteor-up Meteor Up]
 +
*[https://github.com/kadirahq/flow-router Flow Router]
 +
*[https://github.com/meteorhacks/fast-render Fast Render]
 +
*[https://github.com/meteorhacks/subs-manager SubsManager]
 +
*[https://github.com/meteorhacks/npm Meteor NPM]
  
 
==图集==
 
==图集==
 
<gallery>
 
<gallery>
 +
image:meteor-stack.png|堆栈
 +
image:MEAN-stack-vs-Meteor.png|MEAN和Meteor
 
image:meteor-framework.png|框架
 
image:meteor-framework.png|框架
 
image:Meteor-Microservices-Architecture.png|微服务架构
 
image:Meteor-Microservices-Architecture.png|微服务架构
 +
image:isomorphic-app.png| isomorphic app
 
image:meteor-ddp-rpc.png|DDP RPC
 
image:meteor-ddp-rpc.png|DDP RPC
 
image:meteor-ddp-manages-data.png|DDP管理数据
 
image:meteor-ddp-manages-data.png|DDP管理数据
 +
image:Meteor-DDP-Analyzer.png|DDP Analyzer
 
image:meteor-client-server-mongodb.png|C/S MongoDB
 
image:meteor-client-server-mongodb.png|C/S MongoDB
 
image:meteor-autopublish.png|Autopublish
 
image:meteor-autopublish.png|Autopublish
第178行: 第251行:
 
image:Meteor-Local-Market-04.png
 
image:Meteor-Local-Market-04.png
 
image:Meteor-Todos.png
 
image:Meteor-Todos.png
 +
image:Meteor-on-FHIR.png|Meteor on FHIR
 
</gallery>
 
</gallery>
  
第186行: 第260行:
 
*[https://meteorhacks.com/ MeteorHacks] [https://github.com/meteorhacks MeteorHacks @ GitHub]
 
*[https://meteorhacks.com/ MeteorHacks] [https://github.com/meteorhacks MeteorHacks @ GitHub]
 
*[http://www.meteorpedia.com/ Meteorpedia] Meteor的维基百科, [http://www.meteorpedia.com/profile/bt4cayGkw73rxf5Cy Huihoo账户]
 
*[http://www.meteorpedia.com/ Meteorpedia] Meteor的维基百科, [http://www.meteorpedia.com/profile/bt4cayGkw73rxf5Cy Huihoo账户]
 +
*Meteor founder [https://twitter.com/debergalis Matt Debergalis]
 +
*[http://docs.huihoo.com/meteor Meteor文档]
 +
*[http://zh.discovermeteor.com/ Discover Meteor 中文版] [https://github.com/DiscoverMeteor DiscoverMeteor @ GitHub]
  
 
[[category:javaScript]]
 
[[category:javaScript]]
 +
[[category:node.js]]
 +
[[category:mongoDB]]
 
[[category:mobile]]
 
[[category:mobile]]
 
[[category:cordova]]
 
[[category:cordova]]
 
[[category:iOS]]
 
[[category:iOS]]
 
[[category:android]]
 
[[category:android]]

2022年4月19日 (二) 06:02的最后版本

Meteor, the JavaScript App Platform

Meteor,一个面向Web和App的应用框架和构建平台。

Node.js, Meteor, React.js, AngularJS, JavaScript 和 HTML5 生态系统

目录

[编辑] 简介

Meteor 基于 Node.js 构建,Node.js 是所有 Meteor 应用的服务器引擎,Meteor 深度整合 MongoDB,通过 Apache_Cordova 支持移动端应用,MIT 许可协议。

Meteor JavaScript 全栈框架

[编辑] 版本

[编辑] 指南

curl https://install.meteor.com | /bin/sh
meteor create try-meteor
cd try-meteor
meteor
=> Started proxy.                             
=> Started MongoDB.                           
=> Started your app. 
http://localhost:3000/
meteor deploy try-meteor.meteor.com

服务端Shell

$ meteor shell

Mongo Shell

$ meteor mongo

升级

$ meteor update
$ meteor update --all-packages

[编辑] 术语表

介绍一些常见的 Meteor 术语

  • 客户端 Client

当我们谈论客户端时,我们指的是用户的网页浏览器,不论是传统的像 Firebox 或 Safari 的浏览器,或是像在 iPhone 原生应用中的 UIwebView 一样复杂的其他程序。

  • 集合 Collection

Meteor 的集合是自动在客户与服务器之间同步的数据源。集合的名称(比如 posts)通常存在于客户端和服务器端。虽然它们表现不同,但是它们有共同的基于 Mongo 的 API。

  • Computation

Computation 就是每当响应数据源变化时而运行的代码块。如果你想让一个响应数据源去响应处理(比如,Session 变量),你需要为它来设置一个 computation。

  • Cursor

Cursor 是查询 Mongo 集合后的结果。在客户端,cursor 不仅仅是结果的数组,也是一个响应的对象,对应于相关集合的添加、删除和更新对象。

  • 分布式数据协议 DDP

DDP 是 Meteor 的分布式数据协议,用来同步集合和调用方法。DDP 的目的是作为一个通用的协议,在大数据的实时应用中起 HTTP 的作用。

  • Tracker

Tracker 是 Meteor 响应性系统。Tracker 在后台使 HTML 自动保持与底层数据模型的同步。

  • 文档 Document

Mongo 是基于文档(document)的数据库,多个文档组成集合。它们是纯 JavaScript 对象(虽然它们不能包含函数),只有一个 _id 属性,Meteor 用这个属性通过 DDP 跟踪这些对象的属性。

  • Helper

当模板需要渲染复杂的多于一个文档属性时,调用 helper 以函数方式来完成渲染任务。

  • 延迟补偿 Latency Compensation

延迟补偿是一种在客户端模拟方法调用以避免等待服务器回应的一种技术。

  • Meteor Development Group (MDG)

Meteor 开发小组(MDG),开发 Meteor 的公司,区别于这个框架本身。

  • 方法 Method

Meteor 方法是一个从客户端到服务器端的远程调用,以一些特别的逻辑保持跟踪集合的更改和允许延迟补偿。

  • MiniMongo

客户端的集合,是有类似 Mongo API 并存在内存的数据源。支持这种操作的库叫做“MiniMongo”,是在内存中运行的小版本的 Mongo。

  • 代码包 Package

Meteor 代码包可以包含服务器端运行的、客户端运行的 JavaScript 代码,处理资源的说明(比如 SASS 至 CSS),处理的资源。 代码包就像一个超级库。Meteor 自带了很多核心代码包,同时在 Atmosphere 集合了社区提供的第三方代码包。

  • 发布 Publication

一个发布就是一套为每个订阅用户而订制的数据。在服务器端设置发布。

  • 服务器 Server

Meteor 服务器是运行在 Node.js 之上的 HTTP 和 DDP 服务器。它包含了所有的 Meteor 库,同时也包含了你的服务器端的 JavaScript 代码。当 Meteor 服务器启动时,它会连接 Mongo 数据库(在开发模式时,会自启动)。

  • 会话 Session

在 Meteor 中,会话指的是客户端的响应数据源,用来跟踪用户所处的状态。

  • Subscription

订阅是为特定客户的发布的连接。订阅是运行在浏览器中的代码,与服务器的发布对话,并保持数据同步。

  • 模板 Template

模板就是一个通过 JavaScript 生成 HTML 的方法。Meteor 默认支持 Spacebars 模板系统,但是将来也会支持其他系统。

  • 模板数据上下文 Template Data Context

当模板渲染时,它指的是 JavaScript 对象为此次渲染提供特定的数据。通常来说,对象就是纯原始的 JavaScript 对象(POJO),经常也是集合的文档,但是它们也可以变得更复杂,可拥有函数。

[编辑] Package

Atmosphere is the catalog for Meteor packages, resources and tools.

Meteor 中的代码包有点特殊,分为五种:

  • Meteor 核心代码本身分成多个核心代码包(core package),每个 Meteor 应用中都包含,你基本上不需要花费精力来维护它们
  • 常规 Meteor 代码包称为“isopack”,或同构代码包(isomorphic package,意味着它们既能在客户端也能在服务器端工作)。第一类代码包例如 accounts-ui 或 appcache 由 Meteor 核心团队维护,与 Meteor 捆绑在一起。
  • 第三方代码包就是其他用户开发的 isopack 上传到 Meteor 的代码包服务器上。你可以访问 Atmosphere 或 meteor search 命令来浏览这些代码包。
  • 本地代码包(local package)是自己开发的代码包,保存在 /packages 文件夹中。
  • NPM 代码包(NPM package)是 Node.js 的代码包,虽不能直接用于 Meteor,但可以在上述几种代码包中使用

[编辑] 集成

[编辑] Bootstrap

cd meteor-accounts
meteor add twbs:bootstrap
meteor add ian:accounts-ui-bootstrap-3
meteor add accounts-password
meteor add accounts-github

更多细节:meteor-accounts-ui-bootstrap-3

[编辑] 模版

[编辑] 例子

sudo meteor create --example localmarket
cd localmarket
meteor
sudo meteor create --example todos
cd todos
meteor

Angular-meteor-ionic-whatsapp.png 更多细节>>>

[编辑] 账户系统

用户体系、身份认证、允许拒绝、第三方登录

accounts-base Meteor用户账户系统包含以下包:

Extending Meteor Accounts (login system)

[编辑] DDP

了解DDP (Distributed Data Protocol)

DDP主要做两件事

  • 处理 Remote Procedure Calls (RPC)
  • 管理数据

DDP Clients

[编辑] MongoDB

Minimongo包 Minimongo

  • Polling MongoDB every ~10 secs
  • Using MongoDB oplog
meteor mongo
> db.posts.insert({title: "A new post"});
> db.posts.find();

[编辑] RethinkDB

RethinkDB integration for Meteor

[编辑] Cassandra

[编辑] Mobile

整合ionic

整合 Apache Cordova

[编辑] Scaffolding

通过脚手架快速启动Meteor项目:

[编辑] 项目

[编辑] 应用

[编辑] 高可用高性能

你也可基于 Meteor Up, Flow Router, Fast Render, SubsManager, and Meteor NPM integration 构建 Meteor 性能运营平台。

[编辑] 图集

[编辑] 链接

分享您的观点
个人工具
名字空间

变换
操作
导航
工具箱