1. /*!
  2. * Cloudgamer JavaScript Library v0.1
  3. * Copyright (c) 2009 cloudgamer
  4. * Blog: http://cloudgamer.cnblogs.com/
  5. * Date: 2009-10-15
  6. */
  7.  
  8. var $$, $$B, $$A, $$F, $$D, $$E, $$CE, $$S;
  9. function wr(text, ap) {
  10. if (ap) {
  11. document.getElementById("WriteDiv").innerHTML += text;
  12. } else {
  13. document.getElementById("WriteDiv").innerHTML = text;
  14. }
  15. }
  16. (function (undefined) {
  17.  
  18. var O, B, A, F, D, E, CE, S;
  19.  
  20. /*Object*/
  21.  
  22. O = function (id) {
  23. return "string" == typeof id ? document.getElementById(id) : id;
  24. };
  25.  
  26. //保存了一个空的function,主要用来代替空function节省资源。
  27. O.emptyFunction = function () { };
  28.  
  29. //扩展对象(override:是否继承属性值)destination格式:var a={name:'1',age:12'}或某个对象:new class();
  30. O.extend = function (destination, source, override) {
  31. if (override === undefined) override = true;
  32. for (var property in source) {
  33. if (override || !(property in destination)) {
  34. destination[property] = source[property];
  35. }
  36. }
  37. return destination;
  38. };
  39.  
  40. //深度扩展,这里的深度跟深度复制里面的意思差不多,参考的是jQuery的extend。
  41. O.deepextend = function (destination, source) {
  42. for (var property in source) {
  43. var copy = source[property];
  44. if (destination === copy) continue;
  45. if (typeof copy === "object") {
  46. destination[property] = arguments.callee(destination[property] || {}, copy);
  47. } else {
  48. destination[property] = copy;
  49. }
  50. }
  51. return destination;
  52. };
  53.  
  54. /*from youa*///就复杂一点,主要用来做继承,主要参考有啊的$extends(跟prototype的Class.create也类似)。
  55. O.wrapper = function (me, parent) {
  56. var ins = function () { me.apply(this, arguments); };
  57. var subclass = function () { };
  58. subclass.prototype = parent.prototype;
  59. ins.prototype = new subclass;
  60. return ins;
  61. };
  62.  
  63. /*Browser*/
  64.  
  65. /*from youa*/
  66. B = (function (ua) {
  67. var b = {
  68. msie: /msie/.test(ua) && !/opera/.test(ua),
  69. opera: /opera/.test(ua),
  70. safari: /webkit/.test(ua) && !/chrome/.test(ua),
  71. firefox: /firefox/.test(ua),
  72. chrome: /chrome/.test(ua)
  73. };
  74. var vMark = "";
  75. for (var i in b) {
  76. if (b[i]) { vMark = "safari" == i ? "version" : i; break; }
  77. }
  78. b.version = vMark && RegExp("(?:" + vMark + ")[\\/: ]([\\d.]+)").test(ua) ? RegExp.$1 : "0";
  79.  
  80. b.ie = b.msie;
  81. b.ie6 = b.msie && parseInt(b.version, 10) == 6;
  82. b.ie7 = b.msie && parseInt(b.version, 10) == 7;
  83. b.ie8 = b.msie && parseInt(b.version, 10) == 8;
  84.  
  85. return b;
  86. })(window.navigator.userAgent.toLowerCase());
  87.  
  88. /*Array*/
  89.  
  90. A = function () {
  91.  
  92. var ret = {
  93. isArray: function (obj) {
  94. return Object.prototype.toString.call(obj) === "[object Array]";
  95. },
  96. indexOf: function (array, elt, from) {
  97. if (array.indexOf) {
  98. return (from) ? array.indexOf(elt) : array.indexOf(elt, from);
  99. } else {
  100. var len = array.length;
  101. from = isNaN(from) ? 0
  102. : from < 0 ? Math.ceil(from) + len : Math.floor(from);
  103.  
  104. for (; from < len; from++) { if (array[from] === elt) return from; }
  105. return -1;
  106. }
  107. },
  108. lastIndexOf: function (array, elt, from) {
  109. if (array.lastIndexOf) {
  110. return isNaN(from) ? array.lastIndexOf(elt) : array.lastIndexOf(elt, from);
  111. } else {
  112. var len = array.length;
  113. from = isNaN(from) || from >= len - 1 ? len - 1
  114. : from < 0 ? Math.ceil(from) + len : Math.floor(from);
  115.  
  116. for (; from > -1; from--) { if (array[from] === elt) return from; }
  117. return -1;
  118. }
  119. }
  120. };
  121.  
  122. //定义一个基本的迭代函数eac
  123. //object:要迭代的对象,callback:回调函数:用于获取迭代对象的值(属性值属性名称,迭代对象,)
  124. function each(object, callback) {
  125. if (undefined === object.length) {
  126. for (var name in object) {
  127. // alert(name + ":" + object[name]);
  128. if (false === callback(object[name], name, object)) break;
  129. }
  130. } else {
  131. for (var i = 0, len = object.length; i < len; i++) {
  132. if (i in object) { if (false === callback(object[i], i, object)) break; }
  133. }
  134. }
  135. };
  136.  
  137. //调用each方法
  138. each(
  139. //object参数
  140. {
  141. forEach: function (object, callback, thisp) {
  142. each(object, function () { callback.apply(thisp, arguments); });
  143. },
  144. map: function (object, callback, thisp) {
  145. var ret = [];
  146. each(object, function () { ret.push(callback.apply(thisp, arguments)); });
  147. return ret;
  148. },
  149. filter: function (object, callback, thisp) {
  150. var ret = [];
  151. each(object, function (item) {
  152. callback.apply(thisp, arguments) && ret.push(item);
  153. });
  154. return ret;
  155. },
  156. every: function (object, callback, thisp) {
  157. var ret = true;
  158. each(object, function () {
  159. if (!callback.apply(thisp, arguments)) { ret = false; return false; };
  160. });
  161. return ret;
  162. },
  163. some: function (object, callback, thisp) {
  164. var ret = false;
  165. each(object, function () {
  166. if (callback.apply(thisp, arguments)) { ret = true; return false; };
  167. });
  168. return ret;
  169. }
  170. },
  171. //callback参数
  172. function (method, name) {
  173. ret[name] = function (object, callback, thisp) {
  174. if (object[name]) {
  175. return object[name](callback, thisp);
  176. } else {
  177. return method(object, callback, thisp);
  178. }
  179. }
  180. });
  181.  
  182. return ret;
  183. }();
  184.  
  185. /*Function*/
  186.  
  187. F = (function () {
  188. var slice = Array.prototype.slice;
  189. return {
  190. bind: function (fun, thisp) {
  191. //将arguments转换成真正的数组
  192. var args = slice.call(arguments, 2);
  193. return function () {
  194. return fun.apply(thisp, args.concat(slice.call(arguments)));//连起来
  195. }
  196. },
  197. bindAsEventListener: function (fun, thisp) {
  198. var args = slice.call(arguments, 2);
  199. return function (event) {
  200. return fun.apply(thisp, [E.fixEvent(event)].concat(args));
  201. }
  202. }
  203. };
  204. })();
  205.  
  206. /*Dom*/
  207.  
  208. D = {
  209. getScrollTop: function (node) {
  210. var doc = node ? node.ownerDocument : document;
  211. return doc.documentElement.scrollTop || doc.body.scrollTop;
  212. },
  213. getScrollLeft: function (node) {
  214. var doc = node ? node.ownerDocument : document;
  215. return doc.documentElement.scrollLeft || doc.body.scrollLeft;
  216. },
  217. contains: document.defaultView
  218. ? function (a, b) { return !!(a.compareDocumentPosition(b) & 16); }
  219. : function (a, b) { return a != b && a.contains(b); },
  220. rect: function (node) {
  221. var left = 0, top = 0, right = 0, bottom = 0;
  222. //ie8的getBoundingClientRect获取不准确
  223. if (!node.getBoundingClientRect || B.ie8) {
  224. var n = node;
  225. while (n) { left += n.offsetLeft, top += n.offsetTop; n = n.offsetParent; };
  226. right = left + node.offsetWidth; bottom = top + node.offsetHeight;
  227. } else {
  228. var rect = node.getBoundingClientRect();
  229. left = right = D.getScrollLeft(node); top = bottom = D.getScrollTop(node);
  230. left += rect.left; right += rect.right;
  231. top += rect.top; bottom += rect.bottom;
  232. };
  233. return { "left": left, "top": top, "right": right, "bottom": bottom };
  234. },
  235. clientRect: function (node) {
  236. var rect = D.rect(node), sLeft = D.getScrollLeft(node), sTop = D.getScrollTop(node);
  237. rect.left -= sLeft; rect.right -= sLeft;
  238. rect.top -= sTop; rect.bottom -= sTop;
  239. return rect;
  240. },
  241. curStyle: document.defaultView
  242. ? function (elem) { return document.defaultView.getComputedStyle(elem, null); }
  243. : function (elem) { return elem.currentStyle; },
  244. getStyle: document.defaultView
  245. ? function (elem, name) {
  246. var style = document.defaultView.getComputedStyle(elem, null);
  247. return name in style ? style[name] : style.getPropertyValue(name);
  248. }
  249. : function (elem, name) {
  250. var style = elem.style, curStyle = elem.currentStyle;
  251. //透明度 from youa
  252. if (name == "opacity") {
  253. if (/alpha\(opacity=(.*)\)/i.test(curStyle.filter)) {
  254. var opacity = parseFloat(RegExp.$1);
  255. return opacity ? opacity / 100 : 0;
  256. }
  257. return 1;
  258. }
  259. if (name == "float") { name = "styleFloat"; }
  260. var ret = curStyle[name] || curStyle[S.camelize(name)];
  261. //单位转换 from jqury
  262. if (!/^-?\d+(?:px)?$/i.test(ret) && /^\-?\d/.test(ret)) {
  263. var left = style.left, rtStyle = elem.runtimeStyle, rsLeft = rtStyle.left;
  264.  
  265. rtStyle.left = curStyle.left;
  266. style.left = ret || 0;
  267. ret = style.pixelLeft + "px";
  268.  
  269. style.left = left;
  270. rtStyle.left = rsLeft;
  271. }
  272. return ret;
  273. },
  274. setStyle: function (elems, style, value) {
  275. if (!elems.length) { elems = [elems]; }
  276. if (typeof style == "string") { var s = style; style = {}; style[s] = value; }
  277. A.forEach(elems, function (elem) {
  278. for (var name in style) {
  279. var value = style[name];
  280. if (name == "opacity" && B.ie) {
  281. //ie透明度设置 from jquery
  282. elem.style.filter = (elem.currentStyle && elem.currentStyle.filter || "").replace(/alpha\([^)]*\)/, "") + " alpha(opacity=" + (value * 100 | 0) + ")";
  283. } else if (name == "float") {
  284. elem.style[B.ie ? "styleFloat" : "cssFloat"] = value;
  285. } else {
  286. elem.style[S.camelize(name)] = value;
  287. }
  288. };
  289. });
  290. },
  291. getSize: function (elem) {
  292. var width = elem.offsetWidth, height = elem.offsetHeight;
  293. if (!width && !height) {
  294. var repair = !D.contains(document.body, elem), parent;
  295. if (repair) {//如果元素不在body上
  296. parent = elem.parentNode;
  297. document.body.insertBefore(elem, document.body.childNodes[0]);
  298. }
  299. var style = elem.style,
  300. cssShow = { position: "absolute", visibility: "hidden", display: "block", left: "-9999px", top: "-9999px" },
  301. cssBack = { position: style.position, visibility: style.visibility, display: style.display, left: style.left, top: style.top };
  302. D.setStyle(elem, cssShow);
  303. width = elem.offsetWidth; height = elem.offsetHeight;
  304. D.setStyle(elem, cssBack);
  305. if (repair) {
  306. parent ? parent.appendChild(elem) : document.body.removeChild(elem);
  307. }
  308. }
  309. return { "width": width, "height": height };
  310. }
  311. };
  312.  
  313. /*Event*/
  314. E = (function () {
  315. /*from dean edwards*/
  316. var addEvent, removeEvent, guid = 1,
  317. storage = function (element, type, handler) {
  318. if (!handler.$$guid) handler.$$guid = guid++;
  319. if (!element.events) element.events = {};
  320. var handlers = element.events[type];
  321. if (!handlers) {
  322. handlers = element.events[type] = {};
  323. if (element["on" + type]) {
  324. handlers[0] = element["on" + type];
  325. }
  326. }
  327. };
  328. if (window.addEventListener) {
  329. var fix = { "mouseenter": "mouseover", "mouseleave": "mouseout" };
  330. addEvent = function (element, type, handler) {
  331. if (type in fix) {
  332. storage(element, type, handler);
  333. var fixhandler = element.events[type][handler.$$guid] = function (event) {
  334. var related = event.relatedTarget;
  335. if (!related || (element != related && !(element.compareDocumentPosition(related) & 16))) {
  336. handler.call(this, event);
  337. }
  338. };
  339. element.addEventListener(fix[type], fixhandler, false);
  340. } else {
  341. element.addEventListener(type, handler, false);
  342. };
  343. };
  344. removeEvent = function (element, type, handler) {
  345. if (type in fix) {
  346. if (element.events && element.events[type]) {
  347. element.removeEventListener(fix[type], element.events[type][handler.$$guid], false);
  348. delete element.events[type][handler.$$guid];
  349. }
  350. } else {
  351. element.removeEventListener(type, handler, false);
  352. };
  353. };
  354. } else {
  355. addEvent = function (element, type, handler) {
  356. storage(element, type, handler);
  357. element.events[type][handler.$$guid] = handler;
  358. element["on" + type] = handleEvent;
  359. };
  360. removeEvent = function (element, type, handler) {
  361. if (element.events && element.events[type]) {
  362. delete element.events[type][handler.$$guid];
  363. }
  364. };
  365. function handleEvent() {
  366. var returnValue = true, event = fixEvent();
  367. var handlers = this.events[event.type];
  368. for (var i in handlers) {
  369. this.$$handleEvent = handlers[i];
  370. if (this.$$handleEvent(event) === false) {
  371. returnValue = false;
  372. }
  373. }
  374. return returnValue;
  375. };
  376. }
  377.  
  378. function fixEvent(event) {
  379. if (event) return event;
  380. event = window.event;
  381. event.pageX = event.clientX + D.getScrollLeft(event.srcElement);
  382. event.pageY = event.clientY + D.getScrollTop(event.srcElement);
  383. event.target = event.srcElement;
  384. event.stopPropagation = stopPropagation;
  385. event.preventDefault = preventDefault;
  386. var relatedTarget = {
  387. "mouseout": event.toElement, "mouseover": event.fromElement
  388. }[event.type];
  389. if (relatedTarget) { event.relatedTarget = relatedTarget; }
  390.  
  391. return event;
  392. };
  393. function stopPropagation() { this.cancelBubble = true; };
  394. function preventDefault() { this.returnValue = false; };
  395.  
  396. return {
  397. "addEvent": addEvent,
  398. "removeEvent": removeEvent,
  399. "fixEvent": fixEvent
  400. };
  401. })();
  402.  
  403. /*CustomEvent*/
  404.  
  405. CE = (function () {
  406. var guid = 1;
  407. return {
  408. addEvent: function (object, type, handler) {
  409. if (!handler.$$$guid) handler.$$$guid = guid++;
  410. if (!object.cusevents) object.cusevents = {};
  411. if (!object.cusevents[type]) object.cusevents[type] = {};
  412. object.cusevents[type][handler.$$$guid] = handler;
  413. },
  414. removeEvent: function (object, type, handler) {
  415. if (object.cusevents && object.cusevents[type]) {
  416. delete object.cusevents[type][handler.$$$guid];
  417. }
  418. },
  419. fireEvent: function (object, type) {
  420. if (!object.cusevents) return;
  421. var args = Array.prototype.slice.call(arguments, 2),
  422. handlers = object.cusevents[type];
  423. for (var i in handlers) {
  424. handlers[i].apply(object, args);
  425. }
  426. },
  427. clearEvent: function (object) {
  428. if (!object.cusevents) return;
  429. for (var type in object.cusevents) {
  430. var handlers = object.cusevents[type];
  431. for (var i in handlers) {
  432. handlers[i] = null;
  433. }
  434. object.cusevents[type] = null;
  435. }
  436. object.cusevents = null;
  437. }
  438. };
  439. })();
  440.  
  441. /*String*/
  442.  
  443. S = {
  444. camelize: function (s) {
  445. return s.replace(/-([a-z])/ig, function (all, letter) { return letter.toUpperCase(); });
  446. }
  447. };
  448.  
  449. /*System*/
  450.  
  451. // remove css image flicker
  452. if (B.ie6) {
  453. try {
  454. document.execCommand("BackgroundImageCache", false, true);
  455. } catch (e) { }
  456. };
  457.  
  458. /*define*/
  459.  
  460. $$ = O; $$B = B; $$A = A; $$F = F; $$D = D; $$E = E; $$CE = CE; $$S = S;
  461.  
  462. })();

原文来自:

http://www.cnblogs.com/cloudgamer/archive/2009/10/29/Cloudgamer_JavaScript_Library.html

http://www.cnblogs.com/cloudgamer/archive/2009/08/10/FixedMenu.html

非常好的一个JS代码(CJL.0.1.js)的更多相关文章

  1. JS代码高亮编辑器 ace.js

    JS代码高亮编辑器 ace.js 字数254 阅读2 评论0 喜欢0 瞎扯 ace 是 js 实现的代码编辑器 编译打包之后的 ACE 代码 官网,未提供编译好的文件 ACE 拥有的特点 语法高亮超过 ...

  2. 站长常用的200个js代码 站长常用js代码大全 站长常用js代码集合

    站长常用的200个js代码 1.文本框焦点问题 onBlur:当失去输入焦点后产生该事件 onFocus:当输入获得焦点后,产生该文件 Onchange:当文字值改变时,产生该事件 Onselect: ...

  3. 如何查找元素对应事件的js代码,检测定位js事件

    比如一张图片当鼠标放到上面时,图片改变.想找到这个事件对应的js代码,假设另存为html之后,文件夹中有.js文件. 如果你会调试,可以用打开浏览器的调试功能,以chrome为例,按F12打开调试窗口 ...

  4. CJL.0.1.js

    /*! * Cloudgamer JavaScript Library v0.1 * Copyright (c) 2009 cloudgamer * Blog: http://cloudgamer.c ...

  5. js代码中引入其他js文件

    /***引入 js 文件 @example: import('js/aui.picker.js') @example: import(['js/aui.picker.js', 'css/aui.pic ...

  6. 非常好的一个JS代码(FixedMenu.htm)

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  7. selenium 执行js代码

    获取一个input输入框的值: JavascriptExecutor js =(JavascriptExecutor) driver; merchatName=js.executeScript(&qu ...

  8. jquery-2.0.3.js和jquery-2.0.3.min.js的区别

    两个文件的作用是完全一样的. jquery-2.0.3.js里的代码是没有进行处理的原代码,适合于人们阅读与研究. jquery-2.0.3.min.js里的代码进行过特殊的处理, 如变量的名称基本都 ...

  9. 在dcef3当中执行js代码并获得返回值

    1.如何在dcef3当中执行js代码 procedure TForm1.btnWriteZMClick(Sender: TObject);var  js: string;begin  js := 'd ...

随机推荐

  1. hdu 6096 String

    题 OvO http://acm.hdu.edu.cn/showproblem.php?pid=6096 ( 2017 Multi-University Training Contest - Team ...

  2. html2canvas 使用指南

    html2canvas(document.body).then(function(canvas) { document.body.appendChild(canvas); }); 属性参数: http ...

  3. HDU 5335 Walk Out BFS 比较坑

    H - H Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Submit Status ...

  4. noi.ac#458 sequence

    题目链接:戳我 蒟蒻的第一道子序列自动机! 给定两个01串A,B,求一个最短的01串,要求C不是A,B的子序列.要求如果同样短,输出字典序最小的. 那么我们先构建A,B两个串的子序列自动机.然后我们设 ...

  5. Codeforces 1167 F Scalar Queries 计算贡献+树状数组

    题意 给一个数列\(a\),定义\(f(l,r)\)为\(b_1, b_2, \dots, b_{r - l + 1}\),\(b_i = a_{l - 1 + i}\),将\(b\)排序,\(f(l ...

  6. BeetleX之快速构建Web多房间聊天室

    其实构建一个Web多房间聊天室也并不是什么困难的技术,借助于websocket就可以轻松实现多用户在线实时通讯交互:在这里主要介绍一下在BeetleX和BeetleXjs的支持下如何让这个功能实现的更 ...

  7. 如何在main.js中改变vuex中的值?

    做登录权限控制的时候, 我通过全局路由守卫来去做权限判断,这样的话可能需要在整个项目加载的初期去做一些诸如 接口请求. vuex修改 之类的问题 其实非常简单,直接如图:

  8. [CSP-S模拟测试]:任务分配(最短路+贪心+DP)

    题目传送门(内部题149) 输入格式 每个测试点第一行为四个正整数$n,b,s,m$,含义如题目所述. 接下来$m$行,每行三个非负整数$u,v,l$,表示从点$u$到点$v$有一条权值为$l$的有向 ...

  9. 03.从尾到头打印链表 (Java)

    题目描述 输入一个链表,按链表值从尾到头的顺序返回一个ArrayList. 思路 采用递归: 若当前节点不为空,则递归其后继节点,并将当前节点加入list中. 采用数据结构栈实现: 利用栈“后进先出” ...

  10. LeetCode 199. 二叉树的右视图(Binary Tree Right Side View)

    题目描述 给定一棵二叉树,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值. 示例: 输入: [1,2,3,null,5,null,4] 输出: [1, 3, 4] 解释: 1 ...