テキストWe are sorry but we made a boo boo
が表示された場合
- 5 秒待ちます
- リロード
これを JavaScript で行いたいと思います。
ここに試みがあります
(function () {
"use strict";
function walkTheDOM(node, func) {
if (node && node.nodeType) {
if (typeof func === "function") {
func(node);
}
node = node.firstChild;
while (node) {
walkTheDOM(node, func);
node = node.nextSibling;
}
}
}
function filterElementsByContains(elements, string) {
var toStringFN = {}.toString,
text = toStringFN.call(elements),
result,
length,
i,
element;
if (text !== "[object NodeList]" && text !== "[object Array]" && !($() instanceof jQuery)) {
return result;
}
result = [];
if (typeof string === "string") {
string = new RegExp("^" + string + "$");
} else if (toStringFN.call(string) !== "[object RegExp]") {
return result;
}
function getText(node) {
if (node.nodeType === 3) {
text += node.nodeValue;
}
}
length = elements.length;
i = 0;
while (i < length) {
text = "";
element = elements[i];
walkTheDOM(element, getText);
if (string.test(text)) {
result.push(element);
}
i += 1;
}
return result;
}
if(filterElementsByContains([document.getElementsByTagName("table")[0]], /We are sorry but we made a boo boo/).length) {
location.reload();
}
上記は、特定の場所に表示される場合、テキストに対して機能するはずです。より一般的なものにしたい -そのページのどこにでもテキストを表示できるようにする.
また、一時停止を追加して、たとえば、リロードする前に 5 秒待機する方法を知りたいです。
私は次のようなものを組み込むと思います:
setTimeout(
function()
{
//location.reload();
}, 5000);