<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <!-- <script src="js/jquery-1.10.2.min.js"></script> -->
    <script src="js/jquery-3.3.1.min.js"></script>
    <style>

    </style>
</head>

<body>

    <script>
        var str = "i:0#.f|membership|#alex.hou@gds.ey.com";
        // charAt-code出现位置 和 code Unicode编码
        console.log(str.charAt(1));
        console.log(str.charCodeAt(1));

        // indexOf-字符串第一次出现某字母的位置, 第二个参数是左数第几个索引开始找 默认0
        console.log(str.indexOf("#"));
        console.log(str.indexOf("#", 4));

        // match-查找字符串中是否有相同的字符,有的话返回数组,第0位代表匹配的字符,index为第一次匹配到的索引,没有返回null, 如果是正则匹配 加上g是全字符串匹配,不加g是只匹配第一个
        var str = "2 plus!1 2 equal plus! 3 呵呵456";
        console.log(str.match("1"));
        console.log(str.match(/\d+/g));

        // substring- 方法用于提取字符串中介于两个指定下标之间的字符。  一个参数,从指定位置截取至最后, 两个参数,截取两个参数中间之间的字符。
        var str = "i:0#.f|membership|abcd@163.com";
        console.log(str);
        console.log(str.substring(18));
        console.log(str.substring(7, 17));
        // substr-   一个参数的时候和substring用法相同, 两个参数时,第一个参数代表从哪开始, 第二个参数代表从第一个参数之后数截取个数。
        console.log(str);
        console.log(str.substr(18));
        console.log(str.substr(7, 17));
        // replace
        var str = 'cat, bat, sat, fat';
        // replace-两个参数都为字符串的情况 - 在字符串中找到第一个参数,并将第一个参数替换为第二个参数,只替换一次
        var result = str.replace('at', 'xxx');
        console.log(str);
        console.log(result);
        // replace-两个参数,第一个被替换的为正则, 要替换的为字符串,  replace会替换字符串中出现的所有第一个正则参数。
        var result = str.replace(/at/g, 'xxx');
        console.log(str);
        console.log(result);
        // replace-第一个参数为正则,第二个参数为函数。函数里的三个参数分别代表匹配到的字符, 索引位置,以及原始字符串
        var result = str.replace(/at/g, function (match, i, originalText) {
            console.log("原始字符串------" + originalText);
            console.log("找到了:" + match + ' .... ' + "位置:" + i);
            console.log("replaceing....");
            return 'xxx';
        });
        console.log(result);
        // replace-第一个参数为正则,第二个参数为函数。函数不传参时, arguments[0],arguments[1],arguments[2] 分别代表匹配到的字符, 索引位置,以及原始字符串
        var result = str.replace(/at/g, function () {
            console.log(arguments[0] + '  ' + arguments[1] + '  ' + arguments[2]);
            return 'xxx'
        });
        console.log(result);
        // replace-demo function 去除字符串空格
        var str = '  hello world      ';
        console.log(str+"---"+str.length);
        console.log(str.replace(/(^\s*)|(\s*$)/g, '')+"---"+str.replace(/(^\s*)|(\s*$)/g, '').length);
        



        // console.log(str.split("i:0#.f|membership|")[1]);
    </script>
</body>

</html>

参考:


search
 执行一个正则表达式匹配查找。如果查找成功,返回字符串中匹配的索引值。否则返回 -1 。
 var index1 = a.search(re);
 //index1 = 0
 var index2 = b.search(re);
 //index2 = -1
 slice
 提取字符串的一部分,并返回一个新字符串(与 substring 相同)。
 var sub_string1 = a.slice(1);
 //sub_string1 = “ello”
 var sub_string2 = a.slice(1,4);
 //sub_string2 = “ell”
 split
 通过将字符串划分成子串,将一个字符串做成一个字符串数组。
 var arr1 = a.split("");
 //arr1 = [h,e,l,l,o]
 length
 返回字符串的长度,所谓字符串的长度是指其包含的字符的个数。
 var len = a.length();
 //len = 5
 toLowerCase
 将整个字符串转成小写字母。
 var lower_string = a.toLowerCase();
 //lower_string = “hello”
 toUpperCase
 将整个字符串转成大写字母。
 var upper_string = a.toUpperCase();
 //upper_string = “HELLO”/*
字符串函数扩充
*/
/*
//去除左边的空格
/
 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, “”);
 }/*
//得到左边的字符串
*/
 String.prototype.Left = function(len)
 {if(isNaN(len)||len==null)
 {
 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)||len==null)
 {
 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(str==null)
 {
 str = “”;
 }return this.indexOf(str);
 }/*
//在字符串里反向查找另一字符串:位置0开始
*/
 String.prototype.InStrRev = function(str)
 {if(str==null)
 {
 str = “”;
 }return this.lastIndexOf(str);
 }/*
//计算字符串打印长度
*/
 String.prototype.LengthW = function()
 {
 return this.replace(/[^\x00-\xff]/g,"**").length;
 }/*
//是否是正确的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*KaTeX parse error: Undefined control sequence: \d at position 19: …, "").match(/^(\̲d̲{1,4})(-|\/)(\d…/);
 if(r==null)
 {
 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*KaTeX parse error: Undefined control sequence: \d at position 19: …, "").match(/^(\̲d̲{1,4})(-|\/)(\d…/);
 if(r==null)
 {
 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 /1{6}$/.test(this);
 }/*
//是否是有汉字
/
 String.prototype.existChinese = function()
 {
 //[\u4E00-\u9FA5]為漢字﹐[\uFE30-\uFFA0]為全角符號
 return /2$/.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 iSum=0;
 var info="";
 var sId = this;varaCity={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,“a”);
 //非法地区
 if(aCity[parseInt(sId.substr(0,2))]==null)
 {
 return false;
 }var sBirthday=sId.substr(6,4)+"-"+Number(sId.substr(10,2))+"-"+Number(sId.substr(12,2));
var d=new 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})/.test(this);
 }/*
//是否是数字
*/
 String.prototype.isNumeric = function(flag)
 {
 //验证是否是数字
 if(isNaN(this))
 {return false;
 }switch(flag)
 {case null: //数字
 case “”:
 return true;
 case “+”: //正数
 return /(+?|\d?)\d*.?\d+KaTeX parse error: Undefined control sequence: \d at position 62: … /^-\̲d̲*\.?\d+/.test(this);
 case “i”: //整数
 return /(-?|+?|\d)\d+KaTeX parse error: Undefined control sequence: \d at position 64: … /(^\̲d̲+)|(^+?\d+KaTeX parse error: Undefined control sequence: \d at position 90: … /^[-]\̲d̲+/.test(this);
 case “f”: //浮点数
 return /(-?|+?|^\d?)\d*.\d+KaTeX parse error: Undefined control sequence: \+ at position 65: … /(^\̲+̲?|^\d?)\d*\.\d+/.test(this);
 case “-f”: //负浮点数
 return /3\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);
 }/*
//转换成全角
*/
 String.prototype.toCase = function()
 {
 var tmp = “”;
 for(var i=0;i<this.length;i++)
 {
 if(this.charCodeAt(i)>0&&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;str=str.replace(/&/g,"&");
 str=str.replace(/</g,"<");
 str=str.replace(/>/g,">");
 str=str.replace(/’/g,"’");
 str=str.replace(/"/g,""");
 str=str.replace(/\n/g,"
");
 str=str.replace(/\ /g," “);
 str=str.replace(/\t/g,”    ");return str;
 }/*
//转换成日期
*/
 String.prototype.toDate = function()
 {
 try
 {
 return new Date(this.replace(/-/g, “/”));
 }
 catch(e)
 {
 return null;
 }
 }1. \d ↩︎
2. \x00-\xff ↩︎
3. - ↩︎