OStack程序员社区-中国程序员成长平台

标题: ios - FirebaseDatabase 网页 iOS/OSX [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-13 00:11
标题: ios - FirebaseDatabase 网页 iOS/OSX

我正在为一个学校项目开发一个网站,其中包含一个您需要按下的按钮。按下时,该按钮从数据库中获取一个值,即 child 'aantal' 并加 1。完成后,它会将其重新上传回数据库。再往前一页,您可以看到该 child 的实时号码。问题是,这不适用于 iOS 9 或更低版本以及 OSX Yosemite 或更低版本。在 android 和 windows 上运行良好。

可重用的代码;

这只是一个按钮。如果按下按钮,它会在 int 上添加 1。这很奇怪,因为它在上面提到的操作系统上不起作用。

<script src="https://www.gstatic.com/firebasejs/3.6.9/firebase.js"></script>
<script language="JavaScript">
        // Initialize Firebase
        var config = {
            apiKey: //API KEY,
            authDomain: //FIRBASE DOMAIN,
            databaseURL: //DATABASE URL,
            storageBucket: //STORAGE BUCKET,
            messagingSenderId: //MESGSENDID
        };
        firebase.initializeApp(config);
        var number;
        var database = firebase.database().ref().child('aantal');
        function buy() {
            database.on('value', snap => number = snap.val());
            var count = parseInt(number, 10) + 1;
            database.set(count);
        }
    </script>

此代码不起作用,初始化自己的 Firebase 项目进行测试。 出于安全原因,我删除了我的详细信息。



Best Answer-推荐答案


编辑 原来 Safari(9.1/iOS 9.3 及以下)不支持箭头功能。

database.on('value', snap => number = snap.val()); 更改为 database.on('value', function(snap) { number = snap.val()}); 修复了这个问题。

我的意思是,该代码不应该在任何地方工作。

function buy() {
    database.on('value', snap => number = snap.val());
    var count = parseInt(number, 10) + 1;
    database.set(count);
}

Firebase 是异步的,您无需等待它从数据库中实际加载数字。

这应该可行。

function buy() {
    database.on('value', snap => {
      number = snap.val();
      var count = parseInt(number, 10) + 1;
      database.set(count);
    });
}

我不知道这是否真的是您遇到的问题,或者您是否只是在示例中写了这个。此外,在增加值时,您应该使用事务。

function buy() {
    database.transaction(function(value) {
        if (value) {
            value++;
        }
        return value;
    });
}

关于ios - FirebaseDatabase 网页 iOS/OSX,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42734217/






欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) Powered by Discuz! X3.4