javascript - Firebase 开关按钮

标签 javascript firebase firebase-realtime-database

所以我正在尝试使用 Javascript 和 Firebase 制作一个实时按钮。目前我有一个工作按钮,可以将实时数据库中的变量从打开更改为关闭。但默认值未保存,因此当我关闭按钮并重新加载页面时,它显示它已打开,我该如何解决此问题?我还希望它在所有客户端之间实时更新

App.js

(function() {    
    //Get elements
    const preObject = document.getElementById('object');

    // Create reference
    dbRefObject = firebase.database().ref().child('button').child('value')

    // Sync changes
    dbRefObject.on('value', snap => console.log(snap.val()));

}());
document.addEventListener("DOMContentLoaded", function() {
    console.log("test");
   });

document.addEventListener('DOMContentLoaded', function () {
    var checkbox = document.querySelector('input[type="checkbox"]');
    const dbRefObject = firebase.database().ref().child('button')

    checkbox.addEventListener('change', function () {
      if (checkbox.checked) {
        dbRefObject.set({value: true})
        console.log('Checked');
      } else {
        dbRefObject.set({value: false})
        console.log('Not checked');
      }
    });
  });

索引.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>

    <link rel="stylesheet" type="text/css" href="styles.css">
    <script src="https://www.gstatic.com/firebasejs/live/3.1/firebase.js"></script>

    <link href="https://gitcdn.github.io/bootstrap-toggle/2.2.2/css/bootstrap-toggle.min.css" rel="stylesheet">
    <script src="https://gitcdn.github.io/bootstrap-toggle/2.2.2/js/bootstrap-toggle.min.js"></script>


</head>
<body>
    <h2>Toggle Switch</h2>

    <label class="switch">
        <input type="checkbox" id="checkbox" checked>
        <div class="slider"></div>
    </label>

    <script src="app.js"></script>
</body>
</html>

最佳答案

您正在从数据库中读取数据,但尚未对其执行任何有用的操作:

dbRefObject.on('value', snap => console.log(snap.val()));}

要让按钮反射(reflect)您存储在数据库中的状态,请使用此监听器更新按钮的状态:

dbRefObject.on('value', (snap) {
  var checkbox = document.querySelector('input[type="checkbox"]');
  checkbox.checked = snap.val().value;
})

关于javascript - Firebase 开关按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61576144/

相关文章:

javascript - Reactjs 无法声明和导出常量

ios - 仅使用客户端代码发送 Firebase 云消息

android-studio - 如何让 Google Play 服务 API 和 Firebase API 的 API javadoc 显示在 Android Studio 中,而不是没有文档的反编译类?

reactjs - 如何使用 ES6 语法将 Firebase Firestore 导入到 create-react-app 项目中

swift - 区分记录更改和 Firebase 中删除的数据

ios - 如何创建将数据插入 block 的函数

javascript - 将数据从 Firebase 检索到 Polymer 元素

javascript - ES6 类实例化中的错误消息

javascript - 更新 jquery 中的 View 模型

javascript - Node.js 和 Socket.io 如何发出 DOM 对象,尽管这看起来不可能?