我正在尝试编写Chrome扩展程序,作为其正在执行的操作的一部分,需要将图像添加到当前显示的html中.我想我需要使用document.createElement然后将其插入某处,但我不确定两件事:
图像作为扩展的一部分,即在任何地方都没有直接链接,因此简单地添加img标记将不起作用.除非我错过了什么.
与Chrome无关:如果html元素没有任何id,将img标记添加到特定位置的最佳方法是什么?我可以找到我想要使用正则表达式添加img的地方,并且如果需要可以重写整个html,但也许有一种我想念的更微妙的方式.
在Javascript程序中,我有一个具有以下两个(简化)函数的对象:
this.do_A = function() {
var nothing_changed = false;
while (!nothing_changed) {
nothing_changed = true;
for (var column=0; column<this.columns; column++) {
for (var row=0; row<this.rows; row++) {
nothing_changed = nothing_changed && this.do_B(row, column);
}
}
}
}
this.do_B = function(row, column) {
nothing_changed = true;
if (this[row][column] == null) {
nothing_changed = false;
}
return nothing_changed;
}
Run Code Online (Sandbox Code Playgroud)
当运行这段代码时,当do_B返回false时会发生一些非常奇怪的事情,因此当又到达时,nothing_changed变为false
for (var row=0; row<this.rows; row++)
Run Code Online (Sandbox Code Playgroud)
行,row变量立即变为this.rows内部循环终止.此外,它发生在外部循环的后续运行中 - row初始化为0,然后this.rows立即变为内部循环再次结束.
我没有理由可以导致这种情况.我已经尝试尽可能地简化功能并且它一直在发生.
这是一个愚蠢的问题,但我怎样才能使某些画布对象的笔触不可见?将宽度设置为 0 无济于事(薄,但可见),我不知道应该将笔划更改为哪种颜色。
通常人们要求更改地址栏而不刷新,我想要相反:我想跳到页面中的锚点,例如有
<a name="foo">
Run Code Online (Sandbox Code Playgroud)
然后实现与用户按下相同的功能
<a href="#foo">
Run Code Online (Sandbox Code Playgroud)
无需更改地址栏.这纯粹是装饰性的,但这意味着像"在完成后再次设置window.location"这样的建议将无济于事,因为中间的更改仍然会引人注意(地址栏会闪烁,这正是我想要的避免).
我有一个字典(但也可以是列表)形式的理解
my_dict = {bar: foo(bar) for bar in some_range if foo(bar) is not None}
Run Code Online (Sandbox Code Playgroud)
这避免了None向字典插入值,但它也迫使我foo对同一元素调用两次。有没有办法避免这种情况并且foo只调用一次,而不用生成带有值的哈希None并稍后对其进行修剪?