RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题

问题[localstorage]

Martin Hope
Niko Papchenko
Asked: 2022-09-30 17:07:01 +0000 UTC

localStorage 在重新加载页面后单击按钮时记住振动

  • 0

有一个代码

let doVibro = false;

document.getElementById("vibro_on").addEventListener('click', () => {
  doVibro = true;
});

document.getElementById("vibro_off").addEventListener('click', () => {
  doVibro = false;
});

document.getElementById("do-vibro").addEventListener('click', () => {
  doVibro ? navigator.vibrate([50]) : navigator.vibrate([0]);
});
<button id="vibro_on">ON</button>
<button id="vibro_off">OFF</button>

<button onclick="vibro()" id="do-vibro">TEST</button>

需要在重新加载页面时,通过按TESET保持振动,即设备记住是否振动,然后在重新加载页面后保持振动。

javascript localstorage
  • 1 个回答
  • 36 Views
Martin Hope
Евгений Ключников
Asked: 2022-08-16 22:15:59 +0000 UTC

做出反应。如何将本地存储中的计时器值减一?[关闭]

  • 0
关闭 这个问题是题外话。目前不接受回复。

该问题是由不再复制的问题或错字引起的。虽然类似的问题可能与本网站相关,但该问题的解决方案不太可能帮助未来的访问者。通常可以通过在发布问题之前编写和研究一个最小程序来重现问题来避免此类问题。

3 个月前关闭。

改进问题

如何将本地存储中的计时器值减一?使用了“useLocalStorage”钩子,但该值不会动态减一

计时器本身:

    const [timeLeft, setTimeLeft] = useLocalStorage('timer',  5 * 60)

    const getPadTime = (time) => time.toString().padStart(2, '0')

    const minutes = getPadTime(Math.floor(timeLeft / 60))
    const seconds = getPadTime(timeLeft - minutes * 60)

    useEffect(() => {
        const interval = setInterval(() => {
            setTimeLeft((timeLeft) => (timeLeft >= 1 ? timeLeft - 1 : setDisabled() ||  5 * 60))
        }, 1000)
        return () => clearInterval(interval) 
    }, [])

'useLocalStorage' 挂钩数据:

import {useState} from 'react'

function useLocalStorage(key, initialValue) {
    // State to store our value
    // Pass initial state function to useState so logic is only executed once
    const [storedValue, setStoredValue] = useState(() => {
      if (typeof window === "undefined") {
        return initialValue;
      }
  
      try {
        // Get from local storage by key
        const item = window.localStorage.getItem(key);
        // Parse stored json or if none return initialValue
        return item ? JSON.parse(item) : initialValue;
      } catch (error) {
        // If error also return initialValue
        console.log(error);
        return initialValue;
      }
    });
  
    // Return a wrapped version of useState's setter function that ...
    // ... persists the new value to localStorage.
    const setValue = (value) => {
      try {
        // Allow value to be a function so we have same API as useState
        const valueToStore =
          value instanceof Function ? value(storedValue) : value;
        // Save state
        setStoredValue(valueToStore);
        // Save to local storage
        if (typeof window !== "undefined") {
          window.localStorage.setItem(key, JSON.stringify(valueToStore));
        }
      } catch (error) {
        // A more advanced implementation would handle the error case
        console.log(error);
      }
    };
  
    return [storedValue, setValue];
  }

  export default useLocalStorage
reactjs localstorage
  • 1 个回答
  • 33 Views
Martin Hope
user497202
Asked: 2022-07-09 21:19:25 +0000 UTC

window.localStorage.getItem() 和 window.sessionStorage.getItem() 返回 null

  • 0

你好,我刚开始学习js。

window.localStorage.getItem()并window.sessionStorage.getItem()返回null,尽管如果您在 chrome 中使用应用程序,则存在值 \u200b\u200bare。

let startBtn = document.getElementById("startBtn")
startBtn.onclick = game;
document.getElementById('clearBR').addEventListener('click', ClearBestResult)
document.getElementById('clearBRforAllTime').addEventListener('click', ClearBestResultForAllTime)
let result
function game() {
   let count = 0
   const nickname = document.getElementById("nickname").value
   document.getElementById('click').addEventListener('click', clickCount)
   let arr = []
   function clickCount() {
      count++
      arr.push(count)
   }
   try {
      if (nickname === "") throw new Error()
   } catch (e) {
      alert('nickname is empty')
   }
   finally {
      setTimeout(function () {
         result = arr.length
         alert(`You clicked ${result} times`)
         if (sessionStorage.getItem, (nickname, result) < result || sessionStorage.getItem, (nickname, result) === undefined) {
            sessionStorage.clear()
            sessionStorage.setItem(nickname, result.toString())
         } else if (result > localStorage.getItem, (nickname, result) || localStorage.getItem === undefined) {
            localStorage.clear()
            localStorage.setItem(nickname, result.toString())
         }
         count = 0
         arr.splice(0, arr.length);
      }, 5000);
   }
   document.getElementById('BRforAllTime').addEventListener('click', bestForAllTimes)
   document.getElementById('BR').addEventListener('click', bestResult)
   function bestForAllTimes() {
      alert(`Best result for the whole time is: ${localStorage.getItem(result)} by ${localStorage.getItem("nickname")}`)
   }
   function bestResult() {
      alert(`Best result is ${window.sessionStorage.getItem(result)}`)
   }
   console.log(sessionStorage.getItem(result)) // null
   console.log(localStorage.getItem(result)) //null
}
function ClearBestResult() {
   window.sessionStorage.clear()
   alert('Best result is cleared')
}
function ClearBestResultForAllTime() {
   localStorage.clear()
   alert('Best result for the whole time is cleared')
}

javascript localstorage
  • 1 个回答
  • 67 Views

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5