聚合物上传图像到firebase

时间:2017-01-26 06:56:40

标签: javascript firebase polymer-1.0 polymerfire

我试图关注firebase文档并使用聚合物将图像上传到firebase。

这就是我所拥有的

  _pushToFirebase: function() {

       // SLUGGING THE NAME B4 WE EVEN SAVE IT!!
      var sluggedname = this._slugify(this.$.crewName.value);
      //FOR THE IMAGE
      var file = this.$.crewProfilePic.value;

      // Upload file
      var uploadTask = this.$.query.storageRef.child('/crewprofileimages/' + file.name).put(file);
      // Listen for state changes, errors, and completion of the upload.
      uploadTask.on(firebase.storage.TaskEvent.STATE_CHANGED, // or 'state_changed'
        function(snapshot) {
          // Get task progress, including the number of bytes uploaded and the total number of bytes to be uploaded
          var progress = (snapshot.bytesTransferred / snapshot.totalBytes) * 100;
          console.log('Upload is ' + progress + '% done');
          switch (snapshot.state) {
            case firebase.storage.TaskState.PAUSED: // or 'paused'
              console.log('Upload is paused');
              break;
            case firebase.storage.TaskState.RUNNING: // or 'running'
              console.log('Upload is running');
              break;
          }
        }, function(error) {
        switch (error.code) {
          case 'storage/unauthorized':
            // User doesn't have permission to access the object
            console.log('You dont have permission to access object');
            break;

          case 'storage/canceled':
            // User canceled the upload
            console.log('User cancelled upload');
            break;

          case 'storage/unknown':
            // Unknown error occurred, inspect error.serverResponse
            console.log(error.code);
            break;
        }
      }, function() {
        // Upload completed successfully, now we can get the download URL
        var downloadURL = uploadTask.snapshot.downloadURL;
      });




      // PUSHING TO FIREBASE
      this.$.query.ref.push({
        name: this.$.crewName.value,
        description: this.$.crewDescription.value,
        createddate: new Date().toString(),
        creator: this.$.createcrewlogin.user.uid,
        slug: sluggedname,
        profileimage: downloadURL,
        members: {
          memberuserid: this.$.createcrewlogin.user.uid,
        }
      });
  },

并且firebase查询看起来像这样

    <!--STORE THE DATA IN CREWS DEFAULT SECTION-->
    <firebase-query
      id="query"
      data="{{mycrews}}"
      path="/crews">
    </firebase-query>

每当我点击提交。我在控制台中收到此错误

cannot read property of 'child' of undefined我该如何解决这个问题?

1 个答案:

答案 0 :(得分:0)

可能会迟到但是从短暂的错误看来,您尝试访问的元素似乎没有定义,即您需要在请求属性(此处为子)之前访问它

Firebase查询有一个路径属性,您可以保存数据的位置。如果你使用polymerfire元素作为firebase-query,那么你需要访问路径并更改它,然后push()。

所以而不是

this.$.query.storageRef.child('/crewprofileimages/' + file.name).put(file);

你应该有类似的东西:

this.$.query.path = yourPath ; 
this.$.query.put(file) ... etc 

您提出的错误来自于此,但为了获得更好的解决方案,需要提供更好的错误。干杯