- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将一个可观察数组保存到 localStorage。为此,我使用 ko.toJSON。
var that = this;
this.items = ko.observableArray();
this.items.subscribe(function(){
localStorage.setItem("items", ko.toJSON(that.items()));
});
所有持久化到 localStorage 的都是 false
。
它抛出一个非常随机的错误:knockout-3.4.2.js:55 Uncaught DOMException: Failed to read the 'cssRules' property from 'CSSStyleSheet': Cannot access rules
。
知道这里发生了什么吗?
我也通过简单的 var json = ko.toJSON(that.items());
得到错误,所以它显然来自于此。但是,简单地执行此操作时我不会收到该错误:var json = ko.toJSON([{'key': 'value'}]);
。
更新:这是完整的错误消息:
Uncaught DOMException: Failed to read the 'cssRules' property from
'CSSStyleSheet': Cannot access rules
at http://localhost:8080/js/knockout-3.4.2.js:55:405
at c (http://localhost:8080/js/knockout-3.4.2.js:56:172)
at b (http://localhost:8080/js/knockout-3.4.2.js:55:380)
at http://localhost:8080/js/knockout-3.4.2.js:56:23
at c (http://localhost:8080/js/knockout-3.4.2.js:56:172)
at b (http://localhost:8080/js/knockout-3.4.2.js:55:380)
at http://localhost:8080/js/knockout-3.4.2.js:56:23
at c (http://localhost:8080/js/knockout-3.4.2.js:56:172)
at b (http://localhost:8080/js/knockout-3.4.2.js:55:380)
at http://localhost:8080/js/knockout-3.4.2.js:56:23
更新 2:这是问题所在的实际代码部分:
这是问题的确切上下文:
this.savedPlaces.subscribe(function() {
// Add all places to filteredPlaces
that.filterPlaces();
// Reinitialize the filter
that.filterString("");
// Update the markers
that.updateMarkers();
// Store itself in localStorage
localStorage.setItem("savedPlaces", ko.toJSON(that.savedPlaces()));
});
当我注释掉最后一行时,我没有遇到任何问题。
如果我将它替换为:localStorage.setItem("savedPlaces", ko.toJSON([{item: "item"}]));
我试图给出一个 items
的内容示例,但显然 observableArrays 是深层(递归)对象,因此我无法在 Chrome 上为 DevTools 控制台复制粘贴。然而它看起来像:
[{'marker': a_google_maps_marker_object,
'place': {data: mostly strings...}]
最佳答案
我发现了问题。我的可观察数组包含一个谷歌地图标记。这些是递归数组,无法进行 JSON 化。
我从数组中删除了 Google map 标记,一切正常。
虽然 Knockout 抛出了这个神秘的错误,但仍然很奇怪。
关于javascript - 带有 observableArray 的 ko.JSON 抛出未捕获的 DOMException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49212071/
我正在尝试使用 Google 的 Material 设计。 我在下面有一个组件,其路径是 epimss_design/lib/component/menu/main-menu-form.html; e
我在导航文档对象以删除特定节点时遇到 DOMException.HIERARCHY_REQUEST_ERR,在谷歌搜索此错误代码后,它说: “HIERARCHY_REQUEST_ERR:如果此节点的类
我已经使用 React JS 为 service worker 注册了 JS 文件。但是,当我尝试注册 periodic-background-sync 时出现错误。我需要在谷歌浏览器中进行任何设置吗
我在 Polymer 2 中有一个简单的 todo aap。它工作得很好,但是当我从 Polymer 目录添加元素时,我收到以下错误?还有纸张输入不能正常显示?检查屏幕截图。一切都很好我不知道为什么这
我一直在查询 websql 数据库表。在这里,插入和删除语句工作正常。 但是当我尝试执行 findAll 查询时,本质上是'select * from myTable',它返回一个带有 DOMExce
我刚刚动态创建了视频对象,然后在将视频对象附加到文档中之前添加了 2 个属性,例如 source 和 muted,最后使用方法 play() 播放添加的视频,如下所示。 let v = documen
在“我的应用程序”中,我想将节点从一个文档复制到另一个文档。 这是代码。 Element entryElement, operationElement; for (int i = 0; i < eve
我正在尝试通过替换其中的某些元素来使用 DOM 修改 XML 文档,但出现以下异常: 03-10 10:49:20.943: W/System.err(22584): org.w3c.dom.D
我正在使用 native-crypto 包,它是一个用于跨平台加密的 API(例如 web 和 node.js)。 let crypto = require("native-crypto"); 我已经
Chrome 会阻止自动播放音频/视频。我找到了自动播放视频的解决方案,但我的用例需要自动播放音频。这是我的代码: let audio = new Audio('music/test.mp3'); a
我正在尝试加载音频,但遇到了两个错误,但是一切都很好,并且来源是正确的。 错误: GET http:// localhost:4200 / src / assets / sound / welcome
每当我运行此代码时 var blob = new Blob(["ninja.mp3"], {type:"audio/mp3"}); var audio = new Audio(URL.createOb
我正在尝试使用 C3 在我的 React 项目中呈现图表。 问题 我所做的是动态生成一个 id (UUID) 并将其附加到我的图表组件中的 div。然后,在组件在 componentDidMount
您好,我在 Chrome 中播放音频时遇到异常。 这是我播放音频的功能 $(document).ready(function () { generateAlarm(); }); functio
我正在开发一个 WebAudio 应用程序,它需要 AudioWorklets 并且需要来自许多不同脚本的函数以用于 process() 函数。因此,我尝试使用 import 命令在 processo
我正在学习本教程,该教程教授 polymer 元件的安装: https://www.polymer-project.org/3.0/start/toolbox/add-elements 运行 npm
我有Video Player 。但是当我改变质量时它给出了这个错误 Uncaught (in promise) DOMException: The play() request was interru
我正在尝试将加密数据从服务器发送到客户端,并使用window.crypto.subtle.decrypt()对其进行解密。但我有一个没有描述的错误。我该如何修复它? node.js 服务器代码: co
我收到这个错误: Uncaught (in promise) DOMException: lockOrientation() is not available on this device. co
我正在使用 indexedDB(通过 npm 的 idb 包装器)来存储表示音频 channel 数据的 2D Float32 数组。它在一段时间内工作正常,但是,当其中一个数组的长度达到大约 166
我是一名优秀的程序员,十分优秀!