前言
工作中常用到的類型判斷

Javascript
1.type類型判斷
????
typeof是一個(gè)操作符,其右側(cè)跟一個(gè)一元表達(dá)式,并返回這個(gè)表達(dá)式的數(shù)據(jù)類型。返回的結(jié)果用該類型的字符串(全小寫字母)形式表示,包括以下 7 種:number、boolean、symbol、string、object、undefined、function等。但是有些時(shí)候,typeof操作符會(huì)返回一些令人迷惑但技術(shù)上卻正確的值:對(duì)于基本類型,除null以外,均可以返回正確的結(jié)果。對(duì)于引用類型,除function以外,一律返回object類型。對(duì)于null,返回object類型。對(duì)于function返回function類型。
????toString()是Object的原型方法,調(diào)用該方法,默認(rèn)返回當(dāng)前對(duì)象的[[Class]]。這是一個(gè)內(nèi)部屬性,其格式為[object Xxx],其中Xxx就是對(duì)象的類型對(duì)于Object對(duì)象,直接調(diào)用toString()就能返回[object Object]。而對(duì)于其他對(duì)象,則需要通過call / apply來調(diào)用才能返回正確的類型信息。
<script>
isString (o) { //是否字符串
return Object.prototype.toString.call(o).slice(8, -1) === 'String'
}
isNumber (o) { //是否數(shù)字
return Object.prototype.toString.call(o).slice(8, -1) === 'Number'
}
isObj (o) { //是否對(duì)象
return Object.prototype.toString.call(o).slice(8, -1) === 'Object'
}
isArray (o) { //是否數(shù)組
return Object.prototype.toString.call(o).slice(8, -1) === 'Array'
}
isDate (o) { //是否時(shí)間
return Object.prototype.toString.call(o).slice(8, -1) === 'Date'
}
isBoolean (o) { //是否boolean
return Object.prototype.toString.call(o).slice(8, -1) === 'Boolean'
}
isFunction (o) { //是否函數(shù)
return Object.prototype.toString.call(o).slice(8, -1) === 'Function'
}
isNull (o) { //是否為null
return Object.prototype.toString.call(o).slice(8, -1) === 'Null'
}
isUndefined (o) { //是否undefined
return Object.prototype.toString.call(o).slice(8, -1) === 'Undefined'
}
isFalse (o) {
if (!o || o === 'null' || o === 'undefined' || o === 'false' || o === 'NaN') return true
return false
}
isTrue (o) {
return !this.isFalse(o)
}
</script>
2.機(jī)型判斷
通過判斷瀏覽器的userAgent,用正則來判斷手機(jī)是否是
[ios](蘋果)和[Android](安卓)客戶端
<script>
isIos () {
var u = navigator.userAgent;
if (u.indexOf('Android') > -1 || u.indexOf('Linux') > -1) {//安卓手機(jī)
// return "Android";
return false
} else if (u.indexOf('iPhone') > -1) {//蘋果手機(jī)
// return "iPhone";
return true
} else if (u.indexOf('iPad') > -1) {//iPad
// return "iPad";
return false
} else if (u.indexOf('Windows Phone') > -1) {//winphone手機(jī)
// return "Windows Phone";
return false
}else{
return false
}
}
isPC () { //是否為PC端
var userAgentInfo = navigator.userAgent;
var Agents = ["Android", "iPhone",
"SymbianOS", "Windows Phone",
"iPad", "iPod"];
var flag = true;
for (var v = 0; v < Agents.length; v++) {
if (userAgentInfo.indexOf(Agents[v]) > 0) {
flag = false;
break;
}
}
return flag;
}
browserType(){
var userAgent = navigator.userAgent; //取得瀏覽器的userAgent字符串
var isOpera = userAgent.indexOf("Opera") > -1; //判斷是否Opera瀏覽器
var isIE = userAgent.indexOf("compatible") > -1 && userAgent.indexOf("MSIE") > -1 && !isOpera; //判斷是否IE瀏覽器
var isEdge = userAgent.indexOf("Edge") > -1; //判斷是否IE的Edge瀏覽器
var isFF = userAgent.indexOf("Firefox") > -1; //判斷是否Firefox瀏覽器
var isSafari = userAgent.indexOf("Safari") > -1 && userAgent.indexOf("Chrome") == -1; //判斷是否Safari瀏覽器
var isChrome = userAgent.indexOf("Chrome") > -1 && userAgent.indexOf("Safari") > -1; //判斷Chrome瀏覽器
if (isIE) {
var reIE = new RegExp("MSIE (\\d+\\.\\d+);");
reIE.test(userAgent);
var fIEVersion = parseFloat(RegExp["$1"]);
if(fIEVersion == 7) return "IE7"
else if(fIEVersion == 8) return "IE8";
else if(fIEVersion == 9) return "IE9";
else if(fIEVersion == 10) return "IE10";
else if(fIEVersion == 11) return "IE11";
else return "IE7以下"http://IE版本過低
}
if (isFF) return "FF";
if (isOpera) return "Opera";
if (isEdge) return "Edge";
if (isSafari) return "Safari";
if (isChrome) return "Chrome";
}
</script>
3.注冊(cè)校驗(yàn)
JavaScript 可用來在數(shù)據(jù)被送往服務(wù)器前對(duì) HTML 表單中的這些輸入數(shù)據(jù)進(jìn)行驗(yàn)證。
<script>
checkStr (str, type) {
switch (type) {
case 'phone': //手機(jī)號(hào)碼
return /^1[3|4|5|6|7|8][0-9]{9}$/.test(str);
case 'tel': //座機(jī)
return /^(0\d{2,3}-\d{7,8})(-\d{1,4})?$/.test(str);
case 'card': //身份證
return /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/.test(str);
case 'pwd': //密碼以字母開頭,長度在6~18之間,只能包含字母、數(shù)字和下劃線
return /^[a-zA-Z]\w{5,17}$/.test(str)
case 'postal': //郵政編碼
return /[1-9]\d{5}(?!\d)/.test(str);
case 'QQ': //QQ號(hào)
return /^[1-9][0-9]{4,9}$/.test(str);
case 'email': //郵箱
return /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/.test(str);
case 'money': //金額(小數(shù)點(diǎn)2位)
return /^\d*(?:\.\d{0,2})?$/.test(str);
case 'URL': //網(wǎng)址
return /(http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-\.,@?^=%&:/~\+#]*[\w\-\@?^=%&/~\+#])?/.test(str)
case 'IP': //IP
return /((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d))/.test(str);
case 'date': //日期時(shí)間
return /^(\d{4})\-(\d{2})\-(\d{2}) (\d{2})(?:\:\d{2}|:(\d{2}):(\d{2}))$/.test(str) || /^(\d{4})\-(\d{2})\-(\d{2})$/.test(str)
case 'number': //數(shù)字
return /^[0-9]$/.test(str);
case 'english': //英文
return /^[a-zA-Z]+$/.test(str);
case 'chinese': //中文
return /^[\u4E00-\u9FA5]+$/.test(str);
case 'lower': //小寫
return /^[a-z]+$/.test(str);
case 'upper': //大寫
return /^[A-Z]+$/.test(str);
case 'HTML': //HTML標(biāo)記
return /<("[^"]*"|'[^']*'|[^'">])*>/.test(str);
default:
return true;
}
// 嚴(yán)格的身份證校驗(yàn),謝謝樓下兄弟提供更加詳細(xì)的身份驗(yàn)證
isCardID(sId) {
if (!/(^\d{15}$)|(^\d{17}(\d|X|x)$)/.test(sId)) {
alert('你輸入的身份證長度或格式錯(cuò)誤')
return false
}
//身份證城市
var aCity={11:"北京",12:"天津",13:"河北",14:"山西",15:"內(nèi)蒙古",21:"遼寧",22:"吉林",23:"黑龍江",31:"上海",32:"江蘇",33:"浙江",34:"安徽",35:"福建",36:"江西",37:"山東",41:"河南",42:"湖北",43:"湖南",44:"廣東",45:"廣西",46:"海南",50:"重慶",51:"四川",52:"貴州",53:"云南",54:"西藏",61:"陜西",62:"甘肅",63:"青海",64:"寧夏",65:"新疆",71:"臺(tái)灣",81:"香港",82:"澳門",91:"國外"};
if(!aCity[parseInt(sId.substr(0,2))]) {
alert('你的身份證地區(qū)非法')
return false
}
// 出生日期驗(yàn)證
var sBirthday=(sId.substr(6,4)+"-"+Number(sId.substr(10,2))+"-"+Number(sId.substr(12,2))).replace(/-/g,"/"),
d = new Date(sBirthday)
if(sBirthday != (d.getFullYear()+"/"+ (d.getMonth()+1) + "/" + d.getDate())) {
alert('身份證上的出生日期非法')
return false
}
// 身份證號(hào)碼校驗(yàn)
var sum = 0,
weights = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2],
codes = "10X98765432"
for (var i = 0; i < sId.length - 1; i++) {
sum += sId[i] * weights[i];
}
var last = codes[sum % 11]; //計(jì)算出來的最后一位身份證號(hào)碼
if (sId[sId.length-1] != last) {
alert('你輸入的身份證號(hào)非法')
return false
}
return true
}
}
</script>