javascript - 解析错误 JSON.parse(意外的标记 u)

标签 javascript arrays json

var storage = chrome.storage.local;
var cachedStorage = {};

这是 js 文件。它显示了意外的标记 u。即使我已经正确完成了解析。并且它还显示了其 html 源页面的意外标记。任何人都可以建议我如何解决这个问题。

<小时/>
var defaultStorage = [{
  savedPatterns: JSON.stringify([
    [{
      "en": "English"
    }, {
      "it": "Italian"
    }, "25", true],
    [{
      "en": "English"
    }, {
      "la": "Latin"
    }, "15", false]
  ]),

}];

error occurs here unexpected token u

function createPattern() {
  console.log('createPattern begin');
  var patterns = JSON.parse(S('savedPatterns'));
  var srce = [],
    trg = [],
    prb = [];
  console.log(S('savedPatterns'));
  console.debug(S('savedPatterns'));
  var translator = document.getElementById('translatorService');
  var service = translator.children[translator.selectedIndex].value;
  srce[0] = document.getElementById('sourceLanguage');
  srce[1] = srce[0].children[srce[0].selectedIndex].value;
  srce[2] = srce[0].children[srce[0].selectedIndex].text;
  trg[0] = document.getElementById('targetLanguage');
  trg[1] = trg[0].children[trg[0].selectedIndex].value;
  trg[2] = trg[0].children[trg[0].selectedIndex].text;
  prb[0] = document.getElementById('translationProbability');
  prb[1] = prb[0].children[prb[0].selectedIndex].value;

  patterns.push([
    [srce[1], srce[2]],
    [trg[1], trg[2]],
    prb[1],
    false,
    service
  ]);
  saveBulk({
    'savedPatterns': JSON.stringify(patterns)
  }, 'Saved Pattern');
  console.log('createPattern end');
}

function S(key) {
  return cachedStorage[key];
}

function loadStorageAndUpdate(callback) {
  storage.get(null, function(data) {
    console.log('data: ' + data + ' : ' + JSON.stringify(data));
    var d = {};
    if (!data || JSON.stringify(data) == '{}') { // in this case, storage was not initialized yet
      console.log('setting storage to defaultStorage (stringified): ');
      console.log(JSON.stringify(defaultStorage));
      storage.set(defaultStorage);
      d = defaultStorage;
    } else {
      d = data;
    }

    cachedStorage = d;
    if (!!callback) {
      callback(d);
    }
  });
}

最佳答案

JSON.parse 失败时,会出现

错误 意外的标记,并且根据字符(本例中为 u),您可以推测其原因。

  • u 表示值未定义
  • o 表示值是否为对象

try {
  JSON.parse(undefined)
} catch (ex) {
  document.write(ex.message + "<br/>")
}

try {
  JSON.parse({})
} catch (ex) {
  document.write(ex.message)
}

你可以尝试这样的事情:

function s(key) {
  var obj = {
    foo: "foo",
    bar: "bar"
  }
  var v = null;

  try {
    v = JSON.parse(obj[key]);
  } catch () {
    v = obj[key];
  }

  return v;
}

function main() {
  var v = s("foo");
}

请参阅以下帖子了解更多信息。 Uncaught SyntaxError: Unexpected token with JSON.parse

关于javascript - 解析错误 JSON.parse(意外的标记 u),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35933985/

相关文章:

javascript - 使用 Angular 时 HTML 表格中的行总和不正确

javascript - 如何检测鼠标是否移动到窗口的某个坐标上,JavaScript/Jquery?

javascript - 我如何在 JavaScript 中循环遍历 XML 节点?

javascript - 如何根据选择选项更改 <p> 的内容

javascript - Onchange 事件解决多个下拉菜单问题

php - 在php中合并两个数组

php - Android Http Post 不起作用

c++ - 双重选择对数组进行排序 - honeSTLy stumped

Python:创建数组的副本

java - 迭代列表并排列数据