国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

發(fā)布一個JavaScript工具類庫jutil

開發(fā) 前端
都說好的設計是易于理解的,不用過多介紹,而這也是我現(xiàn)在想達到的目標,因此下面的介紹會比較簡單,如果大家哪個地方看不明白或有更好的建議,請?zhí)岢鰜恚以賰?yōu)化。

由來

工作中jQuery用的比較多,但jQuery再強大也有些方法是沒有的,以前的做法就是東拼西湊,今天終于下定決心把平時用到的一些方法加以整理,這就是jutil的由來。

當前只有17個方法,涉及到的有Array、HTML、Cookie & localStorage、Date、String。這些方法都采用了原生的JS,不依賴于jQuery。

都說好的設計是易于理解的,不用過多介紹,而這也是我現(xiàn)在想達到的目標,因此下面的介紹會比較簡單,如果大家哪個地方看不明白或有更好的建議,請?zhí)岢鰜恚以賰?yōu)化。

Array相關  

jutil.arrayDistinct(Array)

jutil.arrayIndexOf(Array,Item)

實現(xiàn)代碼如下:

  1.  arrayDistinct: function (arr) {  
  2.     var tempArr = {};  
  3.     for (var i = 0; i < arr.length; i++) {  
  4.         if (tempArr[arr[i] + 1]) {  
  5.             arr.splice(i, 1);  
  6.             i--;  
  7.             continue;  
  8.         }  
  9.         tempArr[arr[i] + 1] = true;  
  10.     }  
  11.     tempArr = null;  
  12.     return arr;  
  13. },  
  14. arrayIndexOf: function (arr, obj, iStart) {  
  15.     if (Array.prototype.indexOf) {  
  16.         return arr.indexOf(obj, (iStart || 0));  
  17.     }  
  18.     else {  
  19.         for (var i = (iStart || 0), j = arr.length; i < j; i++) {  
  20.             if (arr[i] === obj) {  
  21.                 return i;  
  22.             }  
  23.         }  
  24.         return -1;  
  25.     }  
  26. }, 

#p#

HTML相關  

jutil.htmlEncode(sHtml)

jutil.htmlDecode(sHtml)

實現(xiàn)代碼如下:

  1. htmlEncode: function (sHtml) {  
  2.     var div = this.document.createElement("div"),  
  3.         text = this.document.createTextNode(sHtml);  
  4.     div.appendChild(text);  
  5.     return div.innerHTML;  
  6. },  
  7. htmlDecode: function (sHtml) {  
  8.     var div = this.document.createElement("div");  
  9.     div.innerHTML = sHtml;  
  10.     return div.innerText || div.textContent;  
  11. }, 

如果有用jQuery,上面代碼可以進一步簡化為:

  1. htmlEncode: function (sHtml) {  
  2.     return $("div").text(sHtml).html();  
  3. },  
  4. htmlDecode: function (sHtml) {  
  5.     return $("div").html(sHtml).text();  
  6. }, 

#p#

Cookie & localStorage相關

jutil.getCookie(sKey)

jutil.setCookie(sKey, sValue, iExpireSeconds)

jutil.deleteCookie(sKey)

jutil.getStorage(sKey)//如果瀏覽器支持HTML5本地存儲(localStorage)優(yōu)先用本地存儲,否則用cookie,下同

jutil.setStorage(sKey, sValue, iExpireSeconds)

jutil.deleteStorage(sKey)

實現(xiàn)代碼如下:

  1. getCookie: function (sKey) {  
  2.     if (!sKey)  
  3.         return "";  
  4.     if (document.cookie.length > 0) {  
  5.         var startIndex = document.cookie.indexOf(sKey + "=")  
  6.         if (startIndex != -1) {  
  7.             startIndex = startIndex + sKey.length + 1  
  8.             var endIndex = document.cookie.indexOf(";", startIndex)  
  9.             if (endIndex == -1) {  
  10.                 endIndex = document.cookie.length;  
  11.             }  
  12.             return decodeURIComponent(document.cookie.substring(startIndex, endIndex));  
  13.         }  
  14.     }  
  15.     return "" 
  16. },  
  17. setCookie: function (sKey, sValue, iExpireSeconds) {  
  18.     if (!sKey)  
  19.         return;  
  20.     var expireDate = new Date();  
  21.     expireDate.setTime(expireDate.getTime() + iExpireSeconds * 1000);  
  22.     this.document.cookie = sKey + "=" + encodeURIComponent(sValue) +   
  23.     ";expires=" + expireDate.toGMTString() + ";";  
  24. },  
  25. deleteCookie: function (sKey) {  
  26.     if (!sKey)  
  27.         return;  
  28.     this.document.cookie = sKey + '=; expires=Thu, 01 Jan 1970 00:00:01 GMT;';  
  29. },  
  30. getStorage: function (sKey) {  
  31.     if (!sKey)  
  32.         return;  
  33.     if (window.localStorage) {  
  34.         return decodeURIComponent(localStorage.getItem(sKey));  
  35.     }  
  36.     else {  
  37.         return this.getCookie(sKey);  
  38.     }  
  39. },  
  40. setStorage: function (sKey, sValue, iExpireSeconds) {  
  41.     if (!sKey)  
  42.         return;  
  43.     if (window.localStorage) {  
  44.         localStorage.setItem(sKey, encodeURIComponent(sValue));  
  45.     }  
  46.     else {  
  47.         this.setCookie(sKey, sValue, iExpireSeconds);  
  48.     }  
  49. },  
  50. deleteStorage: function (sKey) {  
  51.     if (!sKey)  
  52.         return;  
  53.     if (window.localStorage) {  
  54.         localStorage.removeItem(sKey);  
  55.     }  
  56.     else {  
  57.         this.deleteCookie(sKey);  
  58.     }  
  59. }, 

#p#

Date相關  

jutil.daysInFebruary(obj)//obj:數字(如2012)或時間(如new Date())

jutil.daysInYear(obj)//obj:數字(如2012)或時間(如new Date())

jutil.dateFormat(date, sFormat, sLanguage)//sFormat:yyyy為年,MM為月,DD為日,hh為時,mm為分,ss為秒,MMM為月份,EEE為星期。sLanguage:默認為中文,可以設置成英文(en)

jutil.dateDiff(biggerDate, smallerDate)

jutil.dateInterval(biggerDate, smallerDate)

從名子大家可能看不出最后兩個方法的區(qū)別,這里命名可能是有些問題,大家有沒有推薦的?

dateDiff表示兩個時間之間相隔多長時間,返回的是"10分鐘"、"2天"等字符串,一般用在要顯示"XX分鐘前"、"XX天前"時。

dateInterval表示兩個時間精確差(精確到秒),返回的是"1天:1小時:1分鐘:1秒"這樣的字符串。

實現(xiàn)代碼如下:

  1. daysInFebruary: function (obj) {  
  2.     var year = 0;  
  3.     if (obj instanceof Date) {  
  4.         year = obj.getFullYear();  
  5.     }  
  6.     else if (typeof obj === "number") {  
  7.         year = obj;  
  8.     }  
  9.     else {  
  10.         return 0;  
  11.     }  
  12.     if (year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0)) {  
  13.         return 29;  
  14.     }  
  15.     return 28;  
  16. },  
  17. daysInYear: function (obj) {  
  18.     var year = 0;  
  19.     if (obj instanceof Date) {  
  20.         year = obj.getFullYear();  
  21.     }  
  22.     else if (typeof obj === "number") {  
  23.         year = obj;  
  24.     }  
  25.     else {  
  26.         return 0;  
  27.     }  
  28.     if (year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0)) {  
  29.         return 366;  
  30.     }  
  31.     return 365;  
  32. },  
  33. dateFormat: function (date, sFormat, sLanguage) {  
  34.     var time = {};  
  35.     time.Year = date.getFullYear();  
  36.     time.TYear = ("" + time.Year).substr(2);  
  37.     time.Month = date.getMonth() + 1;  
  38.     time.TMonth = time.Month < 10 ? "0" + time.Month : time.Month;  
  39.     time.Day = date.getDate();  
  40.     time.TDay = time.Day < 10 ? "0" + time.Day : time.Day;  
  41.     time.Hour = date.getHours();  
  42.     time.THour = time.Hour < 10 ? "0" + time.Hour : time.Hour;  
  43.     time.hour = time.Hour < 13 ? time.Hour : time.Hour - 12;  
  44.     time.Thour = time.hour < 10 ? "0" + time.hour : time.hour;  
  45.     time.Minute = date.getMinutes();  
  46.     time.TMinute = time.Minute < 10 ? "0" + time.Minute : time.Minute;  
  47.     time.Second = date.getSeconds();  
  48.     time.TSecond = time.Second < 10 ? "0" + time.Second : time.Second;  
  49.     time.Millisecond = date.getMilliseconds();  
  50.     time.Week = date.getDay();  
  51.  
  52.     var MMMArrEn = ["Jan""Feb""Mar""Apr""May""Jun""Jul""Aug""Sep""Oct""Nov""Dec"],  
  53.         MMMArr = ["一月""二月""三月""四月""五月""六月""七月""八月""九月""十月""十一月""十二月"],  
  54.         WeekArrEn = ["Sun""Mon""Tue""Web""Thu""Fri""Sat"],  
  55.         WeekArr = ["星期日""星期一""星期二""星期三""星期四""星期五""星期六"],  
  56.         oNumber = time.Millisecond / 1000;  
  57.  
  58.     if (sFormat != undefined && sFormat.replace(/\s/g, "").length > 0) {  
  59.         if (sLanguage != undefined && sLanguage === "en") {  
  60.             MMMArr = MMMArrEn.slice(0);  
  61.             WeekArr = WeekArrEn.slice(0);  
  62.         }  
  63.         sFormat = sFormat.replace(/yyyy/ig, time.Year)  
  64.         .replace(/yyy/ig, time.Year)  
  65.         .replace(/yy/ig, time.TYear)  
  66.         .replace(/y/ig, time.TYear)  
  67.         .replace(/MMM/g, MMMArr[time.Month - 1])  
  68.         .replace(/MM/g, time.TMonth)  
  69.         .replace(/M/g, time.Month)  
  70.         .replace(/dd/ig, time.TDay)  
  71.         .replace(/d/ig, time.Day)  
  72.         .replace(/HH/g, time.THour)  
  73.         .replace(/H/g, time.Hour)  
  74.         .replace(/hh/g, time.Thour)  
  75.         .replace(/h/g, time.hour)  
  76.         .replace(/mm/g, time.TMinute)  
  77.         .replace(/m/g, time.Minute)  
  78.         .replace(/ss/ig, time.TSecond)  
  79.         .replace(/s/ig, time.Second)  
  80.         .replace(/fff/ig, time.Millisecond)  
  81.         .replace(/ff/ig, oNumber.toFixed(2) * 100)  
  82.         .replace(/f/ig, oNumber.toFixed(1) * 10)  
  83.         .replace(/EEE/g, WeekArr[time.Week]);  
  84.     }  
  85.     else {  
  86.         sFormat = time.Year + "-" + time.Month + "-" + time.Day + " " + time.Hour + ":" + time.Minute + ":" + time.Second;  
  87.     }  
  88.     return sFormat;  
  89. },  
  90. dateDiff: function (biggerDate, smallerDate) {  
  91.     var intervalSeconds = parseInt((biggerDate - smallerDate) / 1000);  
  92.     if (intervalSeconds < 60) {  
  93.         return intervalSeconds + "秒";  
  94.     }  
  95.     else if (intervalSeconds < 60 * 60) {  
  96.         return Math.floor(intervalSeconds / 60) + "分鐘";  
  97.     }  
  98.     else if (intervalSeconds < 60 * 60 * 24) {  
  99.         return Math.floor(intervalSeconds / (60 * 60)) + "小時";  
  100.     }  
  101.     else if (intervalSeconds < 60 * 60 * 24 * 7) {  
  102.         return Math.floor(intervalSeconds / (60 * 60 * 24)) + "天";  
  103.     }  
  104.     else if (intervalSeconds < 60 * 60 * 24 * 31) {  
  105.         return Math.floor(intervalSeconds / (60 * 60 * 24 * 7)) + "周";  
  106.     }  
  107.     else if (intervalSeconds < 60 * 60 * 24 * 365) {  
  108.         return Math.floor(intervalSeconds / (60 * 60 * 24 * 30)) + "月";  
  109.     }  
  110.     else if (intervalSeconds < 60 * 60 * 24 * 365 * 1000) {  
  111.         return Math.floor(intervalSeconds / (60 * 60 * 24 * 365)) + "年";  
  112.     }  
  113.     else {  
  114.         return Math.floor(intervalSeconds / (60 * 60 * 24)) + "天";  
  115.     }  
  116. },  
  117. dateInterval: function (biggerDate, smallerDate) {  
  118.     var intervalSeconds = parseInt((biggerDate - smallerDate) / 1000),  
  119.         day = Math.floor(intervalSeconds / (60 * 60 * 24)),  
  120.         hour = Math.floor((intervalSeconds - day * 24 * 60 * 60) / 3600),  
  121.         minute = Math.floor((intervalSeconds - day * 24 * 60 * 60 - hour * 3600) / 60),  
  122.         second = Math.floor(intervalSeconds - day * 24 * 60 * 60 - hour * 3600 - minute * 60);  
  123.     return day + "天:" + hour + "小時:" + minute + "分鐘:" + second + "秒";  
  124. }, 

#p#

String相關

jutil.replaceURLWithHTMLLinks(sText, bBlank)

jutil.getLength(sVal, bChineseDouble)

這個就比較簡單了,直接上代碼:

  1. replaceURLWithHTMLLinks: function (sText, bBlank) {  
  2.     var pattern = /(\b(https?|ftp|file):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/ig;  
  3.     if (bBlank) {  
  4.         sText = sText.replace(pattern, "<a target='_blank' href='$1'>$1</a>");  
  5.     }  
  6.     else {  
  7.         sText = sText.replace(pattern, "<a href='$1'>$1</a>");  
  8.     }  
  9.     return sText;  
  10. },  
  11. getLength: function (sVal, bChineseDouble) {  
  12.     var chineseRegex = /[\u4e00-\u9fa5]/g;  
  13.     if (bChineseDouble != undefined && bChineseDouble === false) {  
  14.         return sVal.length;  
  15.     }  
  16.     else {  
  17.         if (chineseRegex.test(sVal)) {  
  18.             return sVal.replace(chineseRegex, "zz").length;  
  19.         }  
  20.         return sVal.length;  
  21.     }  

測試代碼

測試效果:

小結

后面會繼續(xù)添加正則方面的內容,本文也會持續(xù)更新。目前JS下載鏈接:http://files.cnblogs.com/artwl/jutil.js

原文鏈接:http://www.cnblogs.com/artwl/archive/2012/07/09/2583114.html

責任編輯:張偉 來源: Artwl的博客
相關推薦

2017-07-18 18:06:00

JavaScript框架類庫

2013-04-08 10:54:51

Javascript

2022-12-09 15:02:44

2014-02-14 09:37:01

JavascriptDOM

2020-12-08 06:23:05

LockSupport線程工具

2017-12-14 16:55:33

2021-05-19 22:23:56

PythonJavaScript數據

2012-12-12 09:47:56

JavaScript

2022-12-05 14:39:33

Javascript工具

2023-12-07 09:44:29

2017-05-02 11:30:44

JavaScript數組惰性求值庫

2012-02-16 10:12:23

JavaScript

2011-03-24 09:34:41

SPRING

2025-08-18 01:45:00

2022-05-23 08:05:14

benchstat工具Go

2014-12-17 09:40:22

dockerLinuxPaaS

2011-11-03 09:13:27

JavaScript

2020-09-02 07:22:17

JavaScript插件框架

2012-04-10 13:37:28

JavaScript

2023-04-10 09:11:27

HutoolJava工具
點贊
收藏

51CTO技術棧公眾號

成人午夜免费电影| 日韩欧美视频专区| 亚洲777理论| 欧美日韩一区二区三区电影| 视频国产精品| 欧美在线999| 99色在线播放| 国产在线一区二区综合免费视频| 国产99视频精品免视看7| 亚洲四虎影院| 精品久久久久久综合日本欧美| 欧美承认网站| 91网站最新网址| 视频一区三区| 欧美 日韩 国产精品免费观看| 欧美激情一区二区三区高清视频| 成年人视频免费在线播放| 日韩欧美国产网站| 日本欧洲国产一区二区| 亚洲综合男人的天堂| 国产亚av手机在线观看| 99在线热播精品免费| 日韩av大片站长工具| 综合视频免费看| 日韩精品高清在线观看| 日韩一区二区免费看| 亚洲一区二区在线免费观看| 伊人久久婷婷| 久久天堂电影网| 高潮毛片在线观看| 欧美日韩成人激情| 裸体丰满少妇做受久久99精品| 欧美一级鲁丝片| 波多野结衣久草一区| 久久久久久久电影| 中文字幕免费在线观看| 亚洲欧洲成视频免费观看| 亚洲免费一级视频| 欧美日本在线视频| 99在线精品视频在线观看| 黄色一级片在线观看| 久久精品日韩精品| 91福利国产精品| 99国产精品| 免费高清视频在线一区| 日产精品高清视频免费| 欧美一级视频| 久在线观看视频| 成人三级伦理片| 欧洲成人午夜免费大片| 久久精品国产99国产| 岛国大片在线观看| 国产精品国产三级国产aⅴ浪潮| 国产精品白丝jk黑袜喷水| av香蕉成人| 国产精选一区二区| 日韩中文欧美在线| 九热视频在线观看| 欧美亚洲免费在线一区| 在线黄色的网站| 欧美精品一区二区蜜臀亚洲| 风间由美中文字幕在线看视频国产欧美| 国产精品色午夜在线观看| 欧美日韩在线播| 日韩色性视频| 日韩av一区二区三区在线| 亚洲自拍另类综合| 澳门久久精品| 久久精品国产精品青草色艺| 成人欧美一区二区三区视频网页| 日韩av综合| 毛片在线视频观看| 亚洲欧美999| 国产精品午夜春色av| 欧美福利网址| 日韩美女一区| 国产精品流白浆视频| 中文字幕一区二区视频| 国产主播性色av福利精品一区| 国产一区二区在线视频| 久色视频在线播放| 亚洲女人天堂av| 日韩福利视频导航| 韩日成人影院| 天堂在线视频中文网| 日韩av网址在线观看| 日韩专区一卡二卡| 国产成人久久精品麻豆二区| 二区三区在线| 青娱乐一区二区| 欧美日韩免费高清一区色橹橹| 成人国产精品免费| 在线视频您懂的| 777免费视频| 久久久亚洲高清| 成人日韩av在线| 午夜宅男久久久| 乱妇乱女熟妇熟女网站| 亚洲国产欧美一区二区三区丁香婷| 天堂中文8资源在线8| 久久五月情影视| 午夜欧美视频| 人妻有码中文字幕| 欧美日韩一区二区三区高清| 日本成人一区二区| 国产超碰91| 久久久精品国产99久久精品芒果 | 91久久久久久久久| 国内成+人亚洲+欧美+综合在线| 97高清视频| 亚洲第一区在线观看| 欧美猛男男男激情videos| 神马影院午夜我不卡影院| 亚洲在线一区二区三区| 综合久久2023| 肥熟一91porny丨九色丨| 中文字幕久久午夜不卡| av中文字幕在线观看第一页| 国产精品免费视频久久久| 国产成人午夜精品影院观看视频 | 亚洲精品进入| www国产无套内射com| 色哟哟亚洲精品| 麻豆精品少妇| 很污的网站在线观看| 日韩午夜电影av| 最新精品国产| 特黄特黄的视频| 久久视频在线免费观看| 日本在线播放一区二区三区| 欧美美乳在线| 国产精品视频资源| 国产精品免费免费| 久久91视频| 先锋影音男人资源| 欧美刺激午夜性久久久久久久| 亚洲国产一成人久久精品| 天堂在线亚洲| 久久99精品视频一区97 | 欧美精品18videos性欧美| 国产一区在线精品| 成人欧美在线| 成人欧美视频在线| 五月激情丁香一区二区三区| 在线精品国产亚洲| 免费无码不卡视频在线观看| 亚洲精品久久久久国产| 日韩午夜在线| 不卡在线视频| 亚洲一区二区免费| 亚洲国产精品尤物yw在线观看| 欧美大胆视频| a√免费观看在线网址www| 98精品在线视频| 国产精品久久久久四虎| 成人自拍在线| caoporen人人| 国产成人综合精品| 亚洲一区二区三区四区的| 亚洲裸色大胆大尺寸艺术写真| 久久99爱视频| 国产成人拍精品视频午夜网站 | 天堂√中文最新版在线| 日韩中文一区| 欧美成人vr18sexvr| 美女在线视频一区| 日韩大片免费观看| 女人帮男人橹视频播放| 亚洲老司机av| 成人免费视频免费观看| 亚洲午夜国产成人| 国产精品一区二区羞羞答答| 国外色69视频在线观看| 日韩理论在线观看| 日本高清免费电影一区| 飘雪影院手机免费高清版在线观看| 亚洲一区二区三区sesese| 91激情五月电影| 老妇喷水一区二区三区| 日韩大尺度黄色| 成年人小视频网站| 国产mv久久久| 欧美日韩一区成人| 麻豆精品一区二区三区| 日韩美香港a一级毛片| 国产中文字幕第一页| 91观看网站| 亚洲免费一级电影| 亚洲色图.com| 国产精品一区亚洲| 羞羞视频在线观看一区二区| 老鸭窝av在线| 日韩电影免费观看在| www.亚洲免费视频| 性感美女久久精品| 精品亚洲porn| 一本色道久久综合狠狠躁的番外| aⅴ在线视频男人的天堂 | 91麻豆精品国产91久久久使用方法| 麻豆精品一区二区|