js常用自定義公共函數(shù)匯總
更新時間:2014年01月15日 15:42:17 作者:
本文整理了一些js常用自定義公共函數(shù)如檢查是否是日期格式、判斷輸入的字符是否為中文、判斷是否為空、固定電話、手機號碼等等
復制代碼 代碼如下:
String.prototype.trim = function(){
return this.replace(/(^\s*)|(\s*$)/g, "");
}
//檢查是否是日期格式
function isDate(datestr){
var result = datestr.match(/((^((1[8-9]\d{2})|([2-9]\d{3}))(-)(10|12|0?[13578])(-)(3[01]|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(11|0?[469])(-)(30|[12][0-9]|0?[1-9])$)|(^((1[8-9]\d{2})|([2-9]\d{3}))(-)(0?2)(-)(2[0-8]|1[0-9]|0?[1-9])$)|(^([2468][048]00)(-)(0?2)(-)(29)$)|(^([3579][26]00)(-)(0?2)(-)(29)$)|(^([1][89][0][48])(-)(0?2)(-)(29)$)|(^([2-9][0-9][0][48])(-)(0?2)(-)(29)$)|(^([1][89][2468][048])(-)(0?2)(-)(29)$)|(^([2-9][0-9][2468][048])(-)(0?2)(-)(29)$)|(^([1][89][13579][26])(-)(0?2)(-)(29)$)|(^([2-9][0-9][13579][26])(-)(0?2)(-)(29)$))/);
if(result==null){
return "no";
}
return "yes";
}
//此方法以上面效果一致
function isDate2(datestr) {
var result = datestr.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
if (result == null)
return "no";
var d = new Date(result[1], result[3] - 1, result[4]);
if((d.getFullYear() == result[1] && (d.getMonth() + 1) == result[3] && d.getDate() == result[4])){
return "yes";
}
return "no";
}
//判斷輸入的字符是否為中文
function IsChinese(str){
if(str.length!=0){
reg=/^[\u0391-\uFFE5]+$/;
if(!reg.test(str)){
// alert("對不起,您輸入的字符串類型格式不正確!");
return "no";
}
}
return "yes";
}
//判斷是否為空
function isEmpty(str){
if(str==null||typeof str=="undefined"||str.trim()==""){
return true;
}else{
return false;
}
}
//固定電話
function testTelephone(phone){
var phone_reg = new RegExp(/^([+]{0,1}\d{3,4}|\d{3,4}-)?\d{7,8}$/);
if(!phone_reg.test(phone)){
return "no";
}
return "yes";
}
//折扣
function isDiscount(discount){
var phone_reg = new RegExp(/^(0([\.]\d{1,2})|1|1.00|1.0)$/);
if(!phone_reg.test(discount)){
return "no";
}
return "yes";
}
//手機號碼
function testMobile(mobile){
var mobile_reg = new RegExp(/^0{0,1}1[0-9]{10}$/);
if(!mobile_reg.test(mobile)){
return "no";
}
return "yes";
}
//QQ號碼從10000開始
function testQQ(qq){
var qq_reg = new RegExp(/^[1-9][0-9]{4,}$/);
if(!qq_reg.test(qq)){
return "no";
}
return "yes";
}
//電子郵件
function testEmail(email){
var email_reg = new RegExp(/^\w+([-+.]\w+)*@\w+([-.]\w+)*.\w+([-.]\w+)*$/);
if(!email_reg.test(email)){
return "no";
}
return "yes";
}
//不帶符號的正整數(shù)
function testPlusDigit(digit){
var plusDigit_reg = new RegExp(/^\d+$/);
if(!plusDigit_reg.test(digit)){
return "no";
}
return "yes";
}
//DOUBLE價格
function testPriceFormat(str){
var priceFormatReg = new RegExp(/^\d+(.\d{1,2})?$/);
if(!priceFormatReg.test(str)){
return "no";
}
return "yes";
}
//身份證
function testIDCard(str){
var IDCardReg = new RegExp(/(^\d{15}$)|(^\d{17}([0-9]|X)$)/);
if(!IDCardReg.test(str)){
return "no";
}
return "yes";
}
//2012-06-19日期格式
function testDate(str){
var dateReg = new RegExp(/(^\d{4}-[0,1][0-9]-[0-3][0-9]$)/);
if(!dateReg.test(str)){
return "no";
}
return "yes";
}
//浮點數(shù)精確運算(加法)
function accAdd(arg1,arg2){
var r1,r2,m,n;
try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}
try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}
m=Math.pow(10,Math.max(r1,r2));
n=(r1>=r2)?r1:r2;
return ((arg1*m+arg2*m)/m).toFixed(n);
}
Number.prototype.add = function (arg){
return accAdd(arg,this);
}
//浮點數(shù)精確運算(減法)
function accSub(arg1,arg2){
return accAdd(arg1,-arg2);
}
Number.prototype.subtract = function (arg){
return accSub(this,arg);
}
//浮點數(shù)精確運算(乘法)
function accMul(arg1,arg2)
{
var m=0,s1=arg1.toString(),s2=arg2.toString();
try{m+=s1.split(".")[1].length}catch(e){}
try{m+=s2.split(".")[1].length}catch(e){}
return Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m)
}
Number.prototype.mul = function (arg){
return accMul(arg, this);
}
//浮點數(shù)精確運算(除法)
function accDiv(arg1,arg2){
var t1=0,t2=0,r1,r2;
try{t1=arg1.toString().split(".")[1].length}catch(e){}
try{t2=arg2.toString().split(".")[1].length}catch(e){}
with(Math){
r1=Number(arg1.toString().replace(".",""))
r2=Number(arg2.toString().replace(".",""))
return (r1/r2)*pow(10,t2-t1);
}
}
Number.prototype.div = function (arg){
return accDiv(this, arg);
}
//限制輸入數(shù)字
function isNumber(e) {
if ($.browser.msie) {
if ( ((event.keyCode > 47) && (event.keyCode < 58)) ||
(event.keyCode == 8) ) {
return true;
} else {
return false;
}
} else {
if ( ((e.which > 47) && (e.which < 58)) ||
(e.which == 8) ) {
return true;
} else {
return false;
}
}
}
//字符串長度截取
function cutstr(str, len) {
var temp;
var icount = 0;
var patrn = /[^\x00-\xff]/;
var strre = "";
for (var i = 0; i < str.length; i++) {
if (icount < len - 1) {
temp = str.substr(i, 1);
if (patrn.exec(temp) == null) {
icount = icount + 1;
} else {
icount = icount + 2;
}
strre += temp;
} else {
break
}
}
return strre + "...";
}
//獲取域名主機
function getHost(url) {
var host = "null";
if (typeof url == "undefined" || null == url) {
url = window.location.href;
}
var regex = /^\w+\:\/\/([^\/]*).*/;
var match = url.match(regex);
if (typeof match != "undefined" && null != match) {
host = match[1];
}
return host;
}
//判斷某個值是否在所在范圍
//rang=1 表示正整數(shù)[0,2147483647] 2表示float[0,3.4028235E38]
//return= 'empty' 表示輸入為空,
function isRang(str,rang){
if(typeof str == "number"){
var num = Number(str);
//判斷是否在正整數(shù)范圍
if( rang == 1){
if(testPlusDigit(num)=="yes"){
if(num>=0&&num<=2147483647){
return "is_int";
}else{
return "is_not_int_rang";
}
}else{
return "is_not_int";
}
}else if(rang == 2){
if(testPriceFormat(num)=="yes"){
if(num>=0&&num<=3.4028235E38){
return "is_float";
}else{
return "is_not_float_rang";
}
}else{
return "is_not_float";
}
}else{
return "rang_is_not_right";
}
}else{
return "is_not_number";
}
}
您可能感興趣的文章:
- Javascript 中創(chuàng)建自定義對象的方法匯總
- Javascript創(chuàng)建自定義對象 創(chuàng)建Object實例添加屬性和方法
- jQuery asp.net 用json格式返回自定義對象
- JavaScript 類的定義和引用 JavaScript高級培訓 自定義對象
- JS自定義對象實現(xiàn)Java中Map對象功能的方法
- 構造函數(shù)+原型模式構造js自定義對象(最通用)
- javascript中自定義對象的屬性方法分享
- JavaScript實現(xiàn)創(chuàng)建自定義對象的常用方式總結
- JS 自定義帶默認值的函數(shù)
- 100個不能錯過的實用JS自定義函數(shù)
- JS自定義對象創(chuàng)建與簡單使用方法示例
相關文章
javascript document.execCommand() 常用解析
dom下execCommand命令的一些參數(shù)整理,需要的朋友可以參考下。2009-12-12
javascript數(shù)組操作方法小結和3個屬性詳細介紹
這篇文章主要介紹了javascript數(shù)組操作方法小結和3個屬性詳細介紹,需要的朋友可以參考下2014-07-07
Mobile Web開發(fā)基礎之四--處理手機設備的橫豎屏問題
這篇文章主要介紹了Mobile Web開發(fā)基礎之-—處理手機設備的橫豎屏,window.orientation屬性與onorientationchange事件以及media query方式是開發(fā)過程中需要注意到的兩種解決方式,需要的朋友可以參考下2017-08-08
Javascript模塊化編程(一)AMD規(guī)范(規(guī)范使用模塊)
這個系列的第一部分介紹了Javascript模塊的基本寫法,今天介紹如何規(guī)范地使用模塊,先想一想,為什么模塊很重要?接下來為您詳細介紹,感興趣的朋友可以了解下啊2013-01-01
淺談JavaScript中的apply/call/bind和this的使用
apply/call/bind三者的聯(lián)系就在于,都可以用來改變函數(shù)中 this 指向的值,且第一個參數(shù)為要指向的 this 的值,apply的第二個參數(shù)(或 bind 與 call 的不定參數(shù))為要傳入的參數(shù)。這就不得不提及 javascript 中函數(shù)的 this 的指向了。下面我們來簡單探討下2017-02-02

