成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

框架設計中的主體函數

開發 架構
今天我們將談到的是框架設計中的主體函數,包括主體控制函數和一些公用方法。包括 拋異常,打日志。

  JS 這個后產物種真的是讓人糾結。現在的狠多人用JQUERY。但jquery對模塊管理,依賴管理。已經需求加載。這些都無視了。GG的closure YAHOO!的 YUI沒有哪個象他那樣大膽的捆綁那么多的方法到一個整個文件而且又對函數不進行區塊分離。以至于jquery天生就不能用到大項目。插件的缺失。(有人說jquery的插件多如牛毛,可是垃圾插件比牛毛還多。。你的系統不臃腫么???)很多人喜歡它是因為它的接口很好。一口多用。即可以設置,又可以讀取,設置可以多手段。取出的又很實際。這樣的接口現在很多的公司也開始模仿。我在想做的就是在JQUERY的接口思路上。用closure DOJO YUI這樣的大型架構思路來做個自己的庫。選擇器這樣的東西基本隨便找個庫都有吧。可是接口人們總是覺得不爽。我開始發現自己工作之后的時間不僅僅是可以用來打個DOTA-醬油。我們需要不斷努力。一起做出非常棒的插件。看看jquery的成就。相信。我在我師傅的指導下。一定成功。

  下面是主體控制函數和一些公用方法。包括 拋異常,打日志。擴展,遍歷。設置方法模型路徑。獲取模型(之前必須設置才可以獲取不然拋異常)判斷(數據)。

修正

  1. (function(window,undefined){  
  2. var_toString = {}.toString,  
  3. _is,  
  4. _writeScript,  
  5. _listUrl,  
  6. _scriptMap = {  
  7. method_url : {},//method --> url <method : url ><1 : 1 >  
  8. url_method : {},//url --> method <url : [method,method] ><1 : n >  
  9. visited : {},  
  10. writted : {},  
  11. wait_write:[]  
  12. },  
  13. _readyFnx = [],  
  14. alfred = function(){//自己單獨使用也可以。象jquery  
  15. alfred.ready.apply(window,arguments);  
  16. };  
  17. //私有函數開始  
  18. _is = function(it,type){//復雜的可以自己進行設置。正則匹配。  
  19. returntype.test(_toString.call(it).toLowerCase());  
  20. };  
  21. _waitReady = function(){  
  22. //等結束。如果結束了。直接跳出循環。其實就是利用JS的這個特性。  
  23. if(document.readyState != "loaded" &&document.readyState != "complete")  
  24. {  
  25. vartime = setTimeout(arguments.callee,0);  
  26. return;  
  27. }  
  28. clearTimeout(time);  
  29. }  
  30. _checkReady = function(){  
  31. //處理參數  
  32. for(vari=0;i<arguments.length;i++)  
  33. {  
  34. _readyFnx.push(arguments[i]);  
  35. }  
  36. varcallback = _readyFnx.shift();  
  37. //支持高級事件的  
  38. if(document.addEventListener)  
  39. {  
  40. document.addEventListener("DOMContentLoaded",function(){  
  41. _waitReady();  
  42. document.removeEventListener("DOMContentLoaded",arguments.callee,false);  
  43. callback.apply(window,_readyFnx);  
  44. });  
  45. returnthis;  
  46. }  
  47. //支持事件則用事件處理 IE  
  48. if(document.attachEvent)  
  49. {  
  50. document.attachEvent( "onreadystatechange", function(){  
  51. _waitReady();  
  52. document.detachEvent( "onreadystatechange",arguments.callee);  
  53. callback.apply(window,_readyFnx);  
  54. });  
  55. returnthis;  
  56. }  
  57. //不支持的則看不在 iframe 下時候的特殊屬性。看 JSCRIPT MSDN。  
  58. if(document.documentElement.doScroll &&window == window.top)  
  59. {  
  60. try 
  61. {  
  62. document.documentElement.doScroll("left","top");  
  63. }  
  64. catch(e)  
  65. {  
  66. setTimeout(arguments.callee, 0);  
  67. return;}  
  68. callback.apply(window,_readyFnx);  
  69. returnthis;  
  70. }  
  71. };  
  72. _listUrl = function(){  
  73. varl = _scriptMap.visited,i;  
  74. //對我們的URL 進行篩選 。主要防止多次添加訪問過的依賴庫。  
  75. for(i inl){  
  76. if(!_scriptMap.writted[i])  
  77. {  
  78. _scriptMap.wait_write.push(i);  
  79. }  
  80. }  
  81. _scriptMap.wait_write.reverse();  
  82. _writeScript();  
  83. };  
  84. _writeScript = function(){  
  85. //寫入我們的JS 了。  
  86. varhead = document.getElementsByTagName("head").item(0),len = _scriptMap.wait_write.length;  
  87. for(vari;_scriptMap.wait_write.length&&(i=_scriptMap.wait_write.shift());) {  
  88. varscript = document.createElement("script"),  
  89. url = i || "";  
  90. script.setAttribute("async",true);//高級瀏覽器支持HTML5特性  
  91. script.setAttribute("type","text/javascript");  
  92. script.setAttribute("src",url);  
  93. head.appendChild(script);  
  94. _scriptMap.writted[url] = true;//這里無所謂,只要有這個URL就可以  
  95. };  
  96. };  
  97. alfred.extend = function(){  
  98. vardeep = false,  
  99. len,  
  100. options, name, src, copy, copyIsArray, clone,  
  101. target = arguments[0] || {},  
  102. i = 1;  
  103. len = arguments.length;  
  104. if(!len)  
  105. {  
  106. returnthis;  
  107. }  
  108. if(alfred.isBoolean(target))  
  109. {  
  110. deep = arguments[0];  
  111. to = arguments[1];  
  112. i = 2;  
  113. }  
  114. if(!(alfred.isObject(target) || alfred.isFunction(target))) {  
  115. target = {};  
  116. }  
  117. if(len = i)  
  118. {  
  119. target = this;  
  120. --i;  
  121. }  
  122. for(;i<len;i++) {  
  123. if((options=arguments[i])!==null)  
  124. {  
  125. for(name inoptions) {  
  126. copy = options[name];  
  127. src = target[name];  
  128. if(src){throw"Becareful : you are rewrite the "+_handle+"."+name+"!"}  
  129. if(copy===target) {continue}  
  130. if(deep &© &&(alfred.isObject(copy) || (copyIsArray = alfred.isArray(copy))))  
  131. {  
  132. if(copyIsArray)  
  133. {  
  134. copyIsArray = false;  
  135. clone = src &&alfred.isArray(src) ? src : [];  
  136. }  
  137. else 
  138. {  
  139. clone = src &&alfred.isObject(src) ? src : [];  
  140. }  
  141. target[ name ] = alfred.extend( deep, clone, copy );  
  142. }  
  143. elseif( copy !== undefined )  
  144. {  
  145. target[name] = copy;  
  146. }  
  147. }  
  148. }  
  149. }  
  150. };  
  151. alfred.isNumber = function(it){return_is(it,/^[object number]$/)};  
  152. alfred.isString = function(it){return_is(it,/^[object string]$/)};  
  153. alfred.isFunction = function(it){return_is(it,/^[object function]$/)};  
  154. alfred.isObject = function(it){return_is(it,/^[object object]$/)};  
  155. alfred.isArray = function(it){return_is(it,/^[object array]$/)};  
  156. alfred.isBoolean = function(it){returntypeofit ==='boolean'};  
  157. alfred.isDom = function(it){return_is(it,/^[object htmlw+]$/)};  
  158. alfred.extend({  
  159. author : "alfred",  
  160. version : 1.01,  
  161. global : window,  
  162. doc : window.document,  
  163. reset : function(it){alfred.global[it]=alfred;},  
  164. log : function()  
  165. {  
  166. if(window.console &&console.log)  
  167. {  
  168. returnconsole.log.apply(window,arguments)  
  169. }  
  170. },  
  171. error : function(name,value)  
  172. {  
  173. throw{"name":name,"message":value};  
  174. },  
  175. require : function(method)  
  176. {  
  177. varm2u = _scriptMap.method_url,  
  178. u2m = _scriptMap.url_method,  
  179. r;  
  180. if(!(m2u[method])){throw"Error : you need setMethod first"}  
  181. if(!_scriptMap.visited[m2u[method][0]] &&!_scriptMap.writted[m2u[method][0]]) {  
  182. //haven't be visited or write  
  183. _scriptMap.visited[m2u[method][0]] = true;  
  184. //use an beautiful code in here  
  185. for(; m2u[method][1].length &&(r=m2u[method][1].shift());)  
  186. {  
  187. alfred.require(r);  
  188. }  
  189. _listUrl();  
  190. }  
  191. },  
  192. setMethod : function(url,method,rely)  
  193. {  
  194. vari, method = alfred.isArray(method)? method:[method],  
  195. rely = alfred.isArray(rely)?rely:[rely];  
  196. if(url &&!_scriptMap.url_method[url]){  
  197. _scriptMap.url_method[url] = method;  
  198.  
  199. for(;method.length&&(i=method.shift());) {  
  200. _scriptMap.method_url[i] = {"0" : url, "1" : rely};  
  201. }  
  202. returnthis;  
  203. }  
  204. throw"Error : you are setMethod in an old method";  
  205. },  
  206. ready : function(){  
  207. _checkReady.apply(window,arguments);  
  208. },  
  209. each : function(arg,callback){  
  210. for(vari inarg){  
  211. if(arg[i])  
  212. {  
  213. callback.call(arg[i],i);  
  214. }  
  215. }  
  216. returnarg;  
  217. }  
  218. });  
  219. window.alfred = alfred;  
  220. })(window) 

   用的時候先引入這個文件。然后需要類似這樣設置

 

  1. alfred.setMethod("basic.js",["alfred","alfred.global","alfred.doc","alfred.reset","alfred.log","alfred.isNumber",  
  2. "alfred.isFunction","alfred.isArray","alfred.isObject","alfred.isString","alfred.isBoolean",  
  3. "alfred.require","alfred.setMethod","alfred.extend"],[]); 

  這樣設置了以后就可以告訴下面的JS 我已經提供了這些方法。隨意alfred.require("alfred.reset"); 就可以把文件拉進頁面注冊好。

  頁面內是這樣的。

 

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4. <title> 
  5. </title> 
  6. </head> 
  7. <body> 
  8. <script type="text/javascript" src="base.js"></script> 
  9. <script type="text/javascript" src="deps.js"></script> 
  10. <script type="text/javascript"> 
  11. alfred.reset("$");  
  12. $.require("alfred.dom");  
  13. $(function(){  
  14. vara = $.dom("<div id='test' style='width:200px;height:200px;background:red;'> adf</div>");  
  15. $.dom("body").prepend(a);  
  16. })  
  17. </script> 
  18. </body> 
  19. </html> 

 

  alfred.reset 是為了方便自己設置方法名字。這樣我們幾乎可以象jquery一樣使用了。

  alfred.reset("$");

  $.require("alfred.dom");

  $.dom("div a span:first-child").append("hello alfred");

  就 可以這樣用了。。

  如果感覺這樣不爽。歡迎各位朋友來交流下。我剛學JS 不是很久。所以技藝不高,研究不深。忘各位來指點下。互相提高。QQ:164864042

  -------無代碼 ,生活不***。

  開始 到結束 只是那么個過程。結束了 就忘記吧。

原文鏈接:http://www.cnblogs.com/AlfredLee/archive/2012/01/17/base-js.html

【編輯推薦】

  1. 上網搶不到火車票,你該罵誰?
  2. 牛人分享網上訂火車票的小技巧:Firefox+Firebug
  3. 大型JavaScript應用程序架構模式
  4. 京東今天還在用.NET架構的原因是什么?
  5. 系統架構師談企業應用架構之服務層
責任編輯:彭凡 來源: 博客園
相關推薦

2011-04-22 09:26:57

MVC設計

2012-06-25 12:43:26

.NET框架

2020-07-30 10:35:32

Java反射框架設計

2012-06-25 09:28:42

.NET可逆框架

2016-03-23 11:05:58

Socket開發框架分析

2009-09-08 09:12:12

LINQ構建框架設計

2022-09-15 18:32:13

SPI模型框架

2021-02-23 08:18:04

Java 反射機制

2022-06-15 11:01:59

自定義SPIJava

2023-10-26 09:02:30

框架設計模式

2010-09-25 13:09:39

UISymbian

2012-01-10 10:04:43

Node.js

2022-04-03 15:44:55

Vue.js框架設計設計與實現

2022-10-10 09:11:12

互聯網存儲系統云計算

2013-09-03 09:35:48

無線客戶端框架設計iOS

2013-09-03 09:55:42

iOS無線客戶端框架設計

2013-09-09 10:48:24

iOS無線客戶端框架設計

2017-04-12 23:33:38

DevOps平衡計分卡框架

2022-09-25 21:45:54

日志平臺

2024-01-31 22:08:18

分布式重試框架
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品国产精品国产专区不蜜 | 国产高清精品一区二区三区 | 成人一区二区三区 | 亚洲一区二区日韩 | 精品伊人| 老司机精品福利视频 | 久久久久国产 | 国产成人精品免高潮在线观看 | 2019天天操| 99一区二区 | 亚洲一区二区三区免费观看 | 在线免费观看一区二区 | 欧美aaaa视频 | 久久人体视频 | 亚洲一级毛片 | 国产黄色av网站 | 天天操天天摸天天爽 | 91精品国产91久久久久久丝袜 | 亚洲人精品午夜 | 亚洲福利 | 蜜桃免费一区二区三区 | 成人av一区| 国产激情在线 | 欧美不卡 | 成人久久久 | 国产蜜臀97一区二区三区 | 成人午夜在线 | 精品欧美视频 | 九九九久久国产免费 | 国产精品久久久久久久久久久久久 | 国产精品精品视频一区二区三区 | 欧美精品综合在线 | 国产精品福利一区二区三区 | 久草网站 | 欧美激情欧美激情在线五月 | 亚洲久视频 | 在线a视频| 自拍偷拍精品 | 国产一区二区三区在线观看免费 | 久久成人精品视频 | 在线一区视频 |