从Firebase检索数据到Polymer元素

时间:2016-07-14 07:46:44

标签: javascript firebase polymer firebase-realtime-database polymer-1.0

我无法从firebase获取数据到聚合物元素。

这是我的代码:

 <dom-module id="bb-account-settings">

  <template>

    <style is="custom-style" include="shared-styles"></style>

                <div class="settings-dialog">
                    <div class="frame">
                        <div class="horizontal layout">
                            <div>
                                <div class="user-image"></div>
                            </div>
                            <div class="horizontal layout">
                                <paper-input label="First Name" value="{{fNameSet}}"></paper-input>
                                &nbsp&nbsp&nbsp&nbsp&nbsp&nbsp
                                <paper-input label="Last Name" value="{{lNameSet}}"></paper-input>
                            </div>
                            <paper-input label="Email" value="{{emailSet}}"></paper-input>
                        </div>
                        <paper-input label="Phone number" value="{{phoneSet}}" allowed-pattern="[0-9]"></paper-input>
                    </div>
                </div>

  </template>
  <script>

    Polymer({

      is: 'bb-account-settings',

            properties: {
                fNameSet: {
                    type: String,
                    value: function() {
                        var userId = firebase.auth().currentUser.uid;
                        firebase.database().ref('/user/' + userId + '/UserInfo').once('value').then(function(snapshot) {
                            console.log(snapshot.val().fName)
                            return (snapshot.val().fName);
                        });
                    }
                },
                lNameSet: {
                    type: String,
                    value: 'test last name'
                    }
                }
            }

    });

  </script>

lNameSEst是&#39;测试姓氏&#39;显然它已投入其输入。你期望fNameSet能够做同样的事情,但是没有。当我打印它(console.log)它说'测试名字&#39;但它没有在其输入文件中显示!

我很困惑。

1 个答案:

答案 0 :(得分:2)

正如其中一位评论者注意到的那样,在回调中返回一个值就是问题所在。传递给firebase的“一次”函数的函数称为异步&amp;在不同的范围,所以基本上它失去了它与你声明它的关系&amp;你返回的价值不会达到你期望的水平。

有点蛮力的方式来获得你想要的东西是做以下的事情:

ready: function() {
    var userId = firebase.auth().currentUser.uid;
    firebase.database().ref('/user/' + userId + '/UserInfo').once('value').then(function(snapshot) {
          console.log(snapshot.val().fName)
          this.fNameSet = snapshot.val().fName;
        }.bind(this));
}

有更优雅的方法,但它有点超出了这个问题的范围。需要一些重组和更深入地了解您的应用程序结构。