日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Js命名冲突

發(fā)布時間:2024/10/12 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Js命名冲突 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1)如何避免JS沖突
A:匿名函數
在多人合作一個網站時,每個人都會寫自己的JS代碼,定義變量的時候有可能會引起命名沖突,如何避免這種沖突隱患呢?
一種最簡單有效的辦法是“匿名函數”將腳本包起來,讓變量的作用域控制在匿名函數之內。
匿名函數:(function (){})() 前面的括號內是函數體,后面的()表示執(zhí)行。
如:(function(){
  var name,user="test"; //包含在這個匿名函數中的變量,作用域不再是window,而是局限在函數內部。因為各自包在不同的匿名函數內,也就不再互相沖突了。
  })();
用匿名函數將腳本包起來,可以有效的控制全局變量,避免沖突隱患。
B:解決匿名函數之間的通信問題
上面的匿名函數確實解決了沖突,但是如果兩個代碼段之間需要訪問彼此的變量,那就被分隔開了,沒法訪問對方作用域中的變量.
一個比較好的解決辦法是"在window的作用域下定義一個全局變量",但是從上面的沖突來看,全局變量是引起沖突的殺手,如果又這樣定義,就違背了我們使用匿名函數的初衷,所以應該嚴格控制全局變量的數量!
為了控制全局變量的數量,用Hash對象作為全局變量。 var GLOBAl={}; //一個對象類型的變量作為全局變量,擴展性好
定義好對象類型變量后,在匿名函數A中定義GLOBAL的屬性:GLOBAL.str1="aaa"; 在匿名函數B中可以直接訪問var b = BLOBAl.str1;
這樣又出現了一個問題,當在匿名函數B中它也定義一個屬性BLOBAl.str1="bbb"; 這個時候就會把A塊中的屬性str1給覆蓋掉.如何避免這種沖突呢?不可能每個開發(fā)者在使用GLOBAL對象之前,都要查找一下綁定了哪些屬性。
這時,命名空間就出現了,它是一種特殊的前綴,在js中它其實是通過一個{}對象來實現的。我們可以給每個匿名函數聲明不同的命名空間,然后每個匿名函數中GLOBAL對象的屬性都不要直接掛在GLOBAl對象上,而是掛在此匿名函數的命名空間下,既:window全局的GLOBAL.命名空間.屬性變量 ,這樣申明屬性名稱的時候,即使同名,空間不一樣也不會引起沖突。如: GLOBAL.A={};// 定義命名空間; GLOBAL.A.str1="aaa";//定義屬性變量
復雜的匿名函數中,你還可以生產二級命名空間,如GLOBAL.A={};//一級命名空間,GLOBAL.A.CAT={};GLOBAL.A.DOG={};//二級命名空間;
生成命名空間是一個很常用的功能,可以將其封裝為一個函數。
var GLOBAL={};
GLOBAL.namespace=function(str){
  var arr=str.split("."),o=GLOBAL;
  for(i=(arr[0]=="GLOBAL")?1:0; i<arr.length; i++) {
    o[arr[i]]=o[arr[i]] || {};
    o=o[arr[i]];
  }
}
調用: GLOBAL.namespace('A.DOG'); GLOBAL.namespace('GLOBAL.B');
總結:解決js沖突-------全局變量+命名空間+匿名函數很好的結合使用才能更好的解決沖突。
C:注釋
添加必要的代碼注釋,可大大提高可維護性,對團隊合作來說,是很重要的。
注釋添加的信息包括:功能說明;工程師姓名;工程師聯(lián)系方式;代碼最后修改時間;
讓JS不產生沖突,需要避免全局變量的泛濫,合理使用命名空間,以及給代碼添加注釋。

轉載于:https://www.cnblogs.com/xinyeblog/p/5462428.html

總結

以上是生活随笔為你收集整理的Js命名冲突的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。