在本章中,我們將學習如何創建自己的 meteor 包。
創建包
讓我們添加在桌面上的新檔夾用來創建新的包。使用命令提示符窗口執行如下命令。
C:\Users\Administrator\Desktop\meteorApp> mkdir packages
現在我們可以在上面創建的檔夾中創建你的包。運行命令提示符運行以下命令。Username 是您的 Meteor 開發者的用戶名和package-name是你的包的名稱。
C:\Users\Administrator\Desktop\meteorApp\packages>meteor create --package username:package-name
添加包
為了能夠本地包添加到我們的應用程式,需要設置環境變數(ENVIRONMENT VARIABLE),將告訴 meteor 從本地檔夾加載包。右鍵單擊"電腦"圖示,然後選擇屬性/高級系統設置/環境變數/新建。
變數名應該是PACKAGE_DIR變數值路徑應該是指向創建的檔夾。在我們的示例中是:C:\Users\Administrator\Desktop\meteorApp\packages.
注意:不要忘記在添加新的環境變數後重新啟動命令提示符。
現在,我們可以運行下麵的代碼將包添加到我們的應用程式-
C:\Users\Administrator\Desktop\meteorApp>meteor add username:package-name
包檔
如果打開創建軟體包的檔夾,你會看到四個檔。
- package-name-test.js
- package-name.js
- package.js
- README.md
測試包(package-name-test.js)
Meteor 提供 tinytest 包用於測試。讓我們先從命令提示符窗口來安裝它。
C:\Users\Adminitrator\Desktop\meteorApp>meteor add tinytest
如果你打開 package-name-test.js, 你會看到默認的測試例子。我們將用這個例子來測試應用程式。開發 Meteor 包時,你應該要寫寫自己的測試。
要測試包,需要運行在命令提示符下此代碼。
C:\Users\Administrator\Desktop>meteor test-packages packages/package-name
你應該得到以下結果。


package.js檔
我們可以在這個檔中編寫代碼。現在我們在包中實現一些簡單的功能。包將日誌記錄一些文本到控制臺。
packages/package.js
myPackageFunction = function() { console.log('This is simple package...'); }
package-name.js檔
這是我們可以設定一些程式包配置檔。 我們一會再回到它,但現在需要導出myPackageFunction,就可以在應用程式中使用它了。我們需要添加這些到 Package.onUse 函數內。該檔將是這個樣子。
packages/package-name.js
Package.describe({ name: 'username:package-name', version: '0.0.1', // Brief, one-line summary of the package. summary: '', // URL to the Git repository containing the source code for this package. git: '', // By default, Meteor will default to using README.md for documentation. // To avoid submitting documentation, set this field to null. documentation: 'README.md' }); Package.onUse(function(api) { api.versionsFrom('1.2.1'); api.use('ecmascript'); api.addFiles('mypackage.js'); api.export('myPackageFunction'); // We are exporting the function we created above... }); Package.onTest(function(api) { api.use('ecmascript'); api.use('tinytest'); api.use('username:package-name'); api.addFiles('package-name-tests.js'); });
使用軟體包
現在,我們終於可以從 app.js 檔調用myPackageFunction()函數了。
packages/package.js
if(Meteor.isClient) { myPackageFunction(); }
控制臺將日誌記錄包中的文本,其結果如下:
為了更好地理解package.js檔如何配置,我們將使用Meteor 官方文檔的例子。


這是一個例子檔...看看一就知道了
/* Information about this package */ Package.describe({ // Short two-sentence summary. summary: "What this does", // Version number. version: "1.0.0", // Optional. Default is package directory name. name: "username:package-name", // Optional github URL to your source repository. git: "https://github.com/something/something.git", }); /* This defines your actual package */ Package.onUse(function (api) { // If no version is specified for an 'api.use' dependency, use the // one defined in Meteor 0.9.0. api.versionsFrom('0.9.0'); // Use Underscore package, but only on the server. // Version not specified, so it will be as of Meteor 0.9.0. api.use('underscore', 'server'); // Use iron:router package, version 1.0.0 or newer. api.use('iron:router@1.0.0'); // Give users of this package access to the Templating package. api.imply('templating') // Export the object 'Email' to packages or apps that use this package. api.export('Email', 'server'); // Specify the source code for the package. api.addFiles('email.js', 'server'); }); /* This defines the tests for the package */ Package.onTest(function (api) { // Sets up a dependency on this package api.use('username:package-name'); // Allows you to use the 'tinytest' framework api.use('tinytest@1.0.0'); // Specify the source code for the package tests api.addFiles('email_tests.js', 'server'); }); /* This lets you use npm packages in your package*/ Npm.depends({ simplesmtp: "0.3.10", "stream-buffers": "0.2.5" });
上一篇:
Meteor方法
下一篇:
Meteor發佈和訂閱