热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JavaScriptstring字符串类型的扩展方法(搜集整理)

1.Js判断前缀后缀代码和判空(含全部是空格):Js判断后缀String.prototype.endsWithfunction(suffix){ret

1. Js 判断前缀后缀代码和判空(含全部是空格):

// Js 判断后缀 
String.prototype.endsWith = function(suffix) {  
    return this.indexOf(suffix, this.length - suffix.length) !== -1;  
};  

// Js 判断前缀
if (typeof String.prototype.startsWith != 'function') {
  // see below for better implementation!
  String.prototype.startsWith = function (str){
    return this.indexOf(str) == 0;
  };
}  
  
// Js 判空(含全部是空格)
String.prototype.IsNullEmptyOrSpace = function()  
{   
   if (this== null) return true;  
      return this.replace(/s/g, '').length == 0;  
};  


2. 去前后空格

//去除左边的空格

*/
String.prototype.LTrim  function()
{
        return this.replace(/(^\s*)/g, "");
}
 
/*

//去除右边的空格

*/
String.prototype.Rtrim  function()
{
        return this.replace(/(\s*$)/g, "");
}
/*

//去除前后空格

*/
String.prototype.Trim  function()
{
        return this.replace(/(^\s*)|(\s*$)/g, "");
}
/*


 

3. 取子串

//得到左边的字符串

*/
String.prototype.Left  function(len)
{
        if(isNaN(len)||lennull)
        {
                len  this.length;
        }
        else
        {
                if(parseInt(len)<0||parseInt(len)>this.length)
                {
                        len  this.length;
                }
        }
         
        return this.substr(0,len);
}
 
/*

//得到右边的字符串

*/
String.prototype.Right  function(len)
{
        if(isNaN(len)||lennull)
        {
                len  this.length;
        }
        else
        {
                if(parseInt(len)<0||parseInt(len)>this.length)
                {
                        len  this.length;
                }
        }
         
        return this.substring(this.length-len,this.length);
}
 
/*

//得到中间的字符串,注意从0开始

*/
String.prototype.Mid  function(start,len)
{
        return this.substr(start,len);
}
 
/*

//在字符串里查找另一字符串:位置从0开始

*/
String.prototype.InStr  function(str)
{
        if(strnull)
        {
                str  "";
        }
         
        return this.indexOf(str);
}
/*

//在字符串里反向查找另一字符串:位置0开始

*/
String.prototype.InStrRev  function(str)
{
        if(strnull)
        {
                str  "";
        }
         
        return this.lastIndexOf(str);
}
/*


4. 验证常用格式

 

//是否是正确的IP地址

*/
String.prototype.isIP  function()
{
        var reSpaceCheck  /^(\d+)\.(\d+)\.(\d+)\.(\d+)$/;
        if (reSpaceCheck.test(this))
        {
                this.match(reSpaceCheck);
                if (RegExp.$1 <255 && RegExp.$1 > 0 
                 && RegExp.$2 <255 && RegExp.$2 > 0 
                 && RegExp.$3 <255 && RegExp.$3 > 0 
                 && RegExp.$4 <255 && RegExp.$4 > 0) 
                {
                        return true;     
                }
                else
                {
                        return false;
                }
        }
        else
        {
                return false;
        }
    
}
 
/*

//是否是正确的长日期

*/
String.prototype.isLongDate  function()
{
        var r  this.replace(/(^\s*)|(\s*$)/g, "").match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/); 
        if(rnull)
        {
                return false; 
        }
        var d  new Date(r[1], r[3]-1,r[4],r[5],r[6],r[7]); 
        return (d.getFullYear()r[1]&&(d.getMonth()+1)r[3]&&d.getDate()r[4]&&d.getHours()r[5]&&d.getMinutes()r[6]&&d.getSeconds()r[7]);
}
/*

//是否是正确的短日期

*/
String.prototype.isShortDate  function()
{
        var r  this.replace(/(^\s*)|(\s*$)/g, "").match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/); 
        if(rnull)
        {
                return false; 
        }
        var d  new Date(r[1], r[3]-1, r[4]); 
        return (d.getFullYear()r[1]&&(d.getMonth()+1)r[3]&&d.getDate()r[4]);
}
/*

//是否是正确的日期

*/
String.prototype.isDate  function()
{
        return this.isLongDate()||this.isShortDate();
}
/*

//是否是手机

*/
String.prototype.isMobile  function()
{
        return /^0{0,1}13[0-9]{9}$/.test(this);
}
/*

//是否是邮件

*/
String.prototype.isEmail  function()
{
        return /^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/.test(this);
}
/*

//是否是邮编(中国)

*/
String.prototype.isZipCode  function()
{
        return /^[\\d]{6}$/.test(this);
}
/*

//是否是有汉字

*/
String.prototype.existChinese  function()
{
        //[\u4E00-\u9FA5]為漢字﹐[\uFE30-\uFFA0]為全角符號
        return /^[\x00-\xff]*$/.test(this);
}
/*

//是否是合法的文件名/目录名

*/
String.prototype.isFileName  function()
{
        return !/[\\\/\*\?\|:"<>]/g.test(this);
}
/*

//是否是有效链接

*/
String.prototype.isUrl  function()
{
        return /^http[s]?:\/\/([\w-]+\.)+[\w-]+([\w-./?%&]*)?$/i.test(this);
}
 
/*

//是否是有效的身份证(中国)

*/
String.prototype.isIDCard  function()
{
        var iSum0;
        var info"";
        var sId  this;
        var aCity{11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古",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:"台湾",81:"香港",82:"澳门",91:"国外"};
        if(!/^\d{17}(\d|x)$/i.test(sId))
        {
                return false;
        }
        sIdsId.replace(/x$/i,"a");
        //非法地区
        if(aCity[parseInt(sId.substr(0,2))]null)
        {
                return false;
        }
        var sBirthdaysId.substr(6,4)+"-"+Number(sId.substr(10,2))+"-"+Number(sId.substr(12,2));
        var dnew Date(sBirthday.replace(/-/g,"/"))
         
        //非法生日
        if(sBirthday!(d.getFullYear()+"-"+ (d.getMonth()+1) + "-" + d.getDate()))
        {
                return false;
        }
        for(var i  17;i>0;i--) 
        {
                iSum + (Math.pow(2,i) % 11) * parseInt(sId.charAt(17 - i),11);
        }
        if(iSum%11!1)
        {
                return false;
        }
        return true;
}
/*

//是否是有效的电话号码(中国)

*/
String.prototype.isPhoneCall  function()
{
        return /(^[0-9]{3,4}\-[0-9]{3,8}$)|(^[0-9]{3,8}$)|(^\([0-9]{3,4}\)[0-9]{3,8}$)|(^0{0,1}13[0-9]{9}$)/.test(this);
}
 
/*

//是否是数字

*/
String.prototype.isNumeric  function(flag)
{
        //验证是否是数字
        if(isNaN(this))
        {
                return false;
        }
        switch(flag)
        {
                case null:        //数字
                case "":
                        return true;
                case "+":        //正数
                        return                /(^\+?|^\d?)\d*\.?\d+$/.test(this);
                case "-":        //负数
                        return                /^-\d*\.?\d+$/.test(this);
                case "i":        //整数
                        return                /(^-?|^\+?|\d)\d+$/.test(this);
                case "+i":        //正整数
                        return                /(^\d+$)|(^\+?\d+$)/.test(this);                        
                case "-i":        //负整数
                        return                /^[-]\d+$/.test(this);
                case "f":        //浮点数
                        return                /(^-?|^\+?|^\d?)\d*\.\d+$/.test(this);
                case "+f":        //正浮点数
                        return                /(^\+?|^\d?)\d*\.\d+$/.test(this);                        
                case "-f":        //负浮点数
                        return                /^[-]\d*\.\d$/.test(this);                
                default:        //缺省
                        return true;                        
        }
}
/*

//是否是颜色(#FFFFFF形式)

*/
String.prototype.IsColor  function()
{
        var temp         this;
        if (temp"") return true;
        if (temp.length!7) return false;
        return (temp.search(/\#[a-fA-F0-9]{6}/) ! -1);
}
/*


 

5. 格式转换(全角,日期,Html编码)

//转换成全角

*/
String.prototype.toCase  function()
{
        var tmp  "";
        for(var i0;i0&&this.charCodeAt(i)<255)
                {
                        tmp + String.fromCharCode(this.charCodeAt(i)+65248);
                }
                else
                {
                        tmp + String.fromCharCode(this.charCodeAt(i));
                }
        }
        return tmp
}
/*

//对字符串进行Html编码

*/
String.prototype.toHtmlEncode  function()
{
        var str  this;
        strstr.replace(/&/g,"&");
        strstr.replace(//g,">");
        strstr.replace(/\'/g,"'");
        strstr.replace(/\"/g,""");
        strstr.replace(/\n/g,"
"); strstr.replace(/\ /g," "); strstr.replace(/\t/g,"    "); return str; } /* //转换成日期 */ String.prototype.toDate function() { try { return new Date(this.replace(/-/g, "\/")); } catch(e) { return null; } }


6.其他

//计算字符串打印长度

*/
String.prototype.LengthW  function()
{
        return this.replace(/[^\x00-\xff]/g,"**").length;
}
/*


 替换所有匹配的字串:

String.prototype.replaceAll function(find, replace) {
  return this.replace(new RegExp(find, 'g'), replace);
}


 


推荐阅读
  • 本文详细探讨了使用纯JavaScript开发经典贪吃蛇游戏的技术细节和实现方法。通过具体的代码示例,深入解析了游戏逻辑、动画效果及用户交互的实现过程,为开发者提供了宝贵的参考和实践经验。 ... [详细]
  • 本文详细介绍如何在SSM(Spring + Spring MVC + MyBatis)框架中实现分页功能。包括分页的基本概念、数据准备、前端分页栏的设计与实现、后端分页逻辑的编写以及最终的测试步骤。 ... [详细]
  • ASP.NET 进度条实现详解
    本文介绍了如何在ASP.NET中使用HTML和JavaScript创建一个动态更新的进度条,并通过Default.aspx页面进行展示。 ... [详细]
  • 解决JavaScript中法语字符排序问题
    在开发一个使用JavaScript、HTML和CSS的Web应用时,遇到从SQLite数据库中提取的法语词汇排序不正确的问题,特别是带重音符号的字母未按预期排序。 ... [详细]
  • 在处理木偶评估函数时,我发现可以顺利传递本机对象(如字符串、列表和数字),但每当尝试将JSHandle或ElementHandle作为参数传递时,函数会拒绝接受这些对象。这可能是由于这些句柄对象的特殊性质导致的,建议在使用时进行适当的转换或封装,以确保函数能够正确处理。 ... [详细]
  • 本文探讨了如何利用 jQuery 的 JSONP 技术实现跨域调用外部 Web 服务。通过详细解析 JSONP 的工作原理及其在 jQuery 中的应用,本文提供了实用的代码示例和最佳实践,帮助开发者解决跨域请求中的常见问题。 ... [详细]
  • 将JavaScript文件嵌入HTML文档是Web开发中的基本操作。常见的方法是通过在HTML文件中使用``标签来引用外部的.js文件。这种方法不仅保持了代码的整洁性,还便于管理和维护。此外,还可以利用模块化脚本和异步加载技术进一步提升页面性能。 ... [详细]
  • Gradle 是 Android Studio 中默认的构建工具,了解其基本配置对于开发效率的提升至关重要。本文将详细介绍如何在 Gradle 中定义和使用共享变量,以确保项目的一致性和可维护性。 ... [详细]
  • C/C++ 应用程序的安装与卸载解决方案
    本文介绍了如何使用Inno Setup来创建C/C++应用程序的安装程序,包括自动检测并安装所需的运行库,确保应用能够顺利安装和卸载。 ... [详细]
  • 汇总了2023年7月7日最新的网络安全新闻和技术更新,包括最新的漏洞披露、工具发布及安全事件。 ... [详细]
  • 本报告记录了嵌入式软件设计课程中的第二次实验,主要探讨了使用KEIL V5开发环境和ST固件库进行GPIO控制及按键响应编程的方法。通过实际操作,加深了对嵌入式系统硬件接口编程的理解。 ... [详细]
  • 本文探讨了使用Python实现监控信息收集的方法,涵盖从基础的日志记录到复杂的系统运维解决方案,旨在帮助开发者和运维人员提升工作效率。 ... [详细]
  • Awk是一款功能强大的文本分析与处理工具,尤其在数据解析和报告生成方面表现突出。它通过读取由换行符分隔的记录,并按照指定的字段分隔符来划分和处理这些记录,从而实现复杂的数据操作。 ... [详细]
  • 探讨了在HTML表单中使用元素代替进行表单提交的方法。 ... [详细]
  • JavaScript 跨域解决方案详解
    本文详细介绍了JavaScript在不同域之间进行数据传输或通信的技术,包括使用JSONP、修改document.domain、利用window.name以及HTML5的postMessage方法等跨域解决方案。 ... [详细]
author-avatar
润滑油一_576
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有