IOS的Block和代理
不同點:
他位有本質(zhì)的不同,Block是一個語言的特性,而代理是一種設(shè)計模式,這就是它們的不同;
在用于回調(diào)場景的區(qū)別:
Block適合在臨時或者不規(guī)范性的場景下使用;
代理模式適合長久性的或者規(guī)范性的場景下使用;
優(yōu)勢:
在多級回調(diào)場景下,Block有較明顯的優(yōu)勢;比如:
場景:
類A的對象需要從類B的對象獲取數(shù)據(jù),然而類B的對象又需要把任務(wù)代理給類C的對象;
代理:如果使用代理的話,則必須讓類B和類C都遵守相關(guān)代理;
Block:如果使用Block的話,只需要類A把Block傳給類B,類B再傳給類C即可;
與代理相比,Block顯得方便的多;
狀態(tài)設(shè)計:
- 狀態(tài)名字應(yīng)該用“已**”,不應(yīng)該用“待**”,因為用“待**”意味著把當(dāng)頭狀態(tài)與下一步狀態(tài)綁定了;如果將來狀態(tài)需要細化,或者流程需要變更,就會出問題;
- 整個流程的每一步變動,都應(yīng)該對應(yīng)個唯一的狀態(tài);否則,如果狀態(tài)需要細化,則就不得不借用其它渠道輔助判斷狀態(tài),并且會嚴重加大分析難度;
HTML代碼復(fù)用方案:
服務(wù)器端實現(xiàn) :
1.1 使用SSI,既通常的shtml文件;
1.2 asp、php等的include類語句,asp.net的模板頁和用戶控件;**客戶端實現(xiàn): **
2.1 使用javascript客戶端腳本;
2.1.1 可以在html文檔的onload事件中觸發(fā)一個js方法,在該方法中找到一個頁面元素作為容器,在該容器中輸出一段html代碼(可以定義一個字符串存儲要輸出的html代碼片段,比如:var str="<p>hello world!</p>";);
2.1.2 在頁面中使用<script type="text/javascript" src="Default3.aspx"></script>等腳本注冊塊(該處的Default3.aspx也可以是js腳本文件或其他實現(xiàn)js格式的服務(wù)器端輸出),在實現(xiàn)的腳本文件中用document.write方法把要復(fù)用的html代碼打印出來;
2.1.3使用AJAX實現(xiàn)。該方法有個缺陷,就是客戶端的有些瀏覽器默認是不支持ajax的跨站調(diào)用的;
2.2 使用iframe;
**備注: **
更多的情況下首選服務(wù)器端的實現(xiàn),除非是在一些實現(xiàn)靜態(tài)化的頁面或者一些特殊的場合再使用客戶端的實現(xiàn)。