js常用方法總結(jié)

1.手機(jī)類(lèi)型判斷

var BrowserInfo = {
userAgent: navigator.userAgent.toLowerCase()
isAndroid: Boolean(navigator.userAgent.match(/android/ig)),
isIphone: Boolean(navigator.userAgent.match(/iphone|ipod/ig)),
isIpad: Boolean(navigator.userAgent.match(/ipad/ig)),
isWeixin: Boolean(navigator.userAgent.match(/MicroMessenger/ig)),
}

2.返回字符串長(zhǎng)度,漢子計(jì)數(shù)為2

function strLength(str) {
var a = 0;
for (var i = 0; i < str.length; i++) {
  if (str.charCodeAt(i) > 255)
      a += 2;//按照預(yù)期計(jì)數(shù)增加2
  else
      a++;
}
return a;
}

3.獲取url中的參數(shù)

function GetQueryStringRegExp(name,url) {
var reg = new RegExp("(^|\?|&)" + name + "=([^&]*)(\s|&|$)", "i");
if (reg.test(url)) return decodeURIComponent(RegExp.$2.replace(/+/g, " ")); return "";
} 

4.js綁定事件適用于任何瀏覽器的元素綁定

function eventBind(obj, eventType, callBack) {
  if (obj.addEventListener) {
      obj.addEventListener(eventType, callBack, false);
  }
  else if (window.attachEvent) {
      obj.attachEvent('on' + eventType, callBack);
  }
  else {
      obj['on' + eventType] = callBack;
  }
};
eventBind(document, 'click', bodyClick);

5.獲得當(dāng)前瀏覽器JS的版本

function getjsversion(){
var n = navigator;
var u = n.userAgent;
var apn = n.appName;
var v = n.appVersion;
var ie = v.indexOf('MSIE ');
if (ie > 0){
  apv = parseInt(i = v.substring(ie + 5));
  if (apv > 3) {
      apv = parseFloat(i);
  }
} else {
  apv = parseFloat(v);
}
var isie = (apn == 'Microsoft Internet Explorer');
var ismac = (u.indexOf('Mac') >= 0);
var javascriptVersion = "1.0";
if (String && String.prototype) {
  javascriptVersion = '1.1';
  if (javascriptVersion.match) {
      javascriptVersion = '1.2';
      var tm = new Date;
      if (tm.setUTCDate) {
          javascriptVersion = '1.3';
          if (isie && ismac && apv >= 5) javascriptVersion = '1.4';
          var pn = 0;
          if (pn.toPrecision) {
              javascriptVersion = '1.5';
              a = new Array;
              if (a.forEach) {
                  javascriptVersion = '1.6';
                  i = 0;
                  o = new Object;
                  tcf = new Function('o', 'var e,i=0;try{i=new Iterator(o)}catch(e){}return i');
                  i = tcf(o);
                  if (i && i.next) {
                      javascriptVersion = '1.7';
                  }
              }
          }
      }
  }
}
return javascriptVersion;
}  

6.獲取當(dāng)前點(diǎn)擊事件的Object對(duì)象

function getEvent() {
if (document.all) {
   return window.event; //如果是ie
}
func = getEvent.caller;
while (func != null) {
   var arg0 = func.arguments[0];
   if (arg0) {
       if ((arg0.constructor == Event || arg0.constructor == MouseEvent)
|| (typeof (arg0) == "object" && arg0.preventDefault && arg0.stopPropagation)) {
           return arg0;
       }
   }
   func = func.caller;
}
return null;
}; 

7.字符串截取方法

getCharactersLen: function (charStr, cutCount) {
   if (charStr == null || charStr == '') return '';
   var totalCount = 0;
   var newStr = '';
   for (var i = 0; i < charStr.length; i++) {
       var c = charStr.charCodeAt(i);
       if (c < 255 && c > 0) {
           totalCount++;
       } else {
           totalCount += 2;
       }
       if (totalCount >= cutCount) {
           newStr += charStr.charAt(i);
           break;
       }
       else {
           newStr += charStr.charAt(i);
       }
   }
   return newStr;
}  

8.JS彈出新窗口全屏

var tmp = window.open("about:blank", "", "fullscreen=1")
                       tmp.moveTo(0, 0);
                       tmp.resizeTo(screen.width + 20, screen.height);
                       tmp.focus();
                       tmp.location. + msgResult.message[0] + '.html';

var config_ = "left=0,top=0,width=" + (window.screen.Width) + ",height=" + (window.screen.Height);
                       window.open('http://www.che168.com/pinggu/eva_' + msgResult.message[0] + '.html', "winHanle", config_);
//模擬form提交打開(kāi)新頁(yè)面
var f = document.createElement("form");
                       f.setAttribute('action', 'http://www.che168.com/pinggu/eva_' + msgResult.message[0] + '.html');
                       f.target = '_blank';
                       document.body.appendChild(f);
                       f.submit(); 

  1. 全選/全不選
function selectAll(objSelect) {
       if (objSelect.checked == true) {
           $("input[name='chkId']").attr("checked", true);
           $("input[name='chkAll']").attr("checked", true);
       }
       else if (objSelect.checked == false) {
           $("input[name='chkId']").attr("checked", false);
           $("input[name='chkAll']").attr("checked", false);
       }
   }
  1. js判斷瀏覽器
判斷是否是 IE 瀏覽器
if (document.all){
   alert(”IE瀏覽器”);
}else{
   alert(”非IE瀏覽器”);
}
if (!!window.ActiveXObject){
   alert(”IE瀏覽器”);
}else{
   alert(”非IE瀏覽器”);
}
判斷是IE幾
var isIE=!!window.ActiveXObject;
var isIE6=isIE&&!window.XMLHttpRequest;
var isIE8=isIE&&!!document.documentMode;
var isIE7=isIE&&!isIE6&&!isIE8;
if (isIE){
if (isIE6){
   alert(”ie6″);
}else if (isIE8){
   alert(”ie8″);
}else if (isIE7){
   alert(”ie7″);
}
}  

11.判斷瀏覽器

function getOs() {
if (navigator.userAgent.indexOf("MSIE 8.0") > 0) {
   return "MSIE8";
}
else if (navigator.userAgent.indexOf("MSIE 6.0") > 0) {
   return "MSIE6";
}
else if (navigator.userAgent.indexOf("MSIE 7.0") > 0) {
   return "MSIE7";
}
else if (isFirefox = navigator.userAgent.indexOf("Firefox") > 0) {
   return "Firefox";
}
if (navigator.userAgent.indexOf("Chrome") > 0) {
   return "Chrome";
}
else {
   return "Other";
}
}

12.JS判斷兩個(gè)日期大小 適合 2012-09-09 與2012-9-9 兩種格式的對(duì)比

//得到日期值并轉(zhuǎn)化成日期格式,replace(/-/g, "/")是根據(jù)驗(yàn)證表達(dá)式把日期轉(zhuǎn)化成長(zhǎng)日期格式系任,這樣再進(jìn)行判斷就好判斷了
   function ValidateDate() {
       var beginDate = $("#t_datestart").val();
       var endDate = $("#t_dateend").val();
       if (beginDate.length > 0 && endDate.length>0) {
           var sDate = new Date(beginDate.replace(/-/g, "/"));
           var eDate= new Date(endDate.replace(/-/g, "/"));
           if (sDate > eDate) {
               alert('開(kāi)始日期要小于結(jié)束日期');
               return false;
           }
       }
   } 

13.移除事件

this.moveBind = function (objId, eventType, callBack) {
var obj = document.getElementById(objId);
if (obj.removeEventListener) {
   obj.removeEventListener(eventType, callBack, false);
}
else if (window.detachEvent) {
   obj.detachEvent('on' + eventType, callBack);
}
else {
   obj['on' + eventType] = null;
}
} 

14.回車(chē)提交

$("id").onkeypress = function (event) {
event = (event) ? event : ((window.event) ? window.event : "")
keyCode = event.keyCode ? event.keyCode : (event.which ? event.which : event.charCode);
if (keyCode == 13) {
   $("SubmitLogin").onclick();
}
}

15.JS 執(zhí)行計(jì)時(shí)器

timeStart = new Date().getTime();
timesEnd = new Date().getTime();
document.getElementById("time").innerHTML = timesEnd - timeStart;

16.JS 寫(xiě)Cookie

function setCookie(name, value, expires, path, domain) {
if (!expires) expires = -1;
if (!path) path = "/";
var d = "" + name + "=" + value;
var e;
if (expires < 0) {
   e = "";
}
else if (expires == 0) {
   var f = new Date(1970, 1, 1);
   e = ";expires=" + f.toUTCString();
}
else {
   var now = new Date();
   var f = new Date(now.getTime() + expires * 1000);
   e = ";expires=" + f.toUTCString();
}
var dm;
if (!domain) {
   dm = "";
}
else {
   dm = ";domain=" + domain;
}
document.cookie = name + "=" + value + ";path=" + path + e + dm;
};  
  1. JS讀Cookie
function readCookie(name) {
var nameEQ = name + "=";
var ca = document.cookie.split(';');
for (var i = 0; i < ca.length; i++) {
   var c = ca[i];
   while (c.charAt(0) == ' ') c = c.substring(1, c.length);
   if (c.indexOf(nameEQ) == 0) {
       return decodeURIComponent(c.substring(nameEQ.length, c.length))
   }
} return null
}
  1. Ajax請(qǐng)求
C.ajax = function (args) {
var self = this;
this.options = {
   type: 'GET',
   async: true,
   contentType: 'application/x-www-form-urlencoded',
   url: 'about:blank',
   data: null,
   success: {},
   error: {}
};
this.getXmlHttp = function () {
   var xmlHttp;
   try {
       xmlhttp = new XMLHttpRequest();
   }
   catch (e) {
       try {
           xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");
       }
       catch (e) {
           xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
       }
   }
   if (!xmlhttp) {
       alert('您的瀏覽器不支持AJAX');
       return false;
   }
   return xmlhttp;
};
this.send = function () {
   C.each(self.options, function (key, val) {
       self.options[key] = (args[key] == null) ? val : args[key];
   });

   var xmlHttp = new self.getXmlHttp();
   if (self.options.type.toUpperCase() == 'GET') {
       xmlHttp.open(self.options.type, self.options.url + (self.options.data == null ? "" : ((/[?]$/.test(self.options.url) ? '&' : '?') + self.options.data)), self.options.async);
   }
   else {
       xmlHttp.open(self.options.type, self.options.url, self.options.async);
       xmlHttp.setRequestHeader('Content-Length', self.options.data.length);
   }
   xmlHttp.setRequestHeader('Content-Type', self.options.contentType);
   xmlHttp.onreadystatechange = function () {
       if (xmlHttp.readyState == 4) {
           if (xmlHttp.status == 200 || xmlHttp.status == 0) {
               if (typeof self.options.success == 'function') self.options.success(xmlHttp.responseText);
               xmlHttp = null;
           }
           else {
               if (typeof self.options.error == 'function') self.options.error('Server Status: ' + xmlHttp.status);
           }
       }
   };

   xmlHttp.send(self.options.type.toUpperCase() == 'POST' ? self.options.data.toString() : null);
};
this.send();
};  
  1. JS StringBuilder 用法
function StringBuilder() {
this.strings = new Array;
};
StringBuilder.prototype.append = function (str) {
this.strings.push(str);
};
StringBuilder.prototype.toString = function () {
return this.strings.join('');
};
  1. JS加載到頂部LoadJS
function loadJS (url, fn) {
   var ss = document.getElementsByName('script'),
       loaded = false;
   for (var i = 0, len = ss.length; i < len; i++) {
       if (ss[i].src && ss[i].getAttribute('src') == url) {
           loaded = true;
           break;
       }
   }
   if (loaded) {
       if (fn && typeof fn != 'undefined' && fn instanceof Function) fn();
       return false;
   }
   var s = document.createElement('script'),
       b = false;
   s.setAttribute('type', 'text/javascript');
   s.setAttribute('src', url);
   s.onload = s.onreadystatechange = function () {
       if (!b && (!this.readyState || this.readyState == 'loaded' || this.readyState == 'complete')) {
           b = true;
           if (fn && typeof fn != 'undefined' && fn instanceof Function) fn();
       }
   };
   document.getElementsByTagName('head')[0].appendChild(s);
},
bind: function (objId, eventType, callBack) {  //適用于任何瀏覽器的綁定
   var obj = document.getElementById(objId);
   if (obj.addEventListener) {
       obj.addEventListener(eventType, callBack, false);
   }
   else if (window.attachEvent) {
       obj.attachEvent('on' + eventType, callBack);
   }
   else {
       obj['on' + eventType] = callBack;
   }
}

function JSLoad (args) {
   s = document.createElement("script");
   s.setAttribute("type", "text/javascript");
   s.setAttribute("src", args.url);
   s.onload = s.onreadystatechange = function () {
       if (!s.readyState || s.readyState == "loaded" || s.readyState == "complete") {
           if (typeof args.callback == "function") args.callback(this, args);
           s.onload = s.onreadystatechange = null;
           try {
               s.parentNode && s.parentNode.removeChild(s);
           } catch (e) { }
       }
   };
   document.getElementsByTagName("head")[0].appendChild(s);
}

21.清空LoadJS加載到頂部的js引用

function ClearHeadJs  (src) {
   var js = document.getElementsByTagName('head')[0].children;
   var obj = null;
   for (var i = 0; i < js.length; i++) {
       if (js[i].tagName.toLowerCase() == "script" && js[i].attributes['src'].value.indexOf(src) > 0) {
           obj = js[i];
       }
   }
   document.getElementsByTagName('head')[0].removeChild(obj);
};  
  1. JS替換非法字符主要用在密碼驗(yàn)證上出現(xiàn)的特殊字符
function URLencode(sStr) {
return escape(sStr).replace(/+/g, '%2B').replace(/"/g, '%22').replace(/'/g, '%27').replace(///g, '%2F');
}; 
  1. 按Ctrl + Entert 直接提交表單
document.body.onkeydown = function (evt) {
evt = evt ? evt : (window.event ? window.event : null);
if (13 == evt.keyCode && evt.ctrlKey) {

   evt.returnValue = false;
   evt.cancel = true;
   PostData();
}
}; 

24.獲取當(dāng)前時(shí)間

function GetCurrentDate() {
   var d = new Date();
   var y = d.getYear()+1900;
   month = add_zero(d.getMonth() + 1),
   days = add_zero(d.getDate()),
   hours = add_zero(d.getHours());
   minutes = add_zero(d.getMinutes()),
   seconds = add_zero(d.getSeconds());
   var str = y + '-' + month + '-' + days + ' ' + hours + ':' + minutes + ':' + seconds;
   return str;
};
function add_zero(temp) {
   if (temp < 10) return "0" + temp;
   else return temp;
}
  1. Js去掉空格方法
String.prototype.Trim = function()
{ return this.replace(/(^s*)|(s*$)/g, ""); }
String.prototype.LTrim = function()
{return this.replace(/(^s*)/g, "");}
String.prototype.RTrim = function()
{return this.replace(/(s*$)/g, "");} 
  1. Js動(dòng)態(tài)移除head里的js引用
this.ClearHeadJs = function (src) {
var js = document.getElementsByTagName('head')[0].children;
var obj = null;
for (var i = 0; i < js.length; i++) {
   if (js[i].tagName.toLowerCase() == "script" && js[i].attributes['src'].value.indexOf(src) > 0) {
       obj = js[i];
   }
}
document.getElementsByTagName('head')[0].removeChild(obj);
}; 

27.整個(gè)UL點(diǎn)擊事件 加在UL里的onclick里

function CreateFrom(url, params) {
var f = document.createElement("form");
f.setAttribute("action", url);
for (var i = 0; i < params.length; i++) {
    var input = document.createElement("input");
    input.setAttribute("type", "hidden");
    input.setAttribute("name", params[i].paramName);
    input.setAttribute("value", params[i].paramValue);
    f.appendChild(input);
}
f.target = "_blank";
document.body.appendChild(f);
f.submit();
};
  1. 判斷瀏覽器使用的是哪個(gè) JS 版本
<script language="javascript">
 var jsversion = 1.0;
</script>
<script language="javascript1.1">
 jsversion = 1.1;
</script>
<script language="javascript1.2">
 jsversion = 1.2;
</script>
<script language="javascript1.3">
 jsversion = 1.3;
</script>
<script language="javascript1.4">
 jsversion = 1.4;
</script>
<script language="javascript1.5">
 jsversion = 1.5;
</script>
<script language="javascript1.6">
 jsversion = 1.6;
</script>
<script language="javascript1.7">
 jsversion = 1.7;
</script>
<script language="javascript1.8">
 jsversion = 1.8;
</script>
<script language="javascript1.9">
 jsversion = 1.9;
</script>
<script language="javascript2.0">
 jsversion = 2.0;
</script>
alert(jsversion)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市谚攒,隨后出現(xiàn)的幾起案子鸡典,更是在濱河造成了極大的恐慌腰耙,老刑警劉巖榛丢,帶你破解...
    沈念sama閱讀 216,402評(píng)論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異挺庞,居然都是意外死亡晰赞,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)挠阁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)宾肺,“玉大人,你說(shuō)我怎么就攤上這事侵俗∠怯茫” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,483評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵隘谣,是天一觀的道長(zhǎng)增拥。 經(jīng)常有香客問(wèn)我,道長(zhǎng)寻歧,這世上最難降的妖魔是什么掌栅? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,165評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮码泛,結(jié)果婚禮上猾封,老公的妹妹穿的比我還像新娘。我一直安慰自己噪珊,他們只是感情好晌缘,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著痢站,像睡著了一般磷箕。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上阵难,一...
    開(kāi)封第一講書(shū)人閱讀 51,146評(píng)論 1 297
  • 那天岳枷,我揣著相機(jī)與錄音,去河邊找鬼呜叫。 笑死空繁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的朱庆。 我是一名探鬼主播盛泡,決...
    沈念sama閱讀 40,032評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼椎工!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,896評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤维蒙,失蹤者是張志新(化名)和其女友劉穎掰吕,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體颅痊,經(jīng)...
    沈念sama閱讀 45,311評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡殖熟,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了斑响。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片菱属。...
    茶點(diǎn)故事閱讀 39,696評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖舰罚,靈堂內(nèi)的尸體忽然破棺而出纽门,到底是詐尸還是另有隱情,我是刑警寧澤营罢,帶...
    沈念sama閱讀 35,413評(píng)論 5 343
  • 正文 年R本政府宣布赏陵,位于F島的核電站,受9級(jí)特大地震影響饲漾,放射性物質(zhì)發(fā)生泄漏蝙搔。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評(píng)論 3 325
  • 文/蒙蒙 一考传、第九天 我趴在偏房一處隱蔽的房頂上張望吃型。 院中可真熱鬧,春花似錦僚楞、人聲如沸勤晚。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)运翼。三九已至,卻和暖如春兴枯,著一層夾襖步出監(jiān)牢的瞬間血淌,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,815評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工财剖, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留悠夯,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,698評(píng)論 2 368
  • 正文 我出身青樓躺坟,卻偏偏與公主長(zhǎng)得像沦补,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子咪橙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • 前端開(kāi)發(fā)面試知識(shí)點(diǎn)大綱: HTML&CSS: 對(duì)Web標(biāo)準(zhǔn)的理解夕膀、瀏覽器內(nèi)核差異虚倒、兼容性、hack产舞、CSS基本功:...
    秀才JaneBook閱讀 2,362評(píng)論 0 25
  • <a name='html'>HTML</a> Doctype作用魂奥?標(biāo)準(zhǔn)模式與兼容模式各有什么區(qū)別? (1)、<...
    clark124閱讀 3,472評(píng)論 1 19
  • 《裕語(yǔ)言》速成開(kāi)發(fā)手冊(cè)3.0 官方用戶(hù)交流:iApp開(kāi)發(fā)交流(1) 239547050iApp開(kāi)發(fā)交流(2) 10...
    葉染柒丶閱讀 26,633評(píng)論 5 19
  • 請(qǐng)參看我github中的wiki易猫,不定期更新耻煤。https://github.com/ivonzhang/Front...
    zhangivon閱讀 7,127評(píng)論 2 19
  • 今年10月初在非洲·肯尼亞旅行時(shí),每次的Safari途中, 總會(huì)聽(tīng)到Ben (我們?cè)诋?dāng)?shù)卣?qǐng)的私人司機(jī)兼向?qū)?滔滔不...
    RainbowPeng閱讀 500評(píng)論 0 2