在使用 jQuery 時,我們經常會看到一些鏈式調用的代碼:
$('body').addClass('class1').removeClass('class2').html('Hello, world!');
這樣的代碼看起來很簡潔,但是卻存在一些壞處。
首先,這樣的代碼難以進行調試和維護。如果代碼出現了問題,我們很難知道是哪個方法出了問題。此時只能夠一個個分開調試。并且這種方式還會讓我們產生錯覺,認為這是一個長長的語句,實際上它被分成了多個方法調用。
其次,這樣的代碼對于代碼閱讀者來說很難理解。如果我們看到了一段長長的鏈式調用,我們需要破解這個調用來理解代碼的實際含義。這會浪費我們的時間,降低我們的效率。
最后,這樣的代碼違反了面向對象的編程原則。在面向對象的編程中,每個對象都應該有自己的方法,并且應該盡可能地進行封裝,避免對外暴露實現細節。然而在這樣的鏈式調用中,我們操作的是同一個 jQuery 對象,并且暴露了 jQuery 對象的實現細節。
因此,我們應該避免使用過多的鏈式調用。對于需要多個操作的情況,可以將其分成多個獨立的語句,這樣可以使代碼更加易于閱讀和維護,同時也符合面向對象的編程原則。