一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

在js中使用"with"語句中跨frame的變量引用問題

在腳本編程時使用with語句,可以大大的縮減使用多級對象引用代碼行的長度,這是JScript提供給我們的一個Syntax Sugar。當然不使用with,使用臨時變量也可以達到同樣的效果。不過創建變量時起名確實不是一件很遐意的事,就連MASM高版本中也提供了一個@@(以及@F和@B)來處理臨時標號的問題,看來大家都是比較懶得啦。 

     我也挺喜歡用with語句的,確實可以省不少的事情,而且可以讓代碼變得也清晰些,特別是在處理跨frame的變量引用時,更加顯得方便。這不今天就因為貪圖方便又撞到槍口上了,在with中去取跨frame的變量時,遇到一個莫名其妙的bug郁悶了半天。 

     我寫的代碼其實不復雜,就是在一個with中,作了很多另一個frame中的變量引用和計算操作后,把結果賦值到本頁面函數的一個局部變量里。事例代碼大概如下:  // ... 
 var hierarchies = []; 
 with(parent.frames['xxxFrame']) 
 { 
     // 引用xxxFrame里的變量和值產生我要的東西 
     hierarchies.push(xxx); 
 } 

 // 開始使用hierarchies 
     這時hierarchies比較發瘋,不管怎么弄里面的值老是和想要得值有卻別,但又不是完全不對(后面會說為什么會這樣,同時這是也嚴重迷惑我debug的一個地方,被害慘了)。 

     為什么會這樣?最后查出來原來是xxxFrame里也有一個叫hierarchies的變量,而且也是數組,放的內容居然也和我放的差不多,所以我前面說了為什么會被迷惑了吧。而且還不止這點,由于之前還寫了一個這種類似的with來跨頁面取數據,而且工作的很好,所以潛意識就覺得,with里的那個hierarchies就是with外的那個hierarchies。我也不記得xxxFrame中那個變量是不是我自己定義的了,反正debug時被郁悶了好一陣子:(。 

     JScript手冊說with(objects) statements的作用是:為語句設定默認對象。不過在with內部對變量的作用范圍,它有個搜索規則,就是優先做默認對象(objects)中的匹配。雖然有時覺得默認對象的作用域更"遠",就像跨frame這種情況。當默認對象引用中不能匹配,就匹配with之前被聲明過的變量。都不能匹配到就是undefined了。 

     本文只能老實收入"debug中的滑鐵盧"中了。

JavaScript技術在js中使用"with"語句中跨frame的變量引用問題,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国语精品91自产拍在线观看二区 | 亚洲a毛片 | 在线观看成人小视频 | 成年ssswww网站 | 亚洲国产成人超福利久久精品 | 97影院在线午夜 | 狼人伊人干 | 国产91一区二这在线播放 | 欧美ccc| 国产第2页 | 久久免费区一区二区三波多野 | 欧美精品做人一级爱免费 | 好吊色免费视频 | 人和拘一级毛片 | 涩综合| 精品国产福利 | 福利免费视频 | 成人a毛片手机免费播放 | 两性午夜刺激性视频 | 天堂在线观看 | 国产亚洲福利 | 午夜精品久久久久久中宇 | 久久精品伦理 | 伊人网国产 | 香蕉久热 | 四虎在线最新永久免费 | 亚洲88av| 欧美国产亚洲精品a第一页 欧美国产一区二区二区 | 在线精品国内视频秒播 | 色多多免费观看 | 久久久久久久影院 | 日本在线观看一级高清片 | 99成人精品 | 天天操夜夜做 | 久久综合网久久综合 | 亚洲一区二区三区福利在线 | www.精品视频| 一区二区三区在线免费看 | 久99re视频9在线观看 | www.一区| 亚洲小视频网站 |