- objective-c - iOS 5 : Can you override UIAppearance customisations in specific classes?
- iphone - 如何将 CGFontRef 转换为 UIFont?
- ios - 以编程方式关闭标记的信息窗口 google maps iOS
- ios - Xcode 5 - 尝试验证存档时出现 "No application records were found"
在 OSS 网络应用程序中,我们有执行一些 Ajax 更新的 JS 代码(使用 jQuery,不相关)。页面更新后调用html5历史接口(interface)History.pushState
,代码如下:
var updateHistory = function(url) {
var context = { state:1, rand:Math.random() };
/* -----> bedfore the problem call <------- */
History.pushState( context, "Questions", url );
/* -----> after the problem call <------- */
setTimeout(function (){
/* HACK: For some weird reson, sometimes something overrides the above pushState so we re-aplly it
This might be caused by some other JS plugin.
The delay of 10msec allows the other plugin to override the URL.
*/
History.replaceState( context, "Questions", url );
}, 10);
};
[请注意:完整的代码段是为上下文提供的,HACK部分不是本题的问题]
该应用程序是国际化的,并且在 URL 中使用 URL 编码的 Unicode 段,因此在上面的代码中在标记的问题调用之前,URL 参数包含(如在 Firebug 中检查的那样):
"/%D8%A7%D9%84%D8%A3%D8%B3%D8%A6%D9%84%D8%A9/scope:all/sort:activity-desc/page:1/"
编码段为百分号编码的utf-8。浏览器窗口中的 URL 是:(只是为了完整性,并不重要)
http://<base-url>/%D8%A7%D9%84%D8%A3%D8%B3%D8%A6%D9%84%D8%A9/
在调用之后,浏览器窗口中显示的 URL 变为:
http://<base-url>/%C3%98%C2%A7%C3%99%C2%84%C3%98%C2%A3%C3%98%C2%B3%C3%98%C2%A6%C3%99%C2%84%C3%98%C2%A9/scope:all/sort:activity-desc/page:1/
URL 编码段只是 mojibake,是在某种程度上使用错误编码的结果。正确的 URL 应该是:
http://<base-url>/%D8%A7%D9%84%D8%A3%D8%B3%D8%A6%D9%84%D8%A9/scope:all/sort:activity-desc/page:1/
此行为已在 FF 和 Chrome 上进行了测试。
历史界面specs不要提及有关编码 URL 的任何内容,但我假设在接口(interface)的函数调用中使用 URL 时将应用 URL 形成的默认标准(utf-8 和百分比编码等)。
关于这里发生的事情的任何想法。
编辑:
我没有注意 History 中的大写 H - 这段代码实际上使用了 History.js历史界面的包装器。我替换为直接调用 history.pushState
(注意小写的 h)而不通过包装器,据我所知,代码按预期工作。原始代码的问题仍然存在 - 因此 History.js 库似乎存在问题。
最佳答案
作为Doug S在下面的评论中解释说,最新版本的 History.js 包含针对此行为的修复。他还发现我的解决方案在浏览器(例如 IE 9 及以下版本)中使用时会导致双重编码,这需要哈希回退,所以我建议不要使用下面详述的修复方法,而是使用 download the latest version .
我在下面保留了我的原始答案,因为它确实更详细地解释了正在发生的事情。
巴塞尔找到了某种解决方案,但对于引擎盖下发生的事情仍然存在一些困惑。该答案详细介绍了问题并提出了更好的解决方案。 (如果需要,您可以直接跳到修复。)
首先,打开浏览器的 JS 控制台并运行:
window.encodeURI(window.unescape('%D8%A7%D9%84%D8%A3%D8%B3%D8%A6%D9%84%D8%A9'))
是不是很眼熟?它应该——这就是您的 URL 被破坏的结果。问题出在执行 History.unescapeString
,特别是这一行:
tmp = window.unescape(result);
window.unescape
是 DOM Level 0函数——也就是说,一个来自 Netscape 2 古老时代的非标准化遗迹。它使用 RFC 2396 中定义的转义规则。 , 根据未保留范围之外的字符(字母数字和一小组标点符号)被编码为八位字节。
这适用于 US-ASCII 范围,但并非所有(实际上是绝大多数)UTF-8 字符都可以用单个字节表示。由于 URI 没有内置的方式来表示正在使用的字符集,window.unescape
只是假设每个字符都映射到一个八位位组,并愉快地破坏任何不映射的字符。
在此示例中,您的网址中的第一个字母是 Arabic letter alef (ا) ,由两个字节表示:0xD8 0xA7
. window.unescape
将这些解释为两个单独的字符: 0x00 0xD8
(Ø—capital O with stroke)和 0x00 0xA7
(§—section sign) .
这是一个 known issue使用 History.js。
正如提问者上面提到的,可以通过使用 History API 的 native 实现而不是 History.js 包装器来回避这个问题,即 <em>h</em>istory.pushState
而不是 <em>H</em>istory.pushState
.
这适用于支持 History API 的浏览器,但对于那些不支持的浏览器则失去了 polyfill 的好处。幸运的是,有更好的解决方法。打开您引用的 History.js 源并找到这一行(在我的副本中为 ~1059):
tmp = window.unescape(result);
替换为:
tmp = window.unescape(encodeURIComponent(result));
或者,如果您使用的是压缩源,请替换 a.unescape(c)
与 a.unescape(encodeURIComponent(c))
.
为了测试此更改,我在本地 Web 服务器上以阿拉伯语命名的目录中运行了 History.js HTML5 jQuery 测试套件。在进行更改之前,测试 14 失败;更改后,所有测试均通过。
尽管我独立找到了问题和解决方案,Damien Antipa值得称赞的是首先找到它并制作了pull request with the fix .
关于javascript - HTML5 History.pushState 破坏包含百分比编码的非 Ascii (Unicode) 字符的 URL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11068907/
我的函数概念上都返回相同的东西,但结果可以采用不同的形式: function GetThingy() 有四个不同的函数,每个可以返回不同的东西: 0.071(代表增长 7.1% 的 float 值)
这个问题在这里已经有了答案: Int division: Why is the result of 1/3 == 0? (19 个回答) 关闭 4 年前。 有什么方法可以计算(例如)120 的 50
我四处寻找这个,它看起来很简单,但我无法让它工作。 我有一张表格,其中一列需要格式化为百分比。下面是我的代码,但它没有格式化单元格,它只是将它们保留为小数。 我想这是因为 cell ,即使声明为范围,
我刚刚开始使用 WPF。从那以后,我开始关注造型系统。我来自 CSS 背景,我想以百分比设置边距。 当前值以像素为单位
我有一个表,其中每一行都有一个描述字段和一个 bool 值。我正在尝试编写一个查询,我可以在其中按每个相应的描述进行分组,并查看 bool 值为真的次数百分比。 示例表: PID Gen
我从文档中发现,考虑到 orientdb 100% 使用磁盘缓存,它使用的最大大小为 70% 用于读取缓存,30% 用于写入缓存 ( http://orientdb.com/docs/last/plo
有什么方法可以获取 docker 容器内部而不是外部的 cpu 百分比吗?! docker stats DOCKER_ID 显示的百分比正是我需要的,但我需要它作为变量。我需要获取容器本身内部的 cp
我正在尝试计算数据集每列中类别的比例(百分比)。 示例数据: df <- data.frame( "Size" = c("Y","N","N","Y","Y"), "Type" =
我应该使用小数还是 float 在数据库中存储比率?特别是在 SQL2005 中。 最佳答案 这取决于您对准确性的需求。如果您可以容忍来自存储 float 的 IEEE 方法的典型错误,则使用 flo
我正在创建一个游戏,目前必须处理一些math.random问题。 我的Lua能力不是那么强,你觉得怎么样 您能制定一个使用 math.random 和给定百分比的算法吗? 我的意思是这样的函数: fu
如何在SQL中动态计算百分比? 假设您有一个名为 Classes 的下表: ClassSession StudentName -------------------------------
如何通过 jQuery 创建具有百分比的数字掩码输入?我是否让输入仅接受三个数字,并在用户完成输入时在数字后添加百分号(keyup)? 我不使用插件。 示例:1% 或 30% 或 99% 或 100%
我正在尝试构建一个工具,可以突出显示具有最高介数中心性的社交网络节点。我将所有网络节点的测量值计算到字典中,按顺序对字典进行排序,然后仅保留前 3 对。 我希望这个工具是可扩展的,所以我想保留前 10
MYSQL 中的人员如何将一个日期条目和分数的用户百分比与另一个日期条目和分数进行比较,从而有效地返回从一个日期到另一个日期的用户百分比增加情况? 几天来我一直在试图解决这个问题,但我已经没有想法了,
我需要进行查询,结果是百分比。 我现在的查询如下所示: select COUNT(CREATE_WEEKDAY), CREATE_WEEKDAY, COUNT(CREATE
我有一个图像上传功能,其工作原理如下: $('.update-insertimage-form').submit(function() { $(".submit-newupdate-btn").add
我的问题很简单,但我仍然找不到这个问题的答案... 假设我们有两个包含图像的容器。 我们有类似的东西 #containera { width: 50%; height: 50%; backgr
是否可以将 CSS 尺寸指定为除其父元素之外的另一个元素的百分比?例如,我想将 div 的 border-radius 指定为 div 宽度的 10%。但是,border-radius: 10% 在
我正在尝试设置按钮的大小并以百分比进行编辑 但是这个的线性大小是不同的。为什么? 最佳答案 您好,问题出在属性 box-sizing 上.默认为 input type
我将它用于我的页眉,该页眉在一页上下滚动页面中发生变化。我注意到它没有响应,所以我想问你是否知道一种使它响应的方法。就像将 0-690 更改为百分比,以便它可以在移动设备和电视屏幕上使用。 HTML
我是一名优秀的程序员,十分优秀!