函数中 给element的onclick属性赋值了一个闭包,闭包要访问element的id属性。闭包在js中也是对象,函数即对象。闭包会持有外部传入的变量,因此闭包持有了element对象,而element对象通过onclick属性持有了闭包,因此两个对象相互持有,造成内存泄漏。
与OC类比,OC中使用weak对象引用,来解决循环引用的问题,js中也有类似操作,例如:
因为var id是由赋值得到的,js的赋值操作是值或者引用的拷贝,并不持有对象。此时element持有闭包,闭包持有id对象,并未造成循环引用。
使用Excel操作单元格的时候,弹出了循环引用的提示,按照如下步骤即可取消Excel中的循环引用警告: 1、首先打开一个excel表格,可以看到弹出了一个对话框提醒循环引用警告。 2、然后点击上方工具栏中的文件。 3、再点击文件选项卡下的选项。 4、在弹出的对话框中点击公式,在右侧勾选启用迭代计算。 5、最后点击确定即可取消excel中的循环引用警告了。首先打开EXCEL,点击“工具”。 2、在工具里选择“选项”。 3、打开选项对话框之后就会看到如图所示,点击“重新计算”。 4、勾选“迭代计算”,计算数为100,然后点击确定,这时候就不会再弹出“选循环引用”警告了需要找到“excel选项”,这个地方在Office 2003版本里的“工具”选项里,而在Office 2007版本里不好找,在所以这种强调一下,避免有些朋友找不到。 3 其次,点击“公式”选项,在“计算选项”中,可以看到“启用迭代计算”前面是没有勾选上的,将其勾选上之后,就能解决“循环引用”警告的问题了,表示excel默认可以进行循环引用。 4 最后,在“公式”选项卡上的“公式审核”中,点击“错误检查”,可以看到“循环引用”变成了灰色,处于不可操作状态。 END 方法二:针对公式使用错误 针对公式使用错误导致的“循环引用”警告,这种情况就需要对公式本身进行更改。在“公式”选项卡中,错误检查的下