浅谈javascript和java中的字符串
作者:网络转载 发布时间:[ 2015/5/29 14:17:04 ] 推荐标签:Java
javascript字符串操作
一、字符串的创建
创建一个字符串有几种方法。
1、简单的是用引号将一组字符包含起来 var myStr = "Hello, String!";// 在js中单双引号没有区别
2、可使用如下语句:var myStr1 = new String("Hello, String!");
console.log(typeof myStr);//"string"
console.log(typeof myStr1);//"object"
以上输出结果表明:myStr是一个简单类型变量,myStr1是一个对象
二、字符串"长度“方法
1、字符串的拼接
concat()或者“+”
2、字符串的截取
1、string.substring(from, to) 返回截取的字符串
参数分别是截取的首尾索引位置。注意:参数to的索引可以大于、小于、等于from的位置,也可以省略,不支持负数!
var str = "colin is a desinger";
section = str .substring(0, 4); // "coli"
section = str .substring(4, 0); // "coli"
section = str .substring(1, 1); // ""
section = str .substring(-2, 4); // "coli"
str .substring(0, 4);// "coli"<br>console.log(str) //"colin is a desinger";
2、string.slice(start, end) 返回截取的字符串
参数start表示子串的起始位置,如果为负数,那么可以理解为倒数第几个开始,例如-3表示从倒数第三个开始;参数end表示结束位置,与start一 样, 它也可以为负数,其含义也表示到倒数第几个结束。slice()的参数可以为负数,所以要比substring()更加灵活,但没那么宽容了,如果 start比end要大,它将返回一个空字符串
var str = "colin is a desinger";
section = str .slice(0, 4); // "coli"
section = str .slice(4, -1); // "n is a desinge"
section = str .slice(1, 1); // ""
str .slice(0, 4);// ""
console.log(str);//"colin is a desinger"
3、substr(start,len) 返回截取的字符串
参数start为开始的位置,len为子字符串的长度 注:不提倡用该函数(我暂时也不知道原因)
三、字符串的“位置”函数
1、str.indexOf(searchvalue,fromindex) 返回字符串中一个子串第一处出现的索引(从左到右搜索)。如果没有匹配项,返回 -1 。
2、str.charAt(index) 返回指定位置的字符
3、str.charCodeAt(index) 返回指定位置的字符的 Unicode 编码。这个返回值是 0 - 65535 之间的整数。
4、str.fromCharCode(numX,numX,...,numX) 可接受一个指定的 Unicode 值,然后返回一个字符串。
四、字符串的“正则”函数
1、威力强的js字符串函数--> str.replace(regexp/substr,replacement)
改方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。
参数 replacement是字符串:对于正则replace约定了一个特殊标记符$:
$i (i:1-99) : 表示从左到右正则子表达式所匹配的文本。
$&:表示与正则表达式匹配的全文本。
$`(`:切换技能键):表示匹配字符串的左边文本。
$’(‘:单引号):表示匹配字符串的右边文本。
$$:表示$转移。
"boy & girl".replace(/(w+)s*&s*(w+)/g,"$2 & $1") //girl & boy
"boy".replace(/w+/g,"$&-$&") // boy-boy
"javascript".replace(/script/,"$& != $`") //javascript != java
"javascript".replace(/java/,"$&$' is ") // javascript is script
第二个参数为函数:
在ECMAScript3推荐使用函数方式,实现于JavaScript1.2.当replace方法执行的时候每次都会调用该函数,返回值作为替换的新值。
函数参数的规定:
第一个参数为每次匹配的全文本($&)。
中间参数为子表达式匹配字符串,个数不限.( $i (i:1-99))
倒数第二个参数为匹配文本字符串的匹配下标位置。
后一个参数表示字符串本身。
String.prototype.capitalize = function(){
return this.replace( /(^|s)([a-z])/g , function(m,p1,p2){ return p1+p2.toUpperCase();
} );
};
2、str.match(rgExp)
如果 match 方法没有找到匹配,将返回 null。 如果找到匹配,则 match 方法返回一个数组,并将更新全局 RegExp 对象的属性以反映匹配结果。如果没有设置全局标志 (g),数组元素 0 包含整个匹配,而元素 1 到 n 包含任何一个子匹配。 此行为与未设置全局标志时 exec 方法(正则表达式)(JavaScript) 的行为相同。如果设置了全局标志,则元素 0 到元素 n 包含所有出现的匹配。如果未设置全局标志,则 match 方法返回的数组有两个特性:input 和 index。 input 属性包含整个被搜索的字符串。 index 属性包含了在整个被搜索字符串中匹配的子字符串的位置。如果设置了标志 i,则搜索不区分大小写。
五、其他常用方法
1、stringObj.trim() 从字符串中移除前导空格、尾随空格和行终止符。
2、str.toLowerCase() 小写
3、str.toUpperCase() 大写
。。。。。。。
六、字符串属性
1、string.constructor 指定创建一个字符串的函数。
var x = new String();
if (x.constructor == String)
document.write("Object is a String.");
else
document.write("Object is not a String.");
// Output:
// Object is a String.
2. string.prototype 为字符串的类返回原型的引用。
用 prototype 属性为对象的类提供一组基本功能。 对象的新的实例“继承”了赋予该对象的原型的行为。
例如,若要将方法添加到返回字符串的后一个元素的值的 String 对象,请声明函数、将它添加到 String.prototype 并使用它。
function string_last( ){
return this.charAt(this.length - 1);
}
String.prototype.last = string_last;
var myString = new String("every good boy does fine");
document.write(myString.last());
// Ou
七、JavaScript 字符串是不可变的 --》无法修改字符串的长度。
首先请看以下代码:
var a="java"
a=a+"script"
console.log(a);//"javascript"
变量a对应的字符串内容从”java“ 变为”javascript“,不是证明js字符串是可变的吗?(我开始学js的时候也这么认为)
切记:你要理解内存中那块区域不能改变。即第一样的变量a所指的内存地址,不是二行变量a所指的内存地址
后请看下面代码:
var lang = 'Java';
lang[lang.length-1] = 'S';
lang[lang.length-1] = 'c';
console.log(lang);//"java"
var arr = ['J', 'a', 'v', 'a'];
arr[arr.length-1] = 'S';
console.log(arr);// ['J', 'a', 'v', 'S'];
八、巧用数组实现js数组高效拼接
var start = new Date();
var str = "";
for (var i = 0; i < 1000000; i++) {
str += "test";
}
var end = new Date();
document.writeln("+拼接字符串,耗时:" + (end.getMilliseconds() - start.getMilliseconds()));
document.writeln("<br/>");
var begin = new Date();
var arry = new Array();
for (var i = 0; i < 1000000; i++) {
arry.push("test");
}
arry.join("");
var stop = new Date();
document.writeln("数组方式拼接字符串,耗时:" + (stop.getMilliseconds() - begin.getMilliseconds()));
九、回归字符串创建
先看以下代码:
var str="colin";
var str1=new String("colin");
str.substring(0,2); //str基本类型数据 ,为什么可以调用substring方法?
str1.substring(0,2); //str1对象
这里为什么str变量有substring方法,我暂时也不是很明白。我姑且认为在执行“str.substring()"代码的一瞬间,str变成了一个对象???!!
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11