在Ember JS应用程序中初始化cloudinary_js v2

时间:2016-08-01 02:55:33

标签: ember.js npm ember-cli cloudinary

我尝试将图像从EmberJS应用程序(v2.6)上传到cloudinary,跟随enter image description here使用post of Beerlington(现在使用新的API v2)并且为了安装它:

npm install blueimp-file-upload --save
npm install cloudinary-jquery-file-upload --save

但是当我尝试初始化cloudinary时,无法识别库。

#app/initializers/cloudinary.js
export default {
  name: 'cloudinary',
  initialize: function(/* container, app */) {
    jQuery.cloudinary.config({
      cloud_name: ENV.CLOUDINARY_NAME
    });
  }
};

#console
TypeError: Cannot read property 'config' of undefined

1 个答案:

答案 0 :(得分:1)

由于ember.js本质上是一个客户端框架,因此您需要使用bower库而不是npm(more)。

使用bower安装Cloudinary:

bower install cloudinary-jquery-file-upload --save

(blueimp将作为依赖项安装。)

将导入添加到ember-cli-build.js文件中:

/*jshint node:true*/
/* global require, module */
var EmberApp = require('ember-cli/lib/broccoli/ember-app');

module.exports = function(defaults) {
  var app = new EmberApp(defaults, {
    // Add options here
  });

    app.import("bower_components/jquery/dist/jquery.js");
    app.import("bower_components/blueimp-file-upload/js/vendor/jquery.ui.widget.js");
    app.import("bower_components/blueimp-file-upload/js/jquery.iframe-transport.js");
    app.import("bower_components/blueimp-file-upload/js/jquery.fileupload.js");
    app.import('bower_components/cloudinary-jquery-file-upload/cloudinary-jquery-file-upload.js');

  return app.toTree();
};

jQuery添加到.jshintrc中的全局定义(此处显示片段):

{
  "predef": [
    "document",
    "window",
    "-Promise",
    "jQuery",
    "$"
  ],
  "browser": true,
  // rest of file...
}

如果您打算直接使用cloudinary命名空间,也可以添加cloudinary

现在您可以在代码中使用Cloudinary和Blueimp。例如:

import Ember from 'ember';

export default Ember.Route.extend(
  {
    model() {
      $.cloudinary.config({"cloud_name": "your_cloud"});
      $(document).ready(function () {
        $(".cloudinary-fileupload").cloudinary_fileupload(

        // etc.

        )}
      );
    }
  });