不知不觉就收集了100个实用的JavaScript代码片段。。。。
91、原生JavaScript实现窗体改变事件resize的操作(兼容所以的浏览器)
03 | var w = document.documentElement ? document.documentElement.clientWidth : document.body.clientWidth |
05 | ,b = Element.extend(document.body) |
06 | ,classname = b.className; |
13 | if (window.addEventListener){ |
14 | window.addEventListener( 'resize' , function (){ fn(); }); |
15 | } else if (window.attachEvent){ |
16 | window.attachEvent( 'onresize' , function (){ fn(); }); |
92、原生JavaScript用正则清除空格分左右
1 | function ltrim(s){ return s.replace( /^(\s*| *)/, "" ); } |
2 | function rtrim(s){ return s.replace( /(\s*| *)$/, "" ); } |
3 | function trim(s){ return ltrim(rtrim(s));} |
93、原生JavaScript判断变量是否空值
07 | case 'undefined' : return true ; |
08 | case 'string' : if (trim(v).length == 0) return true ; break ; |
09 | case 'boolean' : if (!v) return true ; break ; |
10 | case 'number' : if (0 === v) return true ; break ; |
12 | if ( null === v) return true ; |
13 | if (undefined !== v.length && v.length==0) return true ; |
14 | for ( var k in v){ return false ;} return true ; |
94、原生JavaScript实现base64解码
01 | function base64_decode(data){ |
02 | var b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=" ; |
03 | var o1, o2, o3, h1, h2, h3, h4, bits, i = 0,ac = 0,dec = "" ,tmp_arr = []; |
04 | if (!data) { return data; } |
07 | h1 = b64.indexOf(data.charAt(i++)); |
08 | h2 = b64.indexOf(data.charAt(i++)); |
09 | h3 = b64.indexOf(data.charAt(i++)); |
10 | h4 = b64.indexOf(data.charAt(i++)); |
11 | bits = h1 << 18 | h2 << 12 | h3 << 6 | h4; |
12 | o1 = bits >> 16 & 0xff; |
13 | o2 = bits >> 8 & 0xff; |
16 | tmp_arr[ac++] = String.fromCharCode(o1); |
17 | } else if (h4 == 64) { |
18 | tmp_arr[ac++] = String.fromCharCode(o1, o2); |
20 | tmp_arr[ac++] = String.fromCharCode(o1, o2, o3); |
22 | } while (i < data.length); |
23 | dec = tmp_arr.join( '' ); |
24 | dec = utf8_decode(dec); |
95、原生JavaScript实现utf8解码
01 | function utf8_decode(str_data){ |
02 | var tmp_arr = [],i = 0,ac = 0,c1 = 0,c2 = 0,c3 = 0;str_data += '' ; |
03 | while (i < str_data.length) { |
04 | c1 = str_data.charCodeAt(i); |
06 | tmp_arr[ac++] = String.fromCharCode(c1); |
08 | } else if (c1 > 191 && c1 < 224) { |
09 | c2 = str_data.charCodeAt(i + 1); |
10 | tmp_arr[ac++] = String.fromCharCode(((c1 & 31) << 6) | (c2 & 63)); |
13 | c2 = str_data.charCodeAt(i + 1); |
14 | c3 = str_data.charCodeAt(i + 2); |
15 | tmp_arr[ac++] = String.fromCharCode(((c1 & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63)); |
19 | return tmp_arr.join( '' ); |
96、原生JavaScript获取窗体可见范围的宽与高
1 | function getViewSize(){ |
2 | var de=document.documentElement; |
4 | var viewW=de.clientWidth==0 ? db.clientWidth : de.clientWidth; |
5 | var viewH=de.clientHeight==0 ? db.clientHeight : de.clientHeight; |
6 | return Array(viewW ,viewH); |
97、原生JavaScript判断IE版本号(既简洁、又向后兼容!)
2 | var v = 3, div = document.createElement( 'div' ), all = div.getElementsByTagName( 'i' ); |
4 | div.innerHTML = '<!--[if gt IE ' + (++v) + ']><i></i><![endif]-->' , |
7 | return v > 4 ? v : false ; |
98、原生JavaScript获取浏览器版本号
01 | function browserVersion(types) { |
04 | var v = types[i] ? types[i] : i; |
05 | if (USERAGENT.indexOf(v) != -1) { |
06 | var re = new RegExp(v + '(\\/|\\s|:)([\\d\\.]+)' , 'ig' ); |
07 | var matches = re.exec(USERAGENT); |
08 | var ver = matches != null ? matches[2] : 0; |
09 | other = ver !== 0 && v != 'mozilla' ? 0 : other; |
13 | eval( 'BROWSER.' + i + '= ver' ); |
15 | BROWSER.other = other; |
99、原生JavaScript半角转换为全角函数
03 | for ( var i=0; i < str.length; i++){ |
04 | code = str.charCodeAt(i); |
05 | if (code >= 33 && code <= 126){ |
06 | result += String.fromCharCode(str.charCodeAt(i) + 65248); |
07 | } else if (code == 32){ |
08 | result += String.fromCharCode(str.charCodeAt(i) + 12288 - 32); |
10 | result += str.charAt(i); |
100、原生JavaScript全角转换为半角函数
03 | for ( var i=0; i < str.length; i++){ |
04 | code = str.charCodeAt(i); |
05 | if (code >= 65281 && code <= 65374){ |
06 | result += String.fromCharCode(str.charCodeAt(i) - 65248); |
07 | } else if (code == 12288){ |
08 | result += String.fromCharCode(str.charCodeAt(i) - 12288 + 32); |
10 | result += str.charAt(i); |