0

在 Firefox 扩展中,我打开一个数据库文件并显示数据库内容。但是,Firefox 显示一些字符不正确,可能是由于编码问题。我尝试在 SQLite 数据库浏览器中打开数据库文件,并且名称列正确显示。

如何正确处理此文本字符串,以便它按预期输出字符(例如,Caché而不是Caché)?

重现此问题的代码片段:

var StorageService = Cc["@mozilla.org/storage/service;1"]
    .getService(Ci.mozIStorageService);
_Conn = StorageService.openDatabase(file);
var stmt = _Conn.createStatement("Select name from data");
var RunQuery = function () {
    return {
        arr: [],
        handleResult: function (aResultSet) {
            var row = aResultSet.getNextRow();
            alert([row.getResultByName("name"), 'Cach\u00E9']);
        },
        handleError: function (aError) {},
        handleCompletion: function (aReason) {}
    };
};
stmt.executeAsync(RunQuery());

输出:Caché,Caché
预期输出:Caché,Caché

4

2 回答 2

0

假设 IDX_NAME 是 column 的索引name,那么

alert([row.getUTF8String(IDX_NAME), 'Cach\u00E9']);

会给你预期的结果。

于 2013-02-15T21:42:44.033 回答
0

这似乎有效:

var converter = Cc["@mozilla.org/intl/scriptableunicodeconverter"]
    .createInstance(Ci.nsIScriptableUnicodeConverter);
converter.charset = "UTF-8";
alert([converter.ConvertToUnicode(row.getString("name")), 'Cach\u00E9']);
于 2013-02-15T22:02:08.860 回答