0

我正在尝试编写一个简单的表单来获取单个用户输入,其余的是在现有文档中设置(创建)新子文档的 const 变量。目前我被抛出一个错误:

Uncaught (in promise) TypeError: firebase.firestore(...).collection(...).doc(...).collection(...).set is not a function

这是代码:

                    <form id="bgForm" method="POST">
                        <div class="wrap-input100 validate-input m-t-25 m-b-35" data-validate="Enter blood glucose">
                            <h5>Update Blood Glucose</h5>
                            <font face="Montserrat">Input Blood Glucose: </font>
                            <input class="input100" type="text" name="inputBloodGlucose" style="font-family:Montserrat;" id="inputBg" required />
                            <button type="submit" class="btn btn-primary" id="updateBG">Update Blood Glucose</button>
                            </form>
                                <script>
                                    (function(){
                                        //Update BG
                                        $('#bgForm').on('submit', async function (e) {
                                            e.preventDefault();
                                            var data = {
                                            bgReading: parseInt($('#inputBg').val()), //get bg int
                                            dateAdded: firebase.firestore.Timestamp.fromDate(new Date()),
                                            isActive: true,
                                            };
                                            firebase.auth().onAuthStateChanged(function(user){
                                                if(user){
                                                    this.userId = user.uid; //stores the userid
                                                }
                                                firebase.firestore().collection("users").doc(userId).collection("glucose").set({
                                                    'bgReading': data.bgReading, 'dateAdded': data.dateAdded, 
                                                    'isActive': data.isActive,
                                                })
                                                .then(function(){
                                                    window.alert("Blood Glucose updated!");
                                                    // window.location.href = "diabetesManagement.php"; 
                                                })
                                                .catch(function(error){
                                                    console.log("Error updating blood glucose", error);
                                                    window.alert("Error updating blood glucose" + error);
                                                });
                                               });
                                            });
                                        })();
                                </script>
                        </div>

我在用

firebase.auth().onAuthStateChanged(function(user){ 
if(user){this.userId = user.uid;}

获取uid当前登录的用户,然后将其存储在变量中。我不能使用此代码执行查询吗?因为这是我目前唯一依靠的东西,作为向我抛出错误的原因。

4

1 回答 1

3

改变这个:

firebase.firestore().collection("users").doc(userId).collection("glucose").set({
                                                    'bgReading': data.bgReading, 'dateAdded': data.dateAdded, 
                                                    'isActive': data.isActive,
                                                })

进入这个:

firebase.firestore().collection("users").doc(userId).collection("glucose").add({
                                                    'bgReading': data.bgReading, 'dateAdded': data.dateAdded, 
                                                    'isActive': data.isActive,
                                                })

There is no set method inside CollectionReference, you need to use add that will add a new document with the data passed.

https://firebase.google.com/docs/reference/js/firebase.firestore.CollectionReference.html#add

于 2020-02-01T12:42:22.397 回答