如何解决使用Inspect Element
这是JavaScript代码:
<script type="text/javascript">
var javascript_countdown = function ()
{
var time_left = 10; //number of seconds for countdown
var keep_counting = 1;
var no_time_left_message = 'Please Activate Javascript.';
function countdown()
{
if(time_left < 2)
{
keep_counting = 0;
}
time_left = time_left - 1;
}
function add_leading_zero( n )
{
if(n.toString().length < 2)
{
return '0' + n;
}
else
{
return n;
}
}
function format_output()
{
var hours,minutes,seconds;
seconds = time_left % 60;
minutes = Math.floor(time_left / 60) % 60;
hours = Math.floor(time_left / 3600);
seconds = add_leading_zero( seconds );
minutes = add_leading_zero( minutes );
hours = add_leading_zero( hours );
return minutes + ':' + seconds;
}
function show_time_left()
{
document.getElementById('javascript_countdown_time').innerHTML = format_output();//time_left;
document.getElementById('javascript_countdown_time_bottom').innerHTML = format_output();//time_left;
}
function no_time_left()
{
//document.getElementById('javascript_countdown_time').innerHTML = no_time_left_message;
//alert("");
document.FormAzmoon.submit();
}
return {
count: function () {
countdown();
show_time_left();
},timer: function () {
javascript_countdown.count();
if(keep_counting) {
setTimeout("javascript_countdown.timer();",1000);
} else {
no_time_left();
}
},init: function (n) {
time_left = n;
javascript_countdown.timer();
}
};
}();
javascript_countdown.init(601);// Time Recorder Secends
</script>
此Javascrip代码是页面中的反向计时器(10分钟)。
当timer = 0时,它将自动提交页面。
我想操纵它以增加时间。
我认为增加时间的最佳方法是以下行:
setTimeout("javascript_countdown.timer();",1000);
更改为:
setTimeout("javascript_countdown.timer();",100000);
当我在Firefox中更改Inspector
的{{1}}上的该值时,没有任何反应。
那么解决方案是什么?
如果还有除Firefox以外的其他方法,请教我!
还教我如何通过控制台重写和操作函数中的变量!
解决方法
JS将被解析并在中运行。在JS运行后更改页面标记不会更改JS的运行。您需要以其他方式进行更改。
一种选择是用您自己的函数覆盖.timer
函数。页面脚本运行后,打开控制台并运行:
// save a reference to the original function if you need to
const origTimer = javascript_countdown.timer;
javascript_countdown.timer = () => null;
这将阻止页面对.timer
的调用执行任何操作。然后,一旦要提交表单,只需手动调用document.FormAzmoon.submit();
。
还教我如何通过控制台重写和操作函数中的变量!
如果您实际上不得不采用这种方法,那几乎是不可能的,请参阅this question了解详细信息。简而言之,您需要使用一个用户脚本(或其他在页面加载开始时运行的脚本),使用MutationObserver来拦截<script>
标签的添加,并用其textContent
进行一次修饰。您会检测到脚本的添加。
确定要正确使用setTimeout吗? 尝试在检查中将setTimeout更改为此:
setTimeout(javascript_countdown.timer,100000);
如果这样不起作用,请尝试其他浏览器。也许Firefox不允许您在Inspect中设置计时器
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。