- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试构建一个脚本来改变 the tag page in the user-profile section of Stack Overflow 上标签的着色/布局。 .
我测试了脚本并且它运行了。问题是当我单击排序选项 [votes] 和 [name] 时,我想重新运行它。
我试过:
ready
事件。onclick
处理程序(这是无用的,因为它在页面重新加载之前运行)。load
事件监听器附加到带有标签等的表上,但无济于事。我确定我在这里遗漏了一些非常明显的东西。我怀疑涉及一些异步重新加载,但我无法理解使这项工作所需的操作是什么。
谁能解释我遗漏的内容(或指出一些解释它的文档)?
最佳答案
这是一个常见问题。该页面使用 AJAX 仅替换其部分内容。因此,触发 jQuery 的 ready
事件将不起作用,因为它只会在初始的完整页面加载后触发。
以下是常用的解决方法/方法以供引用。我只推荐第一个:
使用强大的轮询实用程序,例如 waitForKeyElements() .这需要加载外部脚本(通常不是问题),并且需要 jQuery,无论如何您都应该使用它。下面详细介绍了这种方法。
触发 hashchange
事件。有些页面非常好,可以在 AJAX 更改页面时触发此事件。不幸的是,Stack Overflow 不是那些“礼貌”的网站之一。 ;-)
触发对 URL 的其他更改。有些页面非常好,可以在 AJAX 更改内容时更改 URL。 Stack Overflow 会这样做。
不幸的是,在 SO 的情况下,URL 会立即更改,而实际页面更改会在可变(不可预测的)延迟之后发生。这意味着您还必须使用其他技术之一。
拦截页面的 AJAX。这可能会变得复杂和困惑,并且通常仍然需要轮询或延迟,因为实际页面更改可能会在 AJAX 请求完成后的可变时间间隔内发生。从页面可能产生的多种类型中识别正确的 AJAX 请求也可能很麻烦。
使用 MutationObserver
。这可能是最强大的技术,并且是变化驱动的而不是轮询。但它在大多数情况下都有些矫枉过正,实现起来可能很棘手,并且可能会因 CPU 峰值而“卡住”计算机。
请注意,Mutation Events 是一种较旧的技术,它已过时,并且有充分的理由被弃用。不要尝试使用它,尽管某些浏览器尚未删除此功能。
在几乎所有针对 AJAX 驱动页面的脚本中,我们真正想要的只是对某些类型的内容采取行动。艺术是识别该内容,然后很容易使用像 waitForKeyElements() 这样的实用程序每当我们的目标负载被添加或替换时触发。
在你的例子中,内容似乎是出现在这个 HTML 中的标签列表:
<div id="user-tab-tags">
...
<div class="user-tab-content">
<table class="user-tags">
...
</table>
</div>
...
</div>
table.user-tags
每次您更改该选项卡的排序/分页选项时都会被替换。
因此该内容的 jQuery 选择器将是:
"#user-tab-tags div.user-tab-content table.user-tags"
和一个完整的脚本来改变样式是:
// ==UserScript==
// @name _AJAX_compensation techniques
// @include http://stackoverflow.com/users/*
// @require http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js
// @require https://gist.github.com/raw/2625891/waitForKeyElements.js
// @grant GM_addStyle
// ==/UserScript==
/*- The @grant directive is needed to work around a design change
introduced in GM 1.0. It restores the sandbox.
*/
waitForKeyElements (
"#user-tab-tags div.user-tab-content table.user-tags",
customStyleUserTags
);
function customStyleUserTags (jNode) {
jNode.css ("background", "lime");
//***** YOUR CODE HERE *****
}
关于javascript - 对内部选项卡(不是浏览器选项卡)的更改运行 Greasemonkey 脚本?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13976495/
在 Android 的 API > 19 中是否有任何方法可以获取可移动 SD 卡的路径? 与外部 SD 卡一样,我们有 Environment.getExternalStorageDirectory
一些 Android 设备有 microSD(或其他存储卡)插槽,通常安装为 /storage/sdcard1 据我所知,自 Android 4.4 起 Google 限制了对此内存的访问,并在 An
我使用 Java Card 2.1.2 SDK 和 GPShell 作为与设备通信的方式在 Java Card 上构建一个项目。我从 GpShell 测试了 helloworld 示例,并成功发送了
我开发了一个应用程序,它有一个来电接收器,它适用于所有手机。一位用户有一部双 SIM 卡安卓手机。该应用程序适用于第一张 SIM 卡。但是当有人调用他的第二张 SIM 卡时,我们的应用程序不会被调用。
我有一个带预览的文件输入。 这是笔 Codepen 我想强制高度,我无法理解我该怎么做。我想将此组件的高度固定为 300px(示例),我还需要保持加载图像的正确纵横比,用灰色背景填充空白。现在我保持宽
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 6年前关闭。 Improve this qu
我正在使用此代码访问 SD card : import os from os.path import join from jnius import autoclass #from android.pe
我正在为数据记录设备编写固件。它以 20 Hz 的频率从传感器读取数据并将数据写入 SD 卡。但是,向SD卡写入数据的时间并不一致(大约200-300 ms)。因此,一种解决方案是以一致的速率将数据写
我正在使用以下代码将视频放到网站上,但是在垂直方向上,手机屏幕上只能看到视频的左半部分 我不是网络开发人员。有人可以告诉我确切的内容吗,如何使其正确放置在手机屏幕上? 是在youtube iframe
我正在使用 Vuetify 1.5 和 Vuetify 网格系统来设置我的布局。现在我有一个组件 HelloWorld我将其导入到我的 Parent 中成分。我已经在我的 HelloWorld 中设置
我使用 python 制作了一个简单的二十一点游戏。我制作了游戏的其余部分,但我正在努力放入 ASCII 卡,所以这只是代码的一小部分。我尝试将 * len(phand) 放在附加行的末尾。虽然这确实
我正在使用玩家卡设置 Twitter 卡。它可以在预览工具中运行,但文档说它需要在“twitter.com 现代桌面浏览器? native iOs 和 Android Twitter 应用程序?mob
任何旧的 GSM 兼容 SIM 卡(3G USIM 的奖励)。 我想我需要一些硬件?谁能为业余爱好者推荐一些便宜的东西,以及一些更专业的东西? 我认为会有一个带有硬件的 API 的完整文档,所以也许这
我使用 python 制作了一个简单的二十一点游戏。我制作了游戏的其余部分,但我正在努力放入 ASCII 卡,所以这只是代码的一小部分。我尝试将 * len(phand) 放在附加行的末尾。虽然这确实
我记得前一段时间读到有 cpu 卡供系统添加额外的处理能力来进行大规模并行化。任何人都有这方面的经验和任何资源来研究项目的硬件和软件方面吗?这项技术是否不如传统集群?它更注重功率吗? 最佳答案 有两个
我检查外部存储是否已安装并且可用于读/写,然后从中读取。我使用的是确切的官方 Android 示例代码 ( from here )。 它说外部存储未安装。 getExternalFilesDir(nu
在 Android 2.1 及更低版本中,Android 应用程序可以请求下载到 SD 卡上吗?另外我想知道应用程序是否可以请求一些包含视频的文件夹下载到 SD 卡上?以及如何做到这一点? 提前致谢。
我们编写了一个 Windows 设备驱动程序来访问我们的自定义 PCI 卡。驱动程序使用 CreateFile 获取卡的句柄。 我们最近在一次安装中遇到了问题,卡似乎停止工作了。我们尝试更换卡(更换似
有些新设备(例如 Samsung Galaxy)带有两个 SD 卡。我想知道是否有任何方法可以确定设备是否有两张 SD 卡或一张 SD 卡。谢谢 最佳答案 我认为唯一的方法是使用 检查可用根的列表 F
我正在尝试将文件读/写到 SD 卡。我已经尝试在我的真实手机和 Eclipse 中的模拟器上执行此操作。在这两种设备上,对/mnt/sdcard/或/sdcard 的权限仅为“d--------”,我
我是一名优秀的程序员,十分优秀!